diff --git a/src/layout/melissa/MelissaPerfil.vue b/src/layout/melissa/MelissaPerfil.vue
index 4ffd232..6e8f62f 100644
--- a/src/layout/melissa/MelissaPerfil.vue
+++ b/src/layout/melissa/MelissaPerfil.vue
@@ -15,7 +15,7 @@
* Logica de load/save espelhada do ProfilePage.vue (mesmas tabelas
* profiles + user_settings + auth.user_metadata, mesmo bucket avatars).
*/
-import { ref, reactive, computed, onMounted, onBeforeUnmount } from 'vue';
+import { ref, reactive, computed, onMounted, onBeforeUnmount, nextTick } from 'vue';
import { useToast } from 'primevue/usetoast';
import { useConfirm } from 'primevue/useconfirm';
import { useRouter } from 'vue-router';
@@ -402,6 +402,34 @@ async function saveAll() {
}
}
+// ── Ancoras: badge/dica leva pra sessao do form ────────────
+const SECTION_BY_FIELD = {
+ full_name: 'identidade',
+ nickname: 'identidade',
+ work_description: 'identidade',
+ name: 'identidade',
+ nick: 'identidade',
+ work: 'identidade',
+ avatar: 'avatar',
+ photo: 'avatar',
+ bio: 'bio',
+ phone: 'contato',
+ social: 'redes'
+};
+
+function scrollToSection(field) {
+ const sec = SECTION_BY_FIELD[field];
+ if (!sec) return;
+ // Avatar fica na sidebar; em mobile mantem o drawer aberto (e nao scrolla
+ // o main, pq a sessao nao existe no main).
+ const isAvatar = sec === 'avatar';
+ if (isMobile.value && !isAvatar) drawerOpen.value = false;
+ nextTick(() => {
+ const target = document.getElementById('mpr-sec-' + sec);
+ if (target) target.scrollIntoView({ behavior: 'smooth', block: 'start' });
+ });
+}
+
// ── Sair da conta ──────────────────────────────────────────
function confirmSignOut() {
confirm.require({
@@ -557,34 +585,38 @@ onBeforeUnmount(() => {
Conquistas
-
{{ badge.icon }}
{{ badge.label }}
-
+
O que falta
-
{{ tip.text }}
-
+
-
+
Avatar
@@ -642,7 +674,7 @@ onBeforeUnmount(() => {
-
+
Identidade
@@ -712,7 +744,7 @@ onBeforeUnmount(() => {
-
+
Contato
@@ -740,6 +772,7 @@ onBeforeUnmount(() => {
id="mpr_email"
:value="userEmail"
readonly
+ placeholder=" "
class="w-full"
/>
@@ -750,7 +783,7 @@ onBeforeUnmount(() => {
-
+
Bio
@@ -770,7 +803,7 @@ onBeforeUnmount(() => {
-
+
Sites e Redes
@@ -1043,6 +1076,7 @@ onBeforeUnmount(() => {
.mpr-main {
flex: 1;
min-width: 0;
+ min-height: 0;
overflow-y: auto;
overflow-x: hidden;
padding: 16px;
@@ -1058,6 +1092,23 @@ onBeforeUnmount(() => {
border-radius: 3px;
}
+/* Desktop (>=1024px): cards em 2 colunas (50/50). Internal grid
+ colapsa pra 1 col pra nao ficar cramped. */
+@media (min-width: 1024px) {
+ .mpr-main {
+ display: grid;
+ grid-template-columns: repeat(2, 1fr);
+ gap: 12px;
+ align-content: start;
+ }
+ .mpr-main .mpr-grid {
+ grid-template-columns: 1fr;
+ }
+ .mpr-main .mpr-field--half {
+ grid-column: 1 / -1;
+ }
+}
+
/* ═══════ Card-base (mpr-w) ═══════ */
.mpr-w {
background: var(--m-bg-medium);
@@ -1183,7 +1234,11 @@ onBeforeUnmount(() => {
border-radius: 999px;
border: 1px solid var(--m-border);
font-size: 0.7rem;
+ font-family: inherit;
+ cursor: pointer;
+ transition: transform 120ms ease, background-color 120ms ease;
}
+.mpr-badge:hover { transform: translateY(-1px); }
.mpr-badge.is-earned {
background: color-mix(in srgb, var(--p-primary-color) 14%, transparent);
border-color: color-mix(in srgb, var(--p-primary-color) 38%, transparent);
@@ -1222,6 +1277,15 @@ onBeforeUnmount(() => {
border: 1px solid var(--m-border);
color: var(--m-text-muted);
font-size: 0.72rem;
+ font-family: inherit;
+ cursor: pointer;
+ text-align: left;
+ transition: background-color 120ms ease, color 120ms ease, border-color 120ms ease;
+}
+.mpr-tip:hover {
+ background: color-mix(in srgb, var(--p-primary-color) 12%, transparent);
+ border-color: color-mix(in srgb, var(--p-primary-color) 38%, transparent);
+ color: var(--p-primary-color);
}
.mpr-tip > i { font-size: 0.7rem; color: var(--p-primary-color); }