Page MenuHomePhabricator

Make "renderer", "engine", and "encoding" sticky across reloads in Differential and Diffusion
ClosedPublic

Authored by epriestley on Apr 17 2020, 11:18 PM.
Tags
None
Referenced Files
F14757361: D21138.id50349.diff
Wed, Jan 22, 12:36 AM
Unknown Object (File)
Tue, Jan 21, 11:03 AM
Unknown Object (File)
Tue, Jan 21, 1:02 AM
Unknown Object (File)
Sun, Jan 19, 3:51 AM
Unknown Object (File)
Thu, Jan 16, 12:54 PM
Unknown Object (File)
Sun, Jan 5, 9:11 PM
Unknown Object (File)
Dec 21 2024, 3:35 PM
Unknown Object (File)
Dec 17 2024, 5:50 AM
Subscribers
None

Details

Summary

Ref T13455. Update the other "view state" properties to work like "highlight" now works.

Some complexity here arises from these concerns:

  • In "View Standalone", we render the changeset inline. This is useful for debugging/development, and desirable to retain.
  • In all other cases, we render the changeset with AJAX.

So the client needs to be able to learn about the "state" properties of the changeset on two different flows. Prior to this change, each pathway had a fair amount of unique code.

Then, some bookkeeping issues:

  • At inital rendering time, we may not know which renderer will be selected: it may be based on the client viewport dimensions.
  • Prior to this change, the client didn't separate "value of the property for the changeset as rendered" and "desired value of the property".
Test Plan
  • Viewed changes in Differential, Diffusion, and in standalone mode.
  • Toggled renderer, character sets, and document engine (this one isn't terribly useful). Reloaded, saw them stick.
  • Started typing a comment, cancelled it, hit the undo UI.

Diff Detail

Repository
rP Phabricator
Branch
sticky2
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 24153
Build 33261: Run Core Tests
Build 33260: arc lint + arc unit