PowerToys/doc/planning/awake.md
Den Delimarsky 1be3b6c087
[Awake]Refactor and update version - DAISY023_04102024 (#32378)
Improves the following:

- Consolidates different code paths for easier maintenance.
- Removes the dependency on Windows Forms and creates the system tray
icon and handling through native Win32 APIs (massive thank you to
@BrianPeek for helping write the window creation logic and diagnosing
threading issues).
- Changing modes in Awake now triggers icon changes in the tray
(#11996). Massive thank you to @niels9001 for creating the icons.

Fixes the following:

- When in the UI and you select `0` as hours and `0` as minutes in
`TIMED` awake mode, the UI becomes non-responsive whenever you try to
get back to timed after it rolls back to `PASSIVE`. (#33630)
- Adds the option to keep track of Awake state through tray tooltip.
(#12714)

---------

Co-authored-by: Clint Rutkas <clint@rutkas.com>
Co-authored-by: Jaime Bernardo <jaime@janeasystems.com>
2024-07-25 17:09:17 +01:00

3.6 KiB

last-update
7-16-2024

PowerToys Awake Changelog

Builds

The build ID can be found in Core\Constants.cs in the BuildId variable - it is a unique identifier for the current builds that allows better diagnostics (we can look up the build ID from the logs) and offers a way to triage Awake-specific issues faster independent of the PowerToys version. The build ID does not carry any significance beyond that within the PowerToys code base.

The build ID moniker is made up of two components - a reference to a Halo character, and the date when the work on the specific build started in the format of MMDDYYYY.

Build ID Build Date
DAISY023_04102024 April 10, 2024
ATRIOX_04132023 April 13, 2023
LIBRARIAN_03202022 March 20, 2022
ARBITER_01312022 January 31, 2022

DAISY023_04102024 (April 10, 2024)

Note

See pull request: Awake Update - DAISY023_04102024

  • #33630 When in the UI and you select 0 as hours and 0 as minutes in TIMED awake mode, the UI becomes non-responsive whenever you try to get back to timed after it rolls back to PASSIVE.
  • #12714 Adds the option to keep track of Awake state through tray tooltip.
  • #11996 Adds custom icons support for mode changes in Awake.
  • Removes the dependency on System.Windows.Forms and instead uses native Windows APIs to create the tray icon.
  • Removes redundant/unused code that impacted application performance.
  • Updates dependent packages to their latest versions (Microsoft.Windows.CsWinRT and System.Reactive).

ATRIOX_04132023 (April 13, 2023)

  • Moves from using Task.Run to spin up threads to actually using a blocking queue that properly sets thread parameters on the same thread.
  • Moves back to using native Windows APIs through P/Invoke instead of using a package.
  • Move away from custom logging and to built-in logging that is consistent with the rest of PowerToys.
  • Updates System.CommandLine and System.Reactive to the latest preview versions of the package.

LIBRARIAN_03202022 (March 20, 2022)

  • Changed the tray context menu to be following OS conventions instead of the style offered by Windows Forms. This introduces better support for DPI scaling and theming in the future.
  • Custom times in the tray can now be configured in the settings.json file for awake, through the tray_times property. The property values are representative of a Dictionary<string, int> and can be in the form of "YOUR_NAME": LENGTH_IN_SECONDS:
{
    "properties": {
        "awake_keep_display_on": true,
        "awake_mode": 2,
        "awake_hours": 0,
        "awake_minutes": 3,
        "tray_times": {
            "Custom length": 1800,
            "Another custom length": 3600
        }
    },
    "name": "Awake",
    "version": "1.0"
}
  • Proper Awake background window closure was implemented to ensure that the process collects the correct handle instead of the empty one that was previously done through System.Diagnostics.Process.GetCurrentProcess().CloseMainWindow(). This likely can help with the Awake process that is left hanging after PowerToys itself closes.