1
0
mirror of https://github.com/Burrit0z/kai synced 2025-07-01 13:56:48 +00:00

comments for you bro :)

This commit is contained in:
Burrit0z
2020-05-20 20:47:24 -04:00
parent 844aa9c035
commit 98bdd62ca5
2 changed files with 37 additions and 33 deletions

29
Kai.h
View File

@ -4,12 +4,8 @@
#import <objc/runtime.h>
#import <UIKit/UIKit.h>
#define KAISelf ((CSAdjunctListView *)self)
@interface UIApplication (Kai)
+(id)sharedApplication;
-(BOOL)launchApplicationWithIdentifier:(id)arg1 suspended:(BOOL)arg2;
@end
#define KAISelf ((CSAdjunctListView *)self) //for use when calling self in KAITarget
#define KAIBattery UHDUEIHGCEBCHYDEICVKEVSAGJKBCXAHJGKVXHAS //lmao
@interface CSAdjunctListView : UIView
@property (nonatomic, assign) BOOL hasKai;
@ -18,24 +14,6 @@
-(void)KaiUpdate;
@end
@interface SBDashBoardAdjunctListView : UIView
@property (nonatomic, assign) BOOL hasKai;
-(UIStackView *)stackView;
-(void)setStackView:(UIStackView *)arg1;
-(void)KaiUpdate;
@end
@interface CSMainPageView : UIView
-(void)updateForPresentation:(id)arg1;
@end
@interface _CSSingleBatteryChargingView : UIView
@end
@interface NSLayoutConstraint (Kai)
+(id)constraintWithAnchor:(id)arg1 relatedBy:(long long)arg2 toAnchor:(id)arg3 multiplier:(double)arg4 constant:(double)arg5 ;
@end
@interface CALayer (kai)
@property (nonatomic, assign) BOOL continuousCorners;
@end
@ -59,6 +37,7 @@ double cornerRadius;
double bannerWidthFactor;
double horizontalOffset;
//by importing here, I can use vars in the .mm of KAIBattery
#import "KAIBattery.mm"
#define PLIST_PATH @"/User/Library/Preferences/com.burritoz.kaiprefs.plist"
@ -131,6 +110,8 @@ static void preferencesChanged()
static void applyPrefs()
{
preferencesChanged();
//here I remotely refresh the KAIView.
isUpdating = YES;
[UIView animateWithDuration:0.3 animations:^{
[KAIBattery sharedInstance].alpha = 0;

39
Kai.xm
View File

@ -1,16 +1,21 @@
#import "Kai.h"
%hook KAITarget
%hook KAITarget //This class is defined in %ctor, KAITarget is not a class name.
%property (nonatomic, assign) BOOL hasKai;
-(void)_layoutStackView {
NSInteger lastSlot = [[self stackView].subviews count] -1;
//this code is used to determine if kai is at the bottom of the stack view
if([[self stackView].subviews objectAtIndex:lastSlot] != [KAIBattery sharedInstance] && belowMusic) {
//if it is not, but the option to have kai below music is on, i simply remove from it's current pos.
//and insert into last slot.
[[self stackView] removeArrangedSubview:[KAIBattery sharedInstance]];
[[self stackView] insertArrangedSubview:[KAIBattery sharedInstance] atIndex:lastSlot];
}
//makes kai lay itself out when the stack does
[self KaiUpdate];
%orig;
@ -20,19 +25,21 @@
if(!KAISelf.hasKai) {
KAIBattery *battery = [[KAIBattery alloc] init];
//Add noti observer
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(KaiInfo)
name:@"KaiInfoChanged"
object:nil];
KAISelf.hasKai = YES;
UIStackView *newView = arg1;
if(![arg1.subviews containsObject:battery]) {
[newView addArrangedSubview:battery];
if(![arg1.subviews containsObject:battery]) { //if not added
//add kai to the stack view
[arg1 addArrangedSubview:battery];
}
%orig(newView);
//send the adjusted stackview as arg1
%orig(arg1);
}
}
@ -47,16 +54,18 @@
battery.heightConstraint.active = NO;
battery.heightConstraint = [battery.heightAnchor constraintEqualToConstant:85];
//set an initial constraint
battery.heightConstraint.active = YES;
} else {
int height = ((battery.number * (bannerHeight + spacing)) - spacing + 5);
int height = ((battery.number * (bannerHeight + spacing)) - spacing + 5); //big brain math
battery.heightConstraint.active = NO;
battery.heightConstraint.constant = height;
battery.heightConstraint.active = YES;
UIStackView *s = [self stackView];
s.frame = CGRectMake(s.frame.origin.x, s.frame.origin.y, s.frame.size.width, (s.frame.size.height - 1));
//literally does nothing but makes the stack view lay itself out (doesnt adjust frame because translatesAutoreszingMaskIntoConstraints = NO on stack views)
}
}];
@ -65,20 +74,30 @@
%new
-(void)KaiInfo {
if(!isUpdating) {
isUpdating = YES;
[UIView animateWithDuration:0.3 animations:^{
//nice fade out
[KAIBattery sharedInstance].alpha = 0;
} completion:^(BOOL finished){
[[KAIBattery sharedInstance] updateBattery];
[self KaiUpdate];
[UIView animateWithDuration:0.35 animations:^{
//fade back in
[KAIBattery sharedInstance].alpha = 1;
} completion:^(BOOL finished){
isUpdating = NO;
}];
}];
}
}
%end
@ -87,8 +106,8 @@
- (id)initWithIdentifier:(id)arg1 vendor:(long long)arg2 productIdentifier:(long long)arg3 parts:(unsigned long long)arg4 matchIdentifier:(id)arg5 {
//Posts a notification to self when these keys change
[self addObserver:self forKeyPath:@"charging" options:NSKeyValueObservingOptionNew context:nil];
//[self addObserver:self forKeyPath:@"powerSourceState" options:NSKeyValueObservingOptionNew context:nil];
[self addObserver:self forKeyPath:@"batterySaverModeActive" options:NSKeyValueObservingOptionNew context:nil];
[self addObserver:self forKeyPath:@"percentCharge" options:NSKeyValueObservingOptionNew context:nil];
@ -97,6 +116,7 @@
-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context{
dispatch_async(dispatch_get_main_queue(), ^{
//sends the noti to update battery info
[[NSNotificationCenter defaultCenter] postNotificationName:@"KaiInfoChanged" object:nil userInfo:nil];
});
@ -107,6 +127,7 @@
-(void)_transitionChargingViewToVisible:(BOOL)arg1 showBattery:(BOOL)arg2 animated:(BOOL)arg3 {
if(hideChargingAnimation) {
//Yeah bro this just makes the method never call to show the charging thing
%orig(NO,NO,NO);
}
}
@ -123,6 +144,8 @@
NULL,
CFNotificationSuspensionBehaviorDeliverImmediately
);
//Bro Muirey helped me figure out a logical way to do this because iOS 12-13 classes have changed
Class cls = kCFCoreFoundationVersionNumber > 1600 ? ([objc_getClass("CSAdjunctListView") class]) : ([objc_getClass("SBDashBoardAdjunctListView") class]);
if(enabled) {
%init(KAITarget = cls);