|
|
@@ -9,12 +9,12 @@ Dark Mode for Zenith's Grabber view! |
|
|
|
Copyright 2020 J.K. Hayslip (@iKilledAppl3) & ToxicAppl3 INSDC/iKilledAppl3 LLC. |
|
|
|
All code was written for learning purposes and credit must be given to the original author. |
|
|
|
|
|
|
|
Written for Cooper Hull, @(mac-user669). |
|
|
|
Written for Cooper Hull, @mac-user669. |
|
|
|
|
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
%group Tweak13 |
|
|
|
%group Adaptive |
|
|
|
// We then hook the class in this case Zenith's grabber view is called “ZNGrabberAccessoryView” |
|
|
|
%hook ZNGrabberAccessoryView |
|
|
|
|
|
|
@@ -25,11 +25,11 @@ Written for Cooper Hull, @(mac-user669). |
|
|
|
// if the tweak is enabled and the version is iOS 13 or later run our code |
|
|
|
if (@available(iOS 13, *)) { |
|
|
|
if (self.traitCollection.userInterfaceStyle == UIUserInterfaceStyleDark) { |
|
|
|
[self setBackgroundColor:kDarkModeColor]; |
|
|
|
[self setBackgroundColor:kDarkColor]; |
|
|
|
} |
|
|
|
|
|
|
|
else { |
|
|
|
[self setBackgroundColor:kLightModeColor]; |
|
|
|
[self setBackgroundColor:kLightColor]; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@@ -50,7 +50,7 @@ else { |
|
|
|
// by default have our tweak overide this. |
|
|
|
if (@available(iOS 13, *)) { |
|
|
|
if (self.traitCollection.userInterfaceStyle == UIUserInterfaceStyleDark) { |
|
|
|
%orig(kDarkModeColor); |
|
|
|
%orig(kDarkColor); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
@@ -63,10 +63,73 @@ else { |
|
|
|
%end // We need to make sure we tell theos that we are finished hooking this class not doing so with cause the end of the world :P |
|
|
|
%end |
|
|
|
|
|
|
|
static BOOL ios13; |
|
|
|
|
|
|
|
%group justDark |
|
|
|
|
|
|
|
%group Tweak12 |
|
|
|
//We then hook the class in this case Zenith's grabber view is called “ZNGrabberAccessoryView” |
|
|
|
%hook ZNGrabberAccessoryView |
|
|
|
// The method we then modify is this method that is called from UIImageView to set the backgroundColor of the image view. |
|
|
|
// Since the grabber view is of type UIImageView we can modify this method :) |
|
|
|
|
|
|
|
-(void)setBackgroundColor:(UIColor *)backgroundColor { |
|
|
|
//call the original function then pass our custom argument to the backgroundColor argument as shown below. |
|
|
|
%orig(kDarkColor); |
|
|
|
} |
|
|
|
|
|
|
|
// We need to make sure we tell theos that we are finished hooking this class not doing so with cause the end of the world :P |
|
|
|
%end |
|
|
|
%end |
|
|
|
|
|
|
|
%group OLEDadaptive |
|
|
|
// We then hook the class in this case Zenith's grabber view is called “ZNGrabberAccessoryView” |
|
|
|
%hook ZNGrabberAccessoryView |
|
|
|
|
|
|
|
// this is called when iOS 13's dark mode is enabled! |
|
|
|
-(void)traitCollectionDidChange:(UITraitCollection *)previousTraitCollection { |
|
|
|
%orig(previousTraitCollection); |
|
|
|
if (kEnabled) { |
|
|
|
// if the tweak is enabled and the version is iOS 13 or later run our code |
|
|
|
if (@available(iOS 13, *)) { |
|
|
|
if (self.traitCollection.userInterfaceStyle == UIUserInterfaceStyleDark) { |
|
|
|
[self setBackgroundColor:kOLEDColor]; |
|
|
|
} |
|
|
|
|
|
|
|
else { |
|
|
|
[self setBackgroundColor:kLightColor]; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
else { |
|
|
|
%orig(previousTraitCollection); |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// the method we modify is this method that is called from UIImageView to set the backgroundColor of the image view. |
|
|
|
// Since the grabber view is of type UIImageView we can modify this method :) |
|
|
|
-(void)setBackgroundColor:(UIColor *)backgroundColor { |
|
|
|
%orig; |
|
|
|
if (kEnabled) { |
|
|
|
// by default have our tweak overide this. |
|
|
|
if (@available(iOS 13, *)) { |
|
|
|
if (self.traitCollection.userInterfaceStyle == UIUserInterfaceStyleDark) { |
|
|
|
%orig(kOLEDColor); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
else { |
|
|
|
%orig; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
%end // We need to make sure we tell theos that we are finished hooking this class not doing so with cause the end of the world :P |
|
|
|
%end |
|
|
|
|
|
|
|
%group OLEDgroup |
|
|
|
|
|
|
|
//We then hook the class in this case Zenith's grabber view is called “ZNGrabberAccessoryView” |
|
|
|
%hook ZNGrabberAccessoryView |
|
|
@@ -75,7 +138,7 @@ static BOOL ios13; |
|
|
|
|
|
|
|
-(void)setBackgroundColor:(UIColor *)backgroundColor { |
|
|
|
//call the original function then pass our custom argument to the backgroundColor argument as shown below. |
|
|
|
%orig(kDarkModeColor); |
|
|
|
%orig(kOLEDColor); |
|
|
|
} |
|
|
|
|
|
|
|
// We need to make sure we tell theos that we are finished hooking this class not doing so with cause the end of the world :P |
|
|
@@ -99,6 +162,8 @@ static void loadPrefs() { // Load preferences to make sure changes are written |
|
|
|
|
|
|
|
} |
|
|
|
kEnabled = [([prefs objectForKey:@"kEnabled"] ?: @(YES)) boolValue]; //our preference values that write to a plist file when a user selects somethings |
|
|
|
sortType = [([prefs objectForKey:@"sortingType"] ? [prefs objectForKey:@"sortingType"] : @"0") integerValue]; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@@ -112,12 +177,20 @@ static void PreferencesChangedCallback(CFNotificationCenterRef center, void *obs |
|
|
|
loadPrefs(); // Load our prefs |
|
|
|
|
|
|
|
if (kEnabled) { // If enabled |
|
|
|
if (@available(iOS 13, *)) { // If the device is running iOS 13 |
|
|
|
ios13 = YES; // Set "iOS13" to "YES" |
|
|
|
%init(Tweak13); // Enable the group "Tweak13" |
|
|
|
} else { |
|
|
|
ios13 = NO; // Set "iOS13" to "NO" |
|
|
|
%init(Tweak12); // Enable the group "Tweak12" |
|
|
|
if (sortType == ZNDarkSortTypeAdaptive) { |
|
|
|
%init(Adaptive); // Enable the group "Adaptive" |
|
|
|
} |
|
|
|
|
|
|
|
else if (sortType == ZNDarkSortTypeDark) { |
|
|
|
%init(justDark); // Enable the group "Adaptive" |
|
|
|
} |
|
|
|
|
|
|
|
else if (sortType == ZNDarkSortTypeOLEDAdaptive) { |
|
|
|
%init(OLEDadaptive); // Enable the group "OLEDgroup" |
|
|
|
} |
|
|
|
|
|
|
|
else if (sortType == ZNDarkSortTypeOLED) { |
|
|
|
%init(OLEDgroup); // Enable the group "OLEDgroup" |
|
|
|
} |
|
|
|
} |
|
|
|
|