/LegacySystemPreferences

(WIP) A pretty janky attempt to recreate old System Preferences for macOS Ventura.

Primary LanguageSwift

System Preferences Icon

Legacy System Preferences

An expiremental, slightly reverse-engineered attempt (with questionable stability) to return the old System Preferences to MacOS Ventura!


Software Support Software Support Stars

Example Screenshot



Functionality Warning

Due to the nature of the project, some old-macOS panes (such as Software Update or Siri) will definitely be unstable or have limited functionality (see Pane Status Table), some crucial features are not fully implemented (see Completion Checklist), and performance may not be the best depending on the task.

Some panes may require different privacy privileges in order to work properly. For example, screen recording for Appearance (weird, right?) or input monitoring for the keyboard menu in Accessibility.

Project Deets

Wat it do

In order restore the classic System Preferences (albeit in a pretty janky manner), we use the NSPreferencePane framework in order to interface with .prefPane files. New MacOS still contains the old .prefPanes, but most of the bundles are empty (as App Extensions are now used); so instead of using the newer empty files, we rip the completed old ones (these) out of a previous release of MacOS.

(We don't use the new App Extension files because they wouldn't have the classic look!)

Why it do

Because some of us miss the ways of old (see new System Settings). Sure, it may be possible to bring the actual System Preferences from an older release (like Monterey) and run it in Ventura (with the proper pref panes)...

...but it would be a pain to get it to run in most cases, and that method requires access to another Mac or a VM. If you want to go that route and it works, great! It probably will be less janky! Either way, this project is just an attempt of open-source revive-itizing, and was just a fun thing for me to throw togethar.

Misc Notes

The project is written in slightly messy Swift using a SwiftUI lifecycle, plus some good ol' Objective-C for legacy stuff. The app is compiled for x86 due to compatability reasons with old pref panes, and must run under Rosetta for Apple Silicon machines. This may causes some slower than appreciated performance when doing ceratin tasks, but that's the tradeoff.

No localization has been implemented just yet, working on that too...


Usage Guide

Old Preference Pane Installation

  1. Download the preference panes from here.

  2. Unzip the download. Use Finder to Rename > Add Text. Then, append the extension .prefPane to all items in unzipped directory.

  3. Make a folder /Library/LegacyPrefPanes and move the preference panes into it.

  4. Finally, open /Library/LegacyPrefPanes in Terminal, and run the pane_stripper.sh tool (located in source or release DMG). Don't forget to chmod it first!

  5. Now you are ready for..."nostalgia", I guess?

Note: Just like classic System Preferences, this app will not function without .prefPane files. If /Library/LegacyPrefPanes is empty or does not exist, you will have no panes available. You may also place panes under the native /Library/PreferencePanes directory, if you wish.

Using the pane_stripper tool

pane_stripper.sh removes the code signature of all pref panes in the current operating dir (for compatibilty), and flags them as safe to the system (to stop the system from killing the pane for not having a signature). It is necessary to use this tool for our method, and without it, old pref panes (most likely) will not run in the app.


Completion Checklist

This is a checklist of features that obviously existed in old System Preferences, which this project may or may not have currently.

  • Localization
  • AppleID Avatar Setting
  • Search Completion Dropwdown
  • User Avatar Collection
  • Search with Spotlight Focus
  • Backwards/Forwards Navigation
  • Crossfade Transitions
  • Alphabetical Pane Sorting
  • Pane Enable/Disable
  • 3rd Party Pane Support
  • Pane Loading
Notes: 3rd party panes are allowed but may still suffer instability depending on the vendor, architecture, and etc. Place them in /Library/PreferencePanes as you normally would.

Pane Status Table

This is a report on functionality of the old system pref panes (using these) running via this project.

Notes: Some panes, such as Appearance/General, work fine but may crash the app.
Status Pane(s)
Seemingly Working General, Spotlight, Language & Region, Sound, Sidecar, Date & Time, Energy Saver, Sharing, Network, Mouse, Security & Privacy, Extensions, Users & Groups, Mission Control
Missing Crucial Funcs Apple ID, Internet Accounts, Notifications, Desktop & Screensaver, Software Update, Startup Disk
Failing Fibre Channel, Dock, Family Sharing, Printer & Scanner, Siri, Bluetooth, Keyboard, Trackpad, Displays, Classroom, Profiles, Screen Time, Time Machine, Wallet
Untested or Seemingly Working Battery, CDs & DVDs

Contribution

If anyone wishes to contribute towards the app’s preference pane support and stability, feel free to make an issue detailing improvement suggestions or open a PR for the change. I will respond and evaluate propositions as quick as possible.


Usage Disclaimer

  • The app icon used by Legacy System Preferences was designed by Apple, not I, and belongs to the native System Preferences/Settings app.
  • The classic preference panes tested and avaiable for use by this app (I'm talking about the ones I have made available here) were written and licensed by Apple, not I, and were ripped from a previous release of MacOS.

If any preference pane (3rd party or from old macOS) contained by this app decides to wig out and bricks your machine or nukes your filesystem, don't blame me for the catastrophe. This project is very much a jank experiment. You've been warned!!!