Page MenuHomePhabricator

Show fewer useless transactions when creating objects, especially with EditEngine forms
ClosedPublic

Authored by epriestley on Dec 17 2015, 6:18 PM.
Tags
None
Referenced Files
F18803872: D14810.id.diff
Sat, Oct 18, 4:22 AM
F18770846: D14810.id.diff
Wed, Oct 8, 3:31 PM
F18733057: D14810.id.diff
Tue, Sep 30, 9:09 PM
F18720441: D14810.diff
Mon, Sep 29, 6:54 PM
F18702760: D14810.diff
Sun, Sep 28, 1:24 AM
F18650523: D14810.diff
Sep 21 2025, 12:55 AM
F18618323: D14810.id35803.diff
Sep 14 2025, 11:46 PM
F18618140: D14810.diff
Sep 14 2025, 11:17 PM
Subscribers
None

Details

Summary

Fixes T7661. Ref T9527.

When you create a task, especially with an EditEngine form, you currently get more noise than is useful. For example:

alice created this task.
alice changed the edit policy from "All Users" to "Community (Project)".
alice added projects: Feature Request, Differential.
alice added a subscriber: alice.

Transaction (1) is a little useful, since it saves us from a weird empty state and shows the object creation time.

Transaction (2) is totally useless (and even misleading) because that's the default policy for the form.

Transaction (3) isn't completely useless but isn't very interesting, and probably not worth the real-estate.

Transaction (4) is totally useless.

(These transactions are uniquely useless when creating objects -- when editing them later, they're fine.)

This adds two new rules to hide transactions:

  • Hide transactions from object creation if the old value is empty (e.g., set title, set projects, set subscribers).
  • Hide transactions from object creation if the old value is the same as the form default value (e.g., set policy to default, set priorities to default, set status to default).
NOTE: These rules also hide the "created this object" transaction, since it's really one of those transaction types in all cases. I want to keep that around in the long term, but just have it be a separate TYPE_CREATE action -- currently, it is this weird, inconsistent action where we pick some required field (like title) and special-case the rendering if the old value is null. So fixing that is a bit more involved. For now, I'm just dropping these transactions completely, but intend to restore them later.
Test Plan
  • Created objects.
  • Usually saw no extra create transactions.
  • Saw extra create transactions when making an important change away from form defaults (e.g., overriding form policy).

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable