Skip to content

Moved date.ex to Utils folder, and made the date formatting much simpler to use in the layouts#9

Merged
ddon merged 7 commits into
BeamLabEU:devfrom
alexdont:dev
Sep 3, 2025
Merged

Moved date.ex to Utils folder, and made the date formatting much simpler to use in the layouts#9
ddon merged 7 commits into
BeamLabEU:devfrom
alexdont:dev

Conversation

@alexdont
Copy link
Copy Markdown
Contributor

@alexdont alexdont commented Sep 3, 2025

No description provided.

@ddon ddon merged commit bd2b802 into BeamLabEU:dev Sep 3, 2025
ddon pushed a commit that referenced this pull request Nov 12, 2025
…11CV2T9MhcmteMVgLMwh8jR

Fix email system critical issues and improve reliability
ddon pushed a commit that referenced this pull request May 12, 2026
Code (PR #537 review items addressed):

- #1 BUG-MEDIUM: wrap `Annotations.delete/1` in `Repo.transaction/1` so
  comment-cascade + annotation-delete are atomic. Extracted into
  `delete_in_transaction/1` to keep the body flat (credo depth).
- #2 BUG-MEDIUM: sweep stale `resource_type = "annotation"` claims
  across 3 moduledocs (annotation.ex, v115.ex, etcher_adapter.ex). The
  implementation anchors comments to the file with
  `metadata.annotation_uuid` — docs now match reality.
- #5 BUG-LOW: narrow `delete_linked_comments` rescue to expected
  exception classes ([DBConnection.OwnershipError, Postgrex.Error,
  ArgumentError]) so logic bugs surface instead of being swallowed.
- #11 IMPROVEMENT-LOW: drop `normalize/1` — `Ecto.Changeset.cast/3`
  handles both atom- and string-keyed maps natively; the helper added
  silent failure-mode risk on typo'd keys.
- #12 IMPROVEMENT-LOW: drop in-repo `Code.ensure_loaded?(PhoenixKit.Annotations)`
  guard in MediaBrowser — Annotations is a core module, can't be
  missing.
- #19 NITPICK: drop `PhoenixKit.Modules.Storage` from
  AnnotationComposer's `@compile no_warn_undefined` (it's core, not
  optional — rename should fail loudly).
- #20 NITPICK: simplify `AnnotationComposerPosition.destroyed` guard.
- #21 NITPICK: fix misleading "Etcher's bootstrap uses `||` to preserve
  pre-existing slots" comment — PhoenixKit's JS owns the slots.
- #8 IMPROVEMENT-MEDIUM: gettext-wrap ~17 user-facing strings in
  AnnotationComposer (flash messages + heex literals + ARIA labels).

Credo / dialyzer:
- Alias `PhoenixKit.Annotations`, `PhoenixKit.Modules.Storage`,
  `PhoenixKit.Modules.Storage.EtcherAdapter`, `Storage.File` so the
  six "nested modules could be aliased" findings clear.
- Convert `first_attachment_thumbnail/1`'s single-clause `with` to
  `case` (credo readability).
- Add PhoenixKitComments-targeted entries to .dialyzer_ignore.exs for
  the annotations context + composer (optional sibling package,
  guarded at runtime).
- mix.lock picks up `etcher 0.1.0` via deps.get.

mix precommit: compile → format → credo --strict → dialyzer all clean.
Deferred to original author (Alex): #3 (race), #4 (upload rollback),
#6 (authz), #7 (schema-as-source), #9 (geometry validation), #10
(configurable component id), #13/#14 (locale-aware date + traverse_errors),
plus cosmetics #15-18, #22, #23. Disposition table in CLAUDE_REVIEW.md
updated separately.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
mdon added a commit to mdon/phoenix_kit that referenced this pull request May 19, 2026
`position: fixed` on the kebab menu would be interpreted relative to
the nearest containing block, not the viewport. Inside a `<dialog>`
on the top layer (or any ancestor with `transform`/`contain`/`filter`)
this shoves the menu hundreds of pixels off-screen instead of
anchoring under the trigger.

Surfaced by `phoenix_kit_projects` PR BeamLabEU#9's `PopupHostLive` — assignment
edit kebabs inside the modal frame rendered far right of the viewport
on the host application. Reproduced locally via the parent app's
`/projects-emit-demo` route.

Fix portals `[data-row-menu-content]` to `document.body` in `_open()`
before measuring, restores it to its original parent (tracked at
`mounted()`) in `_close()` so LiveView's morphdom patching keeps
finding the element on subsequent diffs. Without restoration the
menu would orphan on `<body>` and LV would re-create it inside the
row, doubling the DOM.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants