هذا غريب… هل قمت بتسجيل الدخول؟ أيضًا، هل جربت السحب جانبيًا لمعرفة ما إذا كان شريط التمرير الأفقي سيظهر؟
إذا كان الأمر كذلك، أتساءل عما إذا كانت هذه مشكلة تحدث فقط مع حسابات المشرفين.
إعجاب واحد (1)
pmusaraj
(Penar Musaraj)
28 أبريل 2026، 6:51م
44
أنا غير مسجل الدخول، وقد جربت السحب يمينًا ويسارًا.
ربما تكون هذه مشكلة تحدث مع المدراء. لا أرى تكرارًا للمشكلة مع مستخدم عادي في نافذة محاكاة جوال Chrome.
في الواقع: يمكنني تكرار المشكلة بصفتي مديرًا على مدونتنا الخاصة.
إعجابَين (2)
pmusaraj
(Penar Musaraj)
28 أبريل 2026، 7:04م
45
4 إعجابات
رائع، شكرًا لك! @pmusaraj
4 إعجابات
ملاحظة سريعة: بينما تم إصلاح هذا التدفق لـ Google One Tap، إلا أنه لا يزال يتصرف بهذه الطريقة عند استخدام تسجيل الدخول الأصلي في Discourse.
إعجاب واحد (1)
Falco
(Falco)
6 مايو 2026، 3:08م
48
نعمل على تحسين تلك العملية
main ← embed-full-app-signin-flow
drafted 04:08PM - 05 May 26 UTC
Previously, full app embeds loaded on a third-party domain could not see the for… um's session cookie, leaving users effectively logged out, and `showLogin` only opened a dead-end `/login` tab the iframe never reacted to.
This change adds an opt-in `embed_full_app_signin_flow` site setting that intercepts logged-out actions inside the iframe with a guided flow: an in-iframe modal opens a top-level sign-in tab that auto-closes via `postMessage` on success, and the iframe reloads to pick up the session cookie. On Safari, the flow first calls `requestStorageAccess()` to bypass ITP before opening the popup.
## Flow
1. User clicks an auth-gated action (Like, Reply CTA, etc.). `showLogin` / `showCreateAccount` (and the embed-topic-footer reply CTA) route into the new `embed-auth-flow` service.
2. **Safari only**: if `hasStorageAccess()` is false, an in-iframe modal asks the user to share their session. Confirming calls `requestStorageAccess()` (synchronously inside the click handler so user activation is preserved), persists the original intent, and reloads the iframe.
3. A sign-in modal opens a top-level `/login?embed_signin_callback=1` (or `/signup`) tab. A new `embed-signin-popup-callback` initializer detects a successful sign-in in that tab, posts a message to the opener, and closes the tab.
4. The iframe reloads on the explicit `postMessage` success signal so the user picks up their session. Plain popup close (user dismissed) tears down silently — no false "signed in" state.
## Setting
- `embed_full_app_signin_flow` (boolean, default `false`, in the `embedding` area). Off by default; the existing Safari-only on-load storage access prompt and the legacy `window.open("/login")` paths continue to run when the flag is off.
- Activating this requires the embed to be **same-site** to the host page (e.g. `forum.discourse.org` ↔ `meta.discourse.org`) **or** `same_site_cookies = "None"` for cross-site embeds. The browser's SameSite policy still applies to cookies after `requestStorageAccess()`, so cross-site Lax/Strict cookies cannot be delivered to the iframe.
## Implementation notes
- **User activation preserved.** The modal is rendered via `service:modal` with native `<button {{on "click" handler}}>` elements rather than `service:dialog` (which wraps actions in `next()` and breaks user activation), so `requestStorageAccess()` and `window.open()` see a live activation token.
- **Intent persisted across reload.** Sign-up vs. sign-in intent survives the storage-access reload via `sessionStorage`.
- **API-unsupported fallback.** On Safari without `document.requestStorageAccess`, the service opens a plain top-level login tab (no callback) instead of trapping the user in a popup that cannot bridge cookies.
- **Storage access denial is a dead-end on purpose.** The catch handler does not chain to a sign-in popup, since a sign-in tab cannot help an iframe that lacks storage access. The user retries the action to be re-prompted.
## Tests
`tests/unit/services/embed-auth-flow-test.js` covers the state machine: gating, the Safari/non-Safari split for Storage Access, post-reload handling (including signup-intent preservation), denial behaviour, popup URL routing, and the API-unsupported fallback.
التغيير معقد، لكننا نأمل في تحقيق تجربة مستخدم أفضل.
6 إعجابات
وجدت خطأ آخر في واجهة المستخدم:
عند النقر لتحرير منشوري، تظهر مساحة فارغة في أسفل الإطار المضمن (iframe) بدون محتوى. تظل النافذة النموذجية “القياسية” مفتوحة، لكن تعليق ليس بداخلها للتحرير. بالإضافة إلى ذلك، ينتقل العنصر الذي يعرض عدد منشورات الموضوع إلى اليسار.
إعجاب واحد (1)
Falco
(Falco)
7 مايو 2026، 8:27م
50
يبدو الأمر مشابهًا لخطأ في منشئ بوت الذكاء الاصطناعي، أليس كذلك يا @keegan ؟
إعجاب واحد (1)
keegan
(Keegan George)
8 مايو 2026، 8:29م
52
يجب أن يكون هذا قد تم حله الآن مع:
committed 06:11PM - 08 May 26 UTC
**Previously**, clicking "edit" on a post in embed mode or an AI bot PM
would op… en the standard floating composer.
**This change** adds inline edit support to both the embed-mode and AI
bot docked composers, intercepting the edit action via app events and
handling the PUT request directly, so users never leave the docked
composer flow.
----
Embed Mode:
<img width="670" height="401" alt="embed-mode"
src="https://github.com/user-attachments/assets/bd11afc6-b7f0-456d-b0be-ddb48fdd964e"
/>
AI Bot:
<img width="786" height="230" alt="ai-bot"
src="https://github.com/user-attachments/assets/7c63fa08-cb03-4a5a-9405-b0f204264d02"
/>
5 إعجابات
كنت أراجع الإحصائيات للتو وأتساءل عما إذا كان كل شيء يعمل كما هو متوقع. أرى أقل من 400 مشاهدة يومية للصفحات تحت قسم “المشاهدات المضمنة”.
وللخلفية، كان المجتمع بأكمله يحصل سابقًا على حوالي 8 آلاف مشاهدة للصفحة يوميًا قبل أن ننتقل إلى تضمين التطبيق الكامل — وقد قفز هذا الرقم أكثر من 5 أضعاف منذ إطلاقنا.
أليس من المفترض أن ينعكس هذا الفرق في قسم “المشاهدات المضمنة”؟
إعجاب واحد (1)
Falco
(Falco)
15 مايو 2026، 5:09م
55
Thiago_Mobilon:
5. احتكاك تسجيل الدخول
التدفق الحالي يمثل عائقًا كبيرًا في التحويل: ينقر المستخدم على تسجيل الدخول → يفتح تبويب جديد → يتم تسجيل الدخول → ينتهي الأمر بالمستخدم في الصفحة الرئيسية للمجتمع. عند العودة إلى منشور المدونة، لا يزال الإطار المصغر (iframe) يظهر وكأنه غير مسجل حتى يقوم المستخدم بتحديث الصفحة بالكامل يدويًا. هذه حلقة مربكة تدفع الناس إلى الاستسلام والمغادرة قبل التعليق.
منذ تفعيلنا للتضمين الجديد، تضاعفت عدد التسجيلات اليومية لدينا بأكثر من الضعف ، وهو أمر رائع. ومع ذلك، لم تتحرك مقاييس المشاركة لدينا على الإطلاق. في الواقع، انخفضت نسبة المستخدمين النشطين يوميًا إلى المستخدمين النشطين شهريًا (DAU/MAU) – لدينا المزيد من المستخدمين المسجلين، لكنهم لا يتفاعلون. لم تسجل مقاييس مثل “المستخدمون النشطون يوميًا” و"المساهمون الجدد" و"عدد المنشورات" أي زيادة.
هذا يثبت أن الناس يريدون الانضمام إلى المحادثة، لكنهم يضيعون في حلقة تسجيل الدخول ويتخلون عن المنشور قبل أن يتمكنوا فعليًا من التعليق.
تم إصلاح هذه المشكلة الآن، يرجى التحديث للحصول على تدفق تسجيل الدخول الجديد.
main ← embed-full-app-signin-flow
merged 04:07PM - 15 May 26 UTC
Previously, full app embeds loaded on a third-party domain could not see the for… um's session cookie, leaving users effectively logged out, and `showLogin` only opened a dead-end `/login` tab the iframe never reacted to.
This adds an `embed_full_app_signin_flow` site setting (on by default, gated to full app embed mode) that intercepts logged-out actions inside the iframe with a guided flow: bridge storage access if the iframe's cookie jar is partitioned, then either reload (if the user is already signed in elsewhere) or open a top-level sign-in tab and watch the session via polling.
## Flow
1. User clicks an auth-gated action (Reply CTA, Like, etc.). `showLogin` / `showCreateAccount` and the embed-topic-footer reply CTA route into the new `embed-auth-flow` service.
2. **If `document.hasStorageAccess()` is `false`** — Safari ITP, Firefox Total Cookie Protection, Chrome's 3p cookie phaseout — an in-iframe modal asks the user to share their session. Confirming calls `requestStorageAccess()` (synchronously inside the click handler so user activation is preserved).
3. Once we have access, the service probes `/session/current.json`. If the user is already signed in elsewhere (common Firefox ETP scenario), the iframe reloads to pick up the session — no popup.
4. Otherwise, a sign-in modal opens a top-level `/login?embed_signin_callback=1` (or `/signup`) tab and shows a waiting state with a spinner. The iframe polls `/session/current.json` every 3s for up to 5 min.
5. When polling sees a logged-in response, the iframe reloads. The popup self-closes once it has a session, driven by the `embed_signin_callback` query param + sessionStorage flag.
## Why polling instead of `postMessage`
The popup-side callback originally posted a success message back to the opener. Discourse's default `Cross-Origin-Opener-Policy` (`same-origin-allow-popups`) typically mismatches an embedding host's (`unsafe-none`), which severs `window.opener` on the popup's very first load — and any OAuth provider redirect amplifies this. Polling sidesteps the whole opener relationship and works regardless of COOP, OAuth, or the user opening the link in a new tab.
## Setting
- `embed_full_app_signin_flow` (boolean, default `true`, in the `embedding` area).
- The flow assumes the iframe can receive its cookies after popup sign-in — true when the embed is **same-site to the host page** (any SameSite setting) or when `same_site_cookies = "None"` is configured for cross-site embeds. We trust the admin to enable this only on a compatible deployment.
## Implementation notes
- **Browser-agnostic storage access.** `hasStorageAccess()` is the single signal — `true` on same-site/same-origin embeds (no prompt needed), `false` whenever the iframe's cookie jar is partitioned. No browser sniffing.
- **User activation preserved.** The modal uses native `<button {{on "click" handler}}>` rather than `service:dialog`, so `requestStorageAccess()` and `window.open()` see a live activation token in the click handler.
- **No reload after storage access.** `requestStorageAccess()` grants access for the current document; we chain directly into the next step in the same execution. Reloading would put the iframe back in partitioned mode in most browsers.
- **Popup self-close is param-driven, not opener-driven.** The callback initializer keys off `?embed_signin_callback=1` alone — `window.opener` is unreliable thanks to COOP.
- **API-unsupported fallback.** Without `document.requestStorageAccess`, the service opens a plain top-level login tab (no callback param) instead of trapping the user in a popup that cannot bridge cookies.
- **Storage access denial is a dead-end on purpose.** The catch handler does not chain to a sign-in popup, since a sign-in tab cannot help an iframe that lacks storage access. The user retries the action to be re-prompted.
- **Waiting modal.** While polling, the iframe shows a spinner and "Waiting for sign-in" message. Cancel stops the poll and closes the popup; the modal auto-dismisses on timeout.
## Tests
`tests/unit/services/embed-auth-flow-test.js` covers gating, the partitioned vs. non-partitioned split, the storage-access → sign-in chain, the already-signed-in → reload path, denial behaviour, popup URL routing, and the API-unsupported fallback.
4 إعجابات
أعتقد أن ميزة الردود المتداخلة الجديدة قد لا تكون متوافقة مع وضع التضمين.
لقد قمت بتفعيل الردود المتداخلة في موضوع ما لاختبارها، وبدلاً من تحميل قسم التعليقات، انتهى الأمر بإطار الـ iframe بتحميل المنشور داخل المنشور.
إعجاب واحد (1)