Browse Source

Major refactoring.

v1.2.4
Abhishek Banthia 9 years ago
parent
commit
ac8c0122b8
  1. 297
      Clocker-Helper/Clocker-Helper.xcodeproj/project.pbxproj
  2. 91
      Clocker-Helper/Clocker-Helper.xcodeproj/xcuserdata/abhishekbanthia.xcuserdatad/xcschemes/Clocker-Helper.xcscheme
  3. 22
      Clocker-Helper/Clocker-Helper.xcodeproj/xcuserdata/abhishekbanthia.xcuserdatad/xcschemes/xcschememanagement.plist
  4. 293
      Clocker.dot
  5. 103
      Clocker.xcodeproj/project.pbxproj
  6. BIN
      Clocker.xcodeproj/project.xcworkspace/xcuserdata/abhishekbanthia.xcuserdatad/UserInterfaceState.xcuserstate
  7. 10
      Clocker.xcodeproj/xcuserdata/abhishekbanthia.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist
  8. 4
      Clocker.xcodeproj/xcuserdata/abhishekbanthia.xcuserdatad/xcschemes/Clocker.xcscheme
  9. 2
      Clocker/API/CLAPIConnector.h
  10. 8
      Clocker/API/CLAPIConnector.m
  11. 4
      Clocker/AboutUsWindow/CLAboutUsViewController.h
  12. 30
      Clocker/AboutUsWindow/CLAboutUsViewController.m
  13. 82
      Clocker/App Feedback/CLAppFeedbackWindowController.m
  14. 3
      Clocker/Appearance Tab/CLAppearanceViewController.h
  15. 92
      Clocker/Appearance Tab/CLAppearanceViewController.m
  16. 18
      Clocker/Appearance Tab/en.lproj/CLAppearanceView.xib
  17. 48
      Clocker/Appearance Tab/ja.lproj/CLAppearanceView.xib
  18. 34
      Clocker/Appearance Tab/zh-Hans.lproj/CLAppearanceView.xib
  19. 70
      Clocker/Appearance Tab/zh-Hant.lproj/CLAppearanceView.xib
  20. 34
      Clocker/ApplicationDelegate.m
  21. 33
      Clocker/BackgroundView.m
  22. 4
      Clocker/CLMainWindowController.m
  23. 8
      Clocker/CLOneWindow/CLOneWindowController.m
  24. 1
      Clocker/CLParentPanelController.h
  25. 12
      Clocker/CLParentPanelController.m
  26. 13
      Clocker/CLParentViewController.h
  27. 27
      Clocker/CLParentViewController.m
  28. 41
      Clocker/CLRatingCellView.m
  29. 16
      Clocker/CLScaleUpButton.h
  30. 74
      Clocker/CLScaleUpButton.m
  31. 4
      Clocker/Clocker-Info.plist
  32. 36
      Clocker/ColoredButton.h
  33. 61
      Clocker/ColoredButton.m
  34. 4
      Clocker/Custom Slider/CLCustomSliderCell.m
  35. 5
      Clocker/Custom Table Cell Views/CLTimezoneCellView.h
  36. 76
      Clocker/Custom Table Cell Views/CLTimezoneCellView.m
  37. 20
      Clocker/Date Tools/DateTools-master/DateTools/DTTimePeriod.h
  38. 2
      Clocker/Date Tools/DateTools-master/DateTools/DTTimePeriodCollection.h
  39. 14
      Clocker/Date Tools/DateTools-master/DateTools/DTTimePeriodGroup.h
  40. 2
      Clocker/Date Tools/DateTools-master/DateTools/DTTimePeriodGroup.m
  41. 74
      Clocker/Date Tools/DateTools-master/DateTools/NSDate+DateTools.h
  42. 70
      Clocker/Date Tools/DateTools-master/DateTools/NSDate+DateTools.m
  43. 19
      Clocker/EDSunriseSet.m
  44. 1
      Clocker/Floating Window/CLFloatingWindowController.h
  45. 39
      Clocker/Floating Window/CLFloatingWindowController.m
  46. 6
      Clocker/MenubarController.h
  47. 78
      Clocker/MenubarController.m
  48. 19
      Clocker/Model/CLTimezoneData.h
  49. 71
      Clocker/Model/CLTimezoneData.m
  50. 8
      Clocker/Onboarding/CLIntroViewController.h
  51. 23
      Clocker/Onboarding/CLIntroViewController.m
  52. 7
      Clocker/Onboarding/CLOnboardingWindowController.m
  53. 4
      Clocker/Onboarding/Onboarding Animated Views/QCMethod.h
  54. 12
      Clocker/Onboarding/Onboarding Animated Views/QCMethod.m
  55. 3
      Clocker/PanelController.h
  56. 74
      Clocker/PanelController.m
  57. 1
      Clocker/Parse/Bolts.framework/Bolts
  58. 1
      Clocker/Parse/Bolts.framework/Headers
  59. 1
      Clocker/Parse/Bolts.framework/Modules
  60. 1
      Clocker/Parse/Bolts.framework/Resources
  61. BIN
      Clocker/Parse/Bolts.framework/Versions/A/Bolts
  62. 42
      Clocker/Parse/Bolts.framework/Versions/A/Headers/BFCancellationToken.h
  63. 29
      Clocker/Parse/Bolts.framework/Versions/A/Headers/BFCancellationTokenRegistration.h
  64. 60
      Clocker/Parse/Bolts.framework/Versions/A/Headers/BFCancellationTokenSource.h
  65. 18
      Clocker/Parse/Bolts.framework/Versions/A/Headers/BFDefines.h
  66. 62
      Clocker/Parse/Bolts.framework/Versions/A/Headers/BFExecutor.h
  67. 257
      Clocker/Parse/Bolts.framework/Versions/A/Headers/BFTask.h
  68. 91
      Clocker/Parse/Bolts.framework/Versions/A/Headers/BFTaskCompletionSource.h
  69. 47
      Clocker/Parse/Bolts.framework/Versions/A/Headers/Bolts.h
  70. 1
      Clocker/Parse/Bolts.framework/Versions/A/Headers/BoltsVersion.h
  71. 6
      Clocker/Parse/Bolts.framework/Versions/A/Modules/module.modulemap
  72. 44
      Clocker/Parse/Bolts.framework/Versions/A/Resources/Info.plist
  73. 1
      Clocker/Parse/Bolts.framework/Versions/Current
  74. 1
      Clocker/Parse/Parse.framework/Headers
  75. 1
      Clocker/Parse/Parse.framework/Modules
  76. 1
      Clocker/Parse/Parse.framework/Parse
  77. 1
      Clocker/Parse/Parse.framework/Resources
  78. 244
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFACL.h
  79. 167
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFAnalytics.h
  80. 82
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFAnonymousUtils.h
  81. 90
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFCloud.h
  82. 105
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFConfig.h
  83. 557
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFConstants.h
  84. 444
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFFile.h
  85. 112
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFGeoPoint.h
  86. 115
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFInstallation.h
  87. 126
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFObject+Subclass.h
  88. 1420
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFObject.h
  89. 543
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFPush.h
  90. 892
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFQuery.h
  91. 57
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFRelation.h
  92. 99
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFRole.h
  93. 52
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFSession.h
  94. 89
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFSubclassing.h
  95. 519
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFUser.h
  96. 36
      Clocker/Parse/Parse.framework/Versions/A/Headers/PFUserAuthenticationDelegate.h
  97. 200
      Clocker/Parse/Parse.framework/Versions/A/Headers/Parse.h
  98. 6
      Clocker/Parse/Parse.framework/Versions/A/Modules/module.modulemap
  99. BIN
      Clocker/Parse/Parse.framework/Versions/A/Parse
  100. 42
      Clocker/Parse/Parse.framework/Versions/A/Resources/Info.plist
  101. Some files were not shown because too many files have changed in this diff Show More

297
Clocker-Helper/Clocker-Helper.xcodeproj/project.pbxproj

@ -1,297 +0,0 @@
// !$*UTF8*$!
{
archiveVersion = 1;
classes = {
};
objectVersion = 46;
objects = {
/* Begin PBXBuildFile section */
9A20A05A1C4E801500FB45AB /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A20A0591C4E801500FB45AB /* AppDelegate.m */; };
9A20A05D1C4E801500FB45AB /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A20A05C1C4E801500FB45AB /* main.m */; };
9A20A05F1C4E801500FB45AB /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 9A20A05E1C4E801500FB45AB /* Assets.xcassets */; };
9A8597D51CDA916A00323D9D /* MainMenu.xib in Resources */ = {isa = PBXBuildFile; fileRef = 9A8597D41CDA916A00323D9D /* MainMenu.xib */; };
/* End PBXBuildFile section */
/* Begin PBXFileReference section */
9A20A0551C4E801500FB45AB /* Clocker-Helper.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "Clocker-Helper.app"; sourceTree = BUILT_PRODUCTS_DIR; };
9A20A0581C4E801500FB45AB /* AppDelegate.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = AppDelegate.h; sourceTree = "<group>"; };
9A20A0591C4E801500FB45AB /* AppDelegate.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = AppDelegate.m; sourceTree = "<group>"; };
9A20A05C1C4E801500FB45AB /* main.m */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.objc; path = main.m; sourceTree = "<group>"; };
9A20A05E1C4E801500FB45AB /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
9A20A0631C4E801500FB45AB /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
9A20A0731C4E80D300FB45AB /* Clocker-Helper.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.xml; path = "Clocker-Helper.entitlements"; sourceTree = "<group>"; };
9A8597D41CDA916A00323D9D /* MainMenu.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = MainMenu.xib; sourceTree = "<group>"; };
/* End PBXFileReference section */
/* Begin PBXFrameworksBuildPhase section */
9A20A0521C4E801500FB45AB /* Frameworks */ = {
isa = PBXFrameworksBuildPhase;
buildActionMask = 2147483647;
files = (
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXFrameworksBuildPhase section */
/* Begin PBXGroup section */
9A20A04C1C4E801500FB45AB = {
isa = PBXGroup;
children = (
9A20A0571C4E801500FB45AB /* Clocker-Helper */,
9A20A0561C4E801500FB45AB /* Products */,
);
sourceTree = "<group>";
};
9A20A0561C4E801500FB45AB /* Products */ = {
isa = PBXGroup;
children = (
9A20A0551C4E801500FB45AB /* Clocker-Helper.app */,
);
name = Products;
sourceTree = "<group>";
};
9A20A0571C4E801500FB45AB /* Clocker-Helper */ = {
isa = PBXGroup;
children = (
9A20A0731C4E80D300FB45AB /* Clocker-Helper.entitlements */,
9A20A0581C4E801500FB45AB /* AppDelegate.h */,
9A20A0591C4E801500FB45AB /* AppDelegate.m */,
9A20A05E1C4E801500FB45AB /* Assets.xcassets */,
9A20A0631C4E801500FB45AB /* Info.plist */,
9A20A05B1C4E801500FB45AB /* Supporting Files */,
9A8597D41CDA916A00323D9D /* MainMenu.xib */,
);
path = "Clocker-Helper";
sourceTree = "<group>";
};
9A20A05B1C4E801500FB45AB /* Supporting Files */ = {
isa = PBXGroup;
children = (
9A20A05C1C4E801500FB45AB /* main.m */,
);
name = "Supporting Files";
sourceTree = "<group>";
};
/* End PBXGroup section */
/* Begin PBXNativeTarget section */
9A20A0541C4E801500FB45AB /* Clocker-Helper */ = {
isa = PBXNativeTarget;
buildConfigurationList = 9A20A0661C4E801500FB45AB /* Build configuration list for PBXNativeTarget "Clocker-Helper" */;
buildPhases = (
9A20A0511C4E801500FB45AB /* Sources */,
9A20A0521C4E801500FB45AB /* Frameworks */,
9A20A0531C4E801500FB45AB /* Resources */,
);
buildRules = (
);
dependencies = (
);
name = "Clocker-Helper";
productName = "Clocker-Helper";
productReference = 9A20A0551C4E801500FB45AB /* Clocker-Helper.app */;
productType = "com.apple.product-type.application";
};
/* End PBXNativeTarget section */
/* Begin PBXProject section */
9A20A04D1C4E801500FB45AB /* Project object */ = {
isa = PBXProject;
attributes = {
LastUpgradeCheck = 0720;
ORGANIZATIONNAME = "Abhishek Banthia";
TargetAttributes = {
9A20A0541C4E801500FB45AB = {
CreatedOnToolsVersion = 7.2;
DevelopmentTeam = AJS5SNW8EY;
SystemCapabilities = {
com.apple.Sandbox = {
enabled = 1;
};
};
};
};
};
buildConfigurationList = 9A20A0501C4E801500FB45AB /* Build configuration list for PBXProject "Clocker-Helper" */;
compatibilityVersion = "Xcode 3.2";
developmentRegion = English;
hasScannedForEncodings = 0;
knownRegions = (
en,
);
mainGroup = 9A20A04C1C4E801500FB45AB;
productRefGroup = 9A20A0561C4E801500FB45AB /* Products */;
projectDirPath = "";
projectRoot = "";
targets = (
9A20A0541C4E801500FB45AB /* Clocker-Helper */,
);
};
/* End PBXProject section */
/* Begin PBXResourcesBuildPhase section */
9A20A0531C4E801500FB45AB /* Resources */ = {
isa = PBXResourcesBuildPhase;
buildActionMask = 2147483647;
files = (
9A20A05F1C4E801500FB45AB /* Assets.xcassets in Resources */,
9A8597D51CDA916A00323D9D /* MainMenu.xib in Resources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXResourcesBuildPhase section */
/* Begin PBXSourcesBuildPhase section */
9A20A0511C4E801500FB45AB /* Sources */ = {
isa = PBXSourcesBuildPhase;
buildActionMask = 2147483647;
files = (
9A20A05D1C4E801500FB45AB /* main.m in Sources */,
9A20A05A1C4E801500FB45AB /* AppDelegate.m in Sources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
/* End PBXSourcesBuildPhase section */
/* Begin XCBuildConfiguration section */
9A20A0641C4E801500FB45AB /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO;
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
CLANG_CXX_LIBRARY = "libc++";
CLANG_ENABLE_MODULES = YES;
CLANG_ENABLE_OBJC_ARC = YES;
CLANG_WARN_BOOL_CONVERSION = YES;
CLANG_WARN_CONSTANT_CONVERSION = YES;
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
CLANG_WARN_EMPTY_BODY = YES;
CLANG_WARN_ENUM_CONVERSION = YES;
CLANG_WARN_INT_CONVERSION = YES;
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
CLANG_WARN_UNREACHABLE_CODE = YES;
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
CODE_SIGN_IDENTITY = "";
COPY_PHASE_STRIP = NO;
DEBUG_INFORMATION_FORMAT = dwarf;
ENABLE_STRICT_OBJC_MSGSEND = YES;
ENABLE_TESTABILITY = YES;
GCC_C_LANGUAGE_STANDARD = gnu99;
GCC_DYNAMIC_NO_PIC = NO;
GCC_NO_COMMON_BLOCKS = YES;
GCC_OPTIMIZATION_LEVEL = 0;
GCC_PREPROCESSOR_DEFINITIONS = (
"DEBUG=1",
"$(inherited)",
);
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
GCC_WARN_UNDECLARED_SELECTOR = YES;
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
MACOSX_DEPLOYMENT_TARGET = 10.11;
MTL_ENABLE_DEBUG_INFO = YES;
ONLY_ACTIVE_ARCH = YES;
PROVISIONING_PROFILE = "";
SDKROOT = macosx;
};
name = Debug;
};
9A20A0651C4E801500FB45AB /* Release */ = {
isa = XCBuildConfiguration;
buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO;
CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
CLANG_CXX_LIBRARY = "libc++";
CLANG_ENABLE_MODULES = YES;
CLANG_ENABLE_OBJC_ARC = YES;
CLANG_WARN_BOOL_CONVERSION = YES;
CLANG_WARN_CONSTANT_CONVERSION = YES;
CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
CLANG_WARN_EMPTY_BODY = YES;
CLANG_WARN_ENUM_CONVERSION = YES;
CLANG_WARN_INT_CONVERSION = YES;
CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
CLANG_WARN_UNREACHABLE_CODE = YES;
CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
CODE_SIGN_IDENTITY = "";
COPY_PHASE_STRIP = NO;
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
ENABLE_NS_ASSERTIONS = NO;
ENABLE_STRICT_OBJC_MSGSEND = YES;
GCC_C_LANGUAGE_STANDARD = gnu99;
GCC_NO_COMMON_BLOCKS = YES;
GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
GCC_WARN_UNDECLARED_SELECTOR = YES;
GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
MACOSX_DEPLOYMENT_TARGET = 10.11;
MTL_ENABLE_DEBUG_INFO = NO;
PROVISIONING_PROFILE = "";
SDKROOT = macosx;
};
name = Release;
};
9A20A0671C4E801500FB45AB /* Debug */ = {
isa = XCBuildConfiguration;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_ENTITLEMENTS = "Clocker-Helper/Clocker-Helper.entitlements";
CODE_SIGN_IDENTITY = "";
"CODE_SIGN_IDENTITY[sdk=macosx*]" = "";
COMBINE_HIDPI_IMAGES = YES;
INFOPLIST_FILE = "Clocker-Helper/Info.plist";
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks";
PRODUCT_BUNDLE_IDENTIFIER = "com.abhishek.Clocker-Helper";
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE = "";
SKIP_INSTALL = YES;
};
name = Debug;
};
9A20A0681C4E801500FB45AB /* Release */ = {
isa = XCBuildConfiguration;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CODE_SIGN_ENTITLEMENTS = "Clocker-Helper/Clocker-Helper.entitlements";
CODE_SIGN_IDENTITY = "";
"CODE_SIGN_IDENTITY[sdk=macosx*]" = "";
COMBINE_HIDPI_IMAGES = YES;
INFOPLIST_FILE = "Clocker-Helper/Info.plist";
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks";
PRODUCT_BUNDLE_IDENTIFIER = "com.abhishek.Clocker-Helper";
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE = "";
SKIP_INSTALL = YES;
};
name = Release;
};
/* End XCBuildConfiguration section */
/* Begin XCConfigurationList section */
9A20A0501C4E801500FB45AB /* Build configuration list for PBXProject "Clocker-Helper" */ = {
isa = XCConfigurationList;
buildConfigurations = (
9A20A0641C4E801500FB45AB /* Debug */,
9A20A0651C4E801500FB45AB /* Release */,
);
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
9A20A0661C4E801500FB45AB /* Build configuration list for PBXNativeTarget "Clocker-Helper" */ = {
isa = XCConfigurationList;
buildConfigurations = (
9A20A0671C4E801500FB45AB /* Debug */,
9A20A0681C4E801500FB45AB /* Release */,
);
defaultConfigurationIsVisible = 0;
defaultConfigurationName = Release;
};
/* End XCConfigurationList section */
};
rootObject = 9A20A04D1C4E801500FB45AB /* Project object */;
}

91
Clocker-Helper/Clocker-Helper.xcodeproj/xcuserdata/abhishekbanthia.xcuserdatad/xcschemes/Clocker-Helper.xcscheme

@ -1,91 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
LastUpgradeVersion = "0720"
version = "1.3">
<BuildAction
parallelizeBuildables = "YES"
buildImplicitDependencies = "YES">
<BuildActionEntries>
<BuildActionEntry
buildForTesting = "YES"
buildForRunning = "YES"
buildForProfiling = "YES"
buildForArchiving = "YES"
buildForAnalyzing = "YES">
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "9A20A0541C4E801500FB45AB"
BuildableName = "Clocker-Helper.app"
BlueprintName = "Clocker-Helper"
ReferencedContainer = "container:Clocker-Helper.xcodeproj">
</BuildableReference>
</BuildActionEntry>
</BuildActionEntries>
</BuildAction>
<TestAction
buildConfiguration = "Debug"
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
shouldUseLaunchSchemeArgsEnv = "YES">
<Testables>
</Testables>
<MacroExpansion>
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "9A20A0541C4E801500FB45AB"
BuildableName = "Clocker-Helper.app"
BlueprintName = "Clocker-Helper"
ReferencedContainer = "container:Clocker-Helper.xcodeproj">
</BuildableReference>
</MacroExpansion>
<AdditionalOptions>
</AdditionalOptions>
</TestAction>
<LaunchAction
buildConfiguration = "Debug"
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
launchStyle = "0"
useCustomWorkingDirectory = "NO"
ignoresPersistentStateOnLaunch = "NO"
debugDocumentVersioning = "YES"
debugServiceExtension = "internal"
allowLocationSimulation = "YES">
<BuildableProductRunnable
runnableDebuggingMode = "0">
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "9A20A0541C4E801500FB45AB"
BuildableName = "Clocker-Helper.app"
BlueprintName = "Clocker-Helper"
ReferencedContainer = "container:Clocker-Helper.xcodeproj">
</BuildableReference>
</BuildableProductRunnable>
<AdditionalOptions>
</AdditionalOptions>
</LaunchAction>
<ProfileAction
buildConfiguration = "Release"
shouldUseLaunchSchemeArgsEnv = "YES"
savedToolIdentifier = ""
useCustomWorkingDirectory = "NO"
debugDocumentVersioning = "YES">
<BuildableProductRunnable
runnableDebuggingMode = "0">
<BuildableReference
BuildableIdentifier = "primary"
BlueprintIdentifier = "9A20A0541C4E801500FB45AB"
BuildableName = "Clocker-Helper.app"
BlueprintName = "Clocker-Helper"
ReferencedContainer = "container:Clocker-Helper.xcodeproj">
</BuildableReference>
</BuildableProductRunnable>
</ProfileAction>
<AnalyzeAction
buildConfiguration = "Debug">
</AnalyzeAction>
<ArchiveAction
buildConfiguration = "Release"
revealArchiveInOrganizer = "YES">
</ArchiveAction>
</Scheme>

22
Clocker-Helper/Clocker-Helper.xcodeproj/xcuserdata/abhishekbanthia.xcuserdatad/xcschemes/xcschememanagement.plist

@ -1,22 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>SchemeUserState</key>
<dict>
<key>Clocker-Helper.xcscheme</key>
<dict>
<key>orderHint</key>
<integer>1</integer>
</dict>
</dict>
<key>SuppressBuildableAutocreation</key>
<dict>
<key>9A20A0541C4E801500FB45AB</key>
<dict>
<key>primary</key>
<true/>
</dict>
</dict>
</dict>
</plist>

293
Clocker.dot

@ -1,153 +1,274 @@
digraph G {
node [shape=box];
"CLSAttributes" -> {};
"CLFloatingWindowController" -> "CLOneWindowController";
"CLFloatingWindowController" -> "CLTimezoneData";
"CLFloatingWindowController" -> "CommonStrings";
"CLFloatingWindowController" -> "CLPausableTimer";
"CLFloatingWindowController" -> "CLRatingCellView";
"CLFloatingWindowController" -> "CLParentPanelController";
"CLShortcutAnimatedView" -> "QCMethod";
"PFFile" -> {};
"eisl" -> {};
"SecCustomTransform" -> {};
"StatusItemView" -> {};
"POPSpringSolver" -> "POPVector";
"POPAnimationMRRTests" -> "POPAnimationTestsExtras";
"ApplicationDelegate" -> "CLFloatingWindowController";
"ApplicationDelegate" -> "CommonStrings";
"ApplicationDelegate" -> "iRate";
"ApplicationDelegate" -> "iVersion";
"ApplicationDelegate" -> "PanelController";
"ApplicationDelegate" -> "CLOnboardingWindowController";
"CLTimezoneCellView" -> "CLFloatingWindowController";
"CLTimezoneCellView" -> "CommonStrings";
"cssmkrapi" -> {};
"POPAnimatableProperty" -> "POPAnimationRuntime";
"POPAnimatableProperty" -> "POPLayerExtras";
"POPAnimatableProperty" -> "POPCGUtils";
"POPAnimatableProperty" -> "POPDefines";
"cssmapi" -> {};
"DTTimePeriodCollection" -> "DTTimePeriodGroup";
"DTTimePeriodCollection" -> "DTError";
"SecTrust" -> {};
"ColoredButton" -> {};
"PFSubclassing" -> {};
"cssm" -> {};
"POPVector" -> "POPCGUtils";
"POPVector" -> "POPDefines";
"x509defs" -> {};
"SCPreferences" -> {};
"SecKey" -> {};
"SRKeyEquivalentModifierMaskTransformer" -> "SRRecorderControl";
"SRKeyEquivalentModifierMaskTransformer" -> "SRKeyCodeTransformer";
"SecIdentity" -> {};
"POPSpringAnimationInternal" -> "POPAnimationExtras";
"POPSpringAnimationInternal" -> "POPPropertyAnimationInternal";
"cssmcli" -> {};
"SecAsn1Templates" -> {};
"SecAccessControl" -> {};
"PanelController" -> "StatusItemView";
"PanelController" -> "DateTools";
"PanelController" -> "MenubarController";
"PanelController" -> "CommonStrings";
"PanelController" -> "CLOneWindowController";
"PanelController" -> "CLParentPanelController";
"PanelController" -> "Reachability";
"AuthorizationDB" -> {};
"PanelController" -> "CLOneWindowController";
"PanelController" -> "Panel";
"POPSpringAnimation" -> "POPSpringAnimationInternal";
"CLAppFeedbackWindowController" -> "CLMainWindowController";
"CLAppFeedbackWindowController" -> "CommonStrings";
"CLAppFeedbackWindowController" -> "CLOneWindowController";
"main" -> "AppDelegate";
"PFFile" -> {};
"CLSAttributes" -> {};
"CLIntroViewController" -> "ApplicationDelegate";
"CLIntroViewController" -> "FloatingView";
"CLIntroViewController" -> "PanelController";
"CLIntroViewController" -> "CLFavouriteAnimatedView";
"CLIntroViewController" -> "CLShortcutAnimatedView";
"CLIntroViewController" -> "CommonStrings";
"BFTask" -> {};
"SecKeychainSearch" -> {};
"CLMainWindowController" -> {};
"SecCustomTransform" -> {};
"CLFavouriteAnimatedView" -> "QCMethod";
"SecDecodeTransform" -> "SecEncodeTransform";
"PFQuery" -> {};
"SecBase" -> {};
"Reachability" -> {};
"BFCancellationTokenRegistration" -> {};
"BFExecutor" -> {};
"SCDynamicStoreKey" -> {};
"PFAnonymousUtils" -> {};
"FAuthData" -> "FAuthType";
"oidsbase" -> {};
"SCSchemaDefinitions" -> {};
"ApplicationDelegate" -> "MenubarController";
"ApplicationDelegate" -> "PanelController";
"ApplicationDelegate" -> "CommonStrings";
"ApplicationDelegate" -> "iRate";
"ApplicationDelegate" -> "iVersion";
"SCDynamicStoreKey" -> {};
"CLAPI" -> "Reachability";
"POPPropertyAnimationInternal" -> "POPAnimationInternal";
"DTConstants" -> "DTError";
"SCDynamicStoreCopySpecific" -> {};
"cssmconfig" -> {};
"SecImportExport" -> {};
"SecPolicySearch" -> {};
"PFConfig" -> {};
"certextensions" -> {};
"PTHotKeyCenter" -> "PTKeyCombo";
"Parse" -> {};
"BFDefines" -> {};
"POPAnimationExtras" -> "POPMath";
"POPAnimationExtras" -> "POPAnimationPrivate";
"SecSignVerifyTransform" -> "SecTransform";
"cssmtpi" -> {};
"SecItem" -> {};
"POPBasicAnimationTests" -> "POPAnimatable";
"POPBasicAnimationTests" -> "POPAnimationTestsExtras";
"POPBasicAnimationTests" -> "POPBaseAnimationTests";
"SCNetworkConnection" -> {};
"FAuthType" -> {};
"SRRecorderControl" -> "SRModifierFlagsTransformer";
"SRRecorderControl" -> "SRKeyCodeTransformer";
"FQuery" -> "FEventType";
"FQuery" -> "FDataSnapshot";
"SecEncryptTransform" -> "SecTransform";
"CMSDecoder" -> {};
"SecStaticCode" -> {};
"Fabric" -> "FABAttributes";
"POPAnimationTracerInternal" -> {};
"DateToolsViewController" -> "Colours";
"FDataSnapshot" -> {};
"POPAnimatorPrivate" -> {};
"FirebaseServerValue" -> {};
"POPAction" -> {};
"mds" -> {};
"SecRandom" -> {};
"cssmconfig" -> {};
"ColoredButton" -> {};
"StatusItemView" -> "DateTools";
"StatusItemView" -> "CommonStrings";
"StatusItemView" -> "CLTimezoneData";
"SecTrustedApplication" -> {};
"Bolts" -> {};
"CMSEncoder" -> {};
"CommonStrings" -> {};
"cssmerr" -> {};
"Answers" -> "ANSCompatibility";
"emmspi" -> {};
"SecTrust" -> {};
"MenubarController" -> "StatusItemView";
"MenubarController" -> "CLTimezoneData";
"SecTransform" -> {};
"PFACL" -> {};
"cssmspi" -> {};
"CLTimezoneData" -> {};
"POPDefines" -> {};
"SecCode" -> {};
"SecAccessControl" -> {};
"CLTimezoneData" -> "CLAPI";
"CLTimezoneData" -> "DateTools";
"CLTimezoneData" -> "CommonStrings";
"CLTimezoneData" -> "EDSunriseSet";
"SecureDownload" -> {};
"CLSLogging" -> "CLSAttributes";
"emmspi" -> {};
"FMutableData" -> {};
"POPAnimator" -> "POPAnimatorPrivate";
"POPAnimator" -> "POPAnimationExtras";
"POPAnimator" -> "POPBasicAnimationInternal";
"POPAnimator" -> "POPAnimation";
"POPAnimator" -> "POPDecayAnimation";
"oidscrl" -> {};
"cssmdli" -> {};
"SecCodeHost" -> {};
"IKAppDelegate" -> "IKIBAutoLayoutWindowController";
"IKAppDelegate" -> "IKCodeAutoLayoutWindowController";
"IKAppDelegate" -> "IKIBAutoresizingMasksWindowController";
"Security" -> {};
"PFSession" -> {};
"FirebaseApp" -> {};
"PFPush" -> {};
"SecAsn1Coder" -> {};
"cssmaci" -> {};
"POPCGUtils" -> "POPDefines";
"SecureTransport" -> {};
"AppDelegate" -> "Colours";
"AppDelegate" -> "DateToolsViewController";
"AppDelegate" -> "TimePeriodsViewController";
"AppDelegate" -> "ExampleNavigationController";
"SystemConfiguration" -> {};
"CLTimezoneDataOperations" -> {};
"SecPolicy" -> {};
"CLOneWindowController" -> "CLAboutUsViewController";
"CLOneWindowController" -> "CLPreferencesViewController";
"CLOneWindowController" -> "CLAppearanceViewController";
"Crashlytics" -> "CLSAttributes";
"Crashlytics" -> "CLSReport";
"Crashlytics" -> "CLSLogging";
"Crashlytics" -> "CLSStackFrame";
"Crashlytics" -> "Answers";
"FEventType" -> {};
"UnitBezier" -> {};
"POPAnimatablePropertyTests" -> {};
"POPMath" -> "UnitBezier";
"POPMath" -> "POPAnimationPrivate";
"POPMath" -> "POPDefines";
"SecCertificate" -> {};
"CodeSigning" -> {};
"SecKeychain" -> {};
"SecIdentitySearch" -> {};
"POPBaseAnimationTests" -> "POPAnimatable";
"POPBaseAnimationTests" -> "POPCGUtils";
"POPBaseAnimationTests" -> "POPAnimationTestsExtras";
"POPBaseAnimationTests" -> "POPAnimationInternal";
"PFGeoPoint" -> {};
"TimePeriodsViewController" -> "DTTimePeriod";
"iVersion" -> {};
"cssmapple" -> {};
"PFConstants" -> {};
"SystemConfiguration" -> {};
"oidscert" -> {};
"iRate" -> "CommonStrings";
"iRate" -> "PanelController";
"SecSignVerifyTransform" -> "SecTransform";
"POPDecayAnimationInternal" -> "POPPropertyAnimationInternal";
"POPDecayAnimationTests" -> "POPAnimatable";
"POPDecayAnimationTests" -> "POPAnimationTestsExtras";
"POPDecayAnimationTests" -> "POPBaseAnimationTests";
"SecCodeHost" -> {};
"Authorization" -> {};
"BFCancellationToken" -> {};
"emmtype" -> {};
"CLAboutUsViewController" -> "CLAppFeedbackWindowController";
"oids" -> {};
"PFInstallation" -> {};
"SecDigestTransform" -> "SecTransform";
"cssmkrspi" -> {};
"CLAboutUsViewController" -> "CommonStrings";
"CLPreferencesViewController" -> "CLAPI";
"CLPreferencesViewController" -> "CLTimezoneData";
"CLPreferencesViewController" -> "CommonStrings";
"CLPreferencesViewController" -> "ApplicationDelegate";
"CLPreferencesViewController" -> "Reachability";
"CLPreferencesViewController" -> "PanelController";
"CLPreferencesViewController" -> "CommonStrings";
"CLPreferencesViewController" -> "EDSunriseSet";
"CLPreferencesViewController" -> "Panel";
"SecReadTransform" -> {};
"CLParentPanelController" -> "CLTimezoneData";
"CLParentPanelController" -> "CommonStrings";
"CLParentPanelController" -> "CLRatingCellView";
"CLParentPanelController" -> "CLOneWindowController";
"oids" -> {};
"PFInstallation" -> {};
"FConfig" -> {};
"cssmkrspi" -> {};
"POPCustomAnimationTests" -> "POPAnimatable";
"POPCustomAnimationTests" -> "POPAnimationTestsExtras";
"POPCustomAnimationTests" -> "POPBaseAnimationTests";
"CLScaleUpButton" -> {};
"CLPanelTextField" -> "CLFloatingWindowController";
"DTTimePeriodChain" -> "DTTimePeriodGroup";
"DTTimePeriodChain" -> "DTError";
"CLSReport" -> "CLSAttributes";
"CLPausableTimer" -> {};
"SecReadTransform" -> {};
"BFCancellationTokenSource" -> {};
"PTKeyCodeTranslator" -> {};
"PTHotKey" -> "PTKeyCombo";
"oidsalg" -> {};
"FABAttributes" -> {};
"SCPreferencesPath" -> {};
"POPAnimationInternal" -> "POPAnimationRuntime";
"POPAnimationInternal" -> "POPSpringSolver";
"POPAnimationInternal" -> "POPAction";
"POPAnimationInternal" -> "POPAnimationTracerInternal";
"PFSession" -> {};
"SecACL" -> {};
"SecCertificateOIDs" -> {};
"CSCommon" -> {};
"POPLayerExtras" -> "TransformationMatrix";
"IKCodeAutoLayoutWindowController" -> "IKDemoWindowController";
"ExampleNavigationController" -> "Colours";
"CLAppFeedbackWindowController" -> "CommonStrings";
"CLAppFeedbackWindowController" -> "CLOneWindowController";
"SCPreferencesSetSpecific" -> {};
"POPAnimationRuntime" -> "POPCGUtils";
"POPAnimationRuntime" -> "POPVector";
"POPAnimationRuntime" -> "POPDefines";
"POPAnimationRuntime" -> "POPGeometry";
"cssmaci" -> {};
"AuthorizationDB" -> {};
"Crashlytics" -> "CLSAttributes";
"Crashlytics" -> "CLSReport";
"Crashlytics" -> "CLSLogging";
"Crashlytics" -> "CLSStackFrame";
"Crashlytics" -> "Answers";
"SecEncodeTransform" -> "SecTransform";
"SecDigestTransform" -> "SecTransform";
"PFObject" -> {};
"PFRelation" -> {};
"CLSStackFrame" -> "CLSAttributes";
"SecAsn1Types" -> {};
"mds_schema" -> {};
"SecCertificate" -> {};
"POPAnimation" -> "POPAnimatorPrivate";
"POPAnimation" -> "POPAnimationExtras";
"POPAnimation" -> "POPAction";
"POPAnimation" -> "POPAnimationTracerInternal";
"POPAnimation" -> "POPAnimationRuntime";
"SCPreferencesPath" -> {};
"POPSpringAnimationTests" -> "POPAnimatable";
"POPSpringAnimationTests" -> "POPAnimationTestsExtras";
"POPSpringAnimationTests" -> "POPCGUtils";
"POPSpringAnimationTests" -> "POPBaseAnimationTests";
"POPSpringAnimationTests" -> "POPAnimationInternal";
"IKIBAutoresizingMasksWindowController" -> "IKDemoWindowController";
"POPGeometry" -> "POPDefines";
"CipherSuite" -> {};
"PFUser" -> {};
"POPEaseInEaseOutAnimationTests" -> "POPAnimatable";
"POPEaseInEaseOutAnimationTests" -> "POPAnimationTestsExtras";
"POPEaseInEaseOutAnimationTests" -> "POPBaseAnimationTests";
"DateTools" -> "DTTimePeriod";
"DateTools" -> "DTTimePeriodGroup";
"DateTools" -> "DTConstants";
@ -155,60 +276,120 @@ digraph G {
"DateTools" -> "DTTimePeriodChain";
"DateTools" -> "DTError";
"PFUserAuthenticationDelegate" -> {};
"Firebase" -> "FAuthType";
"Firebase" -> "FirebaseServerValue";
"Firebase" -> "FMutableData";
"Firebase" -> "FConfig";
"Firebase" -> "FDataSnapshot";
"Firebase" -> "FAuthData";
"Firebase" -> "FirebaseApp";
"Firebase" -> "FQuery";
"Firebase" -> "FTransactionResult";
"SCNetworkReachability" -> {};
"CLRatingCellView" -> "CLAppFeedbackWindowController";
"CLRatingCellView" -> "iRate";
"SCNetwork" -> {};
"Colours" -> "TargetConditionals";
"SRKeyEquivalentTransformer" -> "SRRecorderControl";
"SRKeyEquivalentTransformer" -> "SRKeyCodeTransformer";
"AuthorizationPlugin" -> {};
"EDSunriseSet" -> {};
"AuthorizationTags" -> {};
"FABAttributes" -> {};
"SecAccess" -> {};
"BackgroundView" -> "ApplicationDelegate";
"BackgroundView" -> "CommonStrings";
"oidsattr" -> {};
"DTTimePeriod" -> {};
"cssmcspi" -> {};
"SCPreferencesSetSpecific" -> {};
"IKIBAutoLayoutWindowController" -> "IKDemoWindowController";
"CLAppearanceViewController" -> "ApplicationDelegate";
"CLAppearanceViewController" -> "CLFloatingWindowController";
"CLAppearanceViewController" -> "PanelController";
"CLAppearanceViewController" -> "CLTimezoneData";
"CLAppearanceViewController" -> "CommonStrings";
"oidsbase" -> {};
"POP" -> {};
"SecKey" -> {};
"cssmtype" -> {};
"DHCPClientPreferences" -> {};
"ShortcutRecorder" -> {};
"PFAnalytics" -> {};
"SecTrustSettings" -> {};
"SecCode" -> {};
"POPAnimationTests" -> "POPAnimatable";
"POPAnimationTests" -> "POPCGUtils";
"POPAnimationTests" -> "POPAnimationInternal";
"POPAnimationTests" -> "POPAnimationRuntime";
"POPAnimationTests" -> "POPAnimationTestsExtras";
"POPAnimationTests" -> "POPBaseAnimationTests";
"POPAnimationTestsExtras" -> "POPVector";
"IKDemoWindowController" -> {};
"SRModifierFlagsTransformer" -> "SRCommon";
"AuthSession" -> {};
"POPAnimatable" -> {};
"Panel" -> {};
"SCDynamicStore" -> {};
"SecTask" -> {};
"SecRequirement" -> {};
"SecIdentity" -> {};
"iVersion" -> {};
"FloatingView" -> "QCMethod";
"CLOnboardingWindowController" -> "CLMainWindowController";
"CLOnboardingWindowController" -> "CLIntroViewController";
"POPAnimationTracer" -> "POPAnimationEventInternal";
"POPAnimationTracer" -> "POPAnimationInternal";
"POPAnimationTracer" -> "POPSpringAnimation";
"POPAnimationPrivate" -> {};
"AppDelegate" -> "Colours";
"AppDelegate" -> "DateToolsViewController";
"AppDelegate" -> "TimePeriodsViewController";
"AppDelegate" -> "ExampleNavigationController";
"PFRole" -> {};
"DTTimePeriodGroup" -> "DTTimePeriod";
"BoltsVersion" -> {};
"ANSCompatibility" -> {};
"SCNetworkConfiguration" -> {};
"PTKeyCombo" -> "PTKeyCodeTranslator";
"SecRandom" -> {};
"FTransactionResult" -> "FMutableData";
"FloatConversion" -> {};
"QCMethod" -> "TargetConditionals";
"POPCustomAnimation" -> "POPAnimationInternal";
"SCDynamicStoreCopyDHCPInfo" -> {};
"Reachability" -> {};
"DTError" -> {};
"CaptiveNetwork" -> {};
"BFTaskCompletionSource" -> {};
"SecTransformReadTransform" -> {};
"BoltsVersion" -> {};
"POPBasicAnimationInternal" -> "POPPropertyAnimationInternal";
"SRValidator" -> "SRCommon";
"SRValidator" -> "SRKeyCodeTransformer";
"DTTimePeriodGroup" -> "DTTimePeriod";
"CLCustomSliderCell" -> "CommonStrings";
"PFCloud" -> {};
"SecKeychainItem" -> {};
"TransformationMatrix" -> "FloatConversion";
"DateToolsExample-Prefix" [color=red];
"Prefix" [color=red];
"Clocker-Prefix" [color=red];
edge [color=blue, dir=both];
"PanelController" -> "BackgroundView";
"ApplicationDelegate" -> "MenubarController";
"POPPropertyAnimationInternal" -> "POPPropertyAnimation";
"POPAnimationInternal" -> "POPAnimation";
"CLTimezoneCellView" -> "PanelController";
"PTHotKeyCenter" -> "PTHotKey";
"PanelController" -> "BackgroundView";
"POPMath" -> "POPVector";
"POPDecayAnimation" -> "POPDecayAnimationInternal";
"SRKeyCodeTransformer" -> "SRCommon";
"PanelController" -> "CLTimezoneData";
"POPAnimationEvent" -> "POPAnimationEventInternal";
"POPBasicAnimation" -> "POPBasicAnimationInternal";
"CLTimezoneCellView" -> "CLTimezoneData";
"PanelController" -> "CLRatingCellView";
"TargetConditionals" [color=gray, style=dashed, fontcolor=gray]
edge [color=black];
node [shape=plaintext];
"Categories" [label="PFObject+Subclass\nNSDate+DateTools"];
"Categories" [label="PTHotKey+ShortcutRecorder\nPFObject+Subclass\nNSDate+DateTools"];
}

103
Clocker.xcodeproj/project.pbxproj

@ -19,12 +19,13 @@
9A13BAE61CA889BB007C6CBE /* CLAppFeedbackWindow.xib in Resources */ = {isa = PBXBuildFile; fileRef = 9A13BAE81CA889BB007C6CBE /* CLAppFeedbackWindow.xib */; };
9A13BAEA1CA88A76007C6CBE /* Localizable.strings in Resources */ = {isa = PBXBuildFile; fileRef = 9A13BAEC1CA88A76007C6CBE /* Localizable.strings */; };
9A20A04B1C4DEED200FB45AB /* IOKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A20A04A1C4DEED200FB45AB /* IOKit.framework */; };
9A20A0701C4E804D00FB45AB /* ServiceManagement.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A20A06F1C4E804D00FB45AB /* ServiceManagement.framework */; };
9A20A0721C4E80A800FB45AB /* Clocker-Helper.app in CopyFiles */ = {isa = PBXBuildFile; fileRef = 9A20A06E1C4E801600FB45AB /* Clocker-Helper.app */; settings = {ATTRIBUTES = (RemoveHeadersOnCopy, ); }; };
9A20A0781C4EA53600FB45AB /* CLOnboardingWindowController.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A20A0761C4EA53600FB45AB /* CLOnboardingWindowController.m */; };
9A20A07E1C4EAAEB00FB45AB /* CLIntroViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A20A07C1C4EAAEB00FB45AB /* CLIntroViewController.m */; };
9A20A07F1C4EAAEB00FB45AB /* CLIntroView.xib in Resources */ = {isa = PBXBuildFile; fileRef = 9A20A07D1C4EAAEB00FB45AB /* CLIntroView.xib */; };
9A25F7471C1A5E17007D369B /* iRate.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A25F7441C1A5E17007D369B /* iRate.m */; };
9A3169BC1D2CB9B40079FDF8 /* pop.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A82F33B1CDFF8CF00CC8906 /* pop.framework */; };
9A3169BD1D2CB9B40079FDF8 /* pop.framework in CopyFiles */ = {isa = PBXBuildFile; fileRef = 9A82F33B1CDFF8CF00CC8906 /* pop.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; };
9A3169C11D2CC5AA0079FDF8 /* com.abhishek.ClockerHelper.plist in Resources */ = {isa = PBXBuildFile; fileRef = 9A3169C01D2CC5AA0079FDF8 /* com.abhishek.ClockerHelper.plist */; };
9A3247321C25FD3A00CF6B6E /* CLCustomSliderCell.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A3247311C25FD3A00CF6B6E /* CLCustomSliderCell.m */; };
9A3247391C263F4F00CF6B6E /* CLAppearanceViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A3247371C263F4F00CF6B6E /* CLAppearanceViewController.m */; };
9A392EE81C1CDD530072C10A /* CLAboutUsViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A392EE61C1CDD530072C10A /* CLAboutUsViewController.m */; };
@ -33,7 +34,6 @@
9A4379251BEC223900F4E27F /* Security.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A4379211BEC223900F4E27F /* Security.framework */; };
9A4379271BEC223900F4E27F /* Fabric.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A4379231BEC223900F4E27F /* Fabric.framework */; };
9A43792A1BEC230A00F4E27F /* libc++.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A4379291BEC230A00F4E27F /* libc++.tbd */; };
9A43792C1BEC231100F4E27F /* libz.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A43792B1BEC231100F4E27F /* libz.tbd */; };
9A56DB801C1CFB73004CE6AF /* MainMenu.xib in Resources */ = {isa = PBXBuildFile; fileRef = 9A56DB7D1C1CFB73004CE6AF /* MainMenu.xib */; };
9A5951BA1C1D0A22009C17AA /* Crashlytics.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A5951B91C1D0A22009C17AA /* Crashlytics.framework */; };
9A5951BD1C1D0A8D009C17AA /* CommonStrings.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A5951BB1C1D0A8D009C17AA /* CommonStrings.m */; };
@ -41,12 +41,12 @@
9A5951F51C1D3D81009C17AA /* CLTimezoneCellView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A5951F41C1D3D81009C17AA /* CLTimezoneCellView.m */; };
9A5951FA1C1D5214009C17AA /* iVersion.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A5951F91C1D5214009C17AA /* iVersion.m */; };
9A5951FD1C1D592D009C17AA /* iVersion.bundle in Resources */ = {isa = PBXBuildFile; fileRef = 9A5951FC1C1D592D009C17AA /* iVersion.bundle */; };
9A5E6BA01CAF71C1006E7C5C /* libicucore.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A5E6B9F1CAF71C1006E7C5C /* libicucore.tbd */; };
9A5B6C6E1D3DF6E4000EAAF1 /* CLParentViewController.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A5B6C6D1D3DF6E4000EAAF1 /* CLParentViewController.m */; };
9A5B6C711D4087A5000EAAF1 /* NSString+CLStringAdditions.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A5B6C701D4087A5000EAAF1 /* NSString+CLStringAdditions.m */; };
9A5E6BAB1CAF8DFA006E7C5C /* iRate.bundle in Resources */ = {isa = PBXBuildFile; fileRef = 9A5E6BAA1CAF8DFA006E7C5C /* iRate.bundle */; };
9A63620A1C432F68004AD010 /* CLAPI.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A6362091C432F68004AD010 /* CLAPI.m */; };
9A63620A1C432F68004AD010 /* CLAPIConnector.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A6362091C432F68004AD010 /* CLAPIConnector.m */; };
9A6D93371CF3E82F005A8690 /* CoreImage.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A6D93361CF3E82F005A8690 /* CoreImage.framework */; settings = {ATTRIBUTES = (Weak, ); }; };
9A79E9901CB34B6800BA7916 /* CLParentPanelController.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A79E98F1CB34B6800BA7916 /* CLParentPanelController.m */; };
9A82F3441CDFF8F600CC8906 /* pop.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A82F33B1CDFF8CF00CC8906 /* pop.framework */; };
9A8605AE1BEC148400A810A4 /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A8605AD1BEC148400A810A4 /* main.m */; };
9A8605B61BEC14BE00A810A4 /* MenubarController.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A8605B41BEC14BE00A810A4 /* MenubarController.m */; };
9A8605B71BEC14BE00A810A4 /* ApplicationDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 9A8605B51BEC14BE00A810A4 /* ApplicationDelegate.m */; };
@ -71,7 +71,6 @@
9A9E87621C1FEDB500A7A2DF /* CFNetwork.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A9E87611C1FEDB500A7A2DF /* CFNetwork.framework */; };
9A9E87681C1FEDD300A7A2DF /* Security.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A9E87671C1FEDD300A7A2DF /* Security.framework */; };
9A9E876A1C1FEDDB00A7A2DF /* SystemConfiguration.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A9E87691C1FEDDB00A7A2DF /* SystemConfiguration.framework */; };
9A9E876C1C1FEDE700A7A2DF /* libsqlite3.tbd in Frameworks */ = {isa = PBXBuildFile; fileRef = 9A9E876B1C1FEDE700A7A2DF /* libsqlite3.tbd */; };
9AA4AC8C1CEC0FA60054ACB7 /* FloatingView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9AA4AC871CEC0FA60054ACB7 /* FloatingView.m */; };
9AA4AC8D1CEC0FA60054ACB7 /* CLShortcutAnimatedView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9AA4AC891CEC0FA60054ACB7 /* CLShortcutAnimatedView.m */; };
9AA4AC8E1CEC0FA60054ACB7 /* CLFavouriteAnimatedView.m in Sources */ = {isa = PBXBuildFile; fileRef = 9AA4AC8B1CEC0FA60054ACB7 /* CLFavouriteAnimatedView.m */; };
@ -84,18 +83,17 @@
9ABFB3801CA6882000E10745 /* ApplicationServices.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9ABFB37F1CA6882000E10745 /* ApplicationServices.framework */; };
9AC678E41C1ABAB9003B4F6B /* QuartzCore.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9AC678E31C1ABAB9003B4F6B /* QuartzCore.framework */; settings = {ATTRIBUTES = (Weak, ); }; };
9ACE03EF1CB0ADE00039FC01 /* Firebase.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 9ACE03EE1CB0ADE00039FC01 /* Firebase.framework */; };
9AD6DE571CE114DA007A8401 /* CLScaleUpButton.m in Sources */ = {isa = PBXBuildFile; fileRef = 9AD6DE561CE114DA007A8401 /* CLScaleUpButton.m */; };
9AF9A16B1C250AB300EE7C2A /* Reachability.m in Sources */ = {isa = PBXBuildFile; fileRef = 9AF9A16A1C250AB300EE7C2A /* Reachability.m */; };
DD4F7C0913C30F9F00825C6E /* Cocoa.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DD4F7C0813C30F9F00825C6E /* Cocoa.framework */; };
/* End PBXBuildFile section */
/* Begin PBXContainerItemProxy section */
9A20A06D1C4E801600FB45AB /* PBXContainerItemProxy */ = {
9A3169BE1D2CB9B40079FDF8 /* PBXContainerItemProxy */ = {
isa = PBXContainerItemProxy;
containerPortal = 9A20A0691C4E801500FB45AB /* Clocker-Helper.xcodeproj */;
proxyType = 2;
remoteGlobalIDString = 9A20A0551C4E801500FB45AB;
remoteInfo = "Clocker-Helper";
containerPortal = 9A82F32B1CDFF8CE00CC8906 /* pop.xcodeproj */;
proxyType = 1;
remoteGlobalIDString = EC68857E18C7B60000C6194C;
remoteInfo = "pop-osx-framework";
};
9A82F3361CDFF8CF00CC8906 /* PBXContainerItemProxy */ = {
isa = PBXContainerItemProxy;
@ -176,7 +174,6 @@
dstPath = Contents/Library/LoginItems;
dstSubfolderSpec = 1;
files = (
9A20A0721C4E80A800FB45AB /* Clocker-Helper.app in CopyFiles */,
);
runOnlyForDeploymentPostprocessing = 0;
};
@ -187,6 +184,7 @@
dstSubfolderSpec = 10;
files = (
9A86E2C41CE04F7B00547EE7 /* ShortcutRecorder.framework in CopyFiles */,
9A3169BD1D2CB9B40079FDF8 /* pop.framework in CopyFiles */,
9A86E2C51CE04F7B00547EE7 /* PTHotKey.framework in CopyFiles */,
);
runOnlyForDeploymentPostprocessing = 0;
@ -217,7 +215,6 @@
9A13BAEB1CA88A76007C6CBE /* en */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = en; path = en.lproj/Localizable.strings; sourceTree = "<group>"; };
9A13BAED1CA88AD3007C6CBE /* ja */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = ja; path = ja.lproj/Localizable.strings; sourceTree = "<group>"; };
9A20A04A1C4DEED200FB45AB /* IOKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = IOKit.framework; path = System/Library/Frameworks/IOKit.framework; sourceTree = SDKROOT; };
9A20A0691C4E801500FB45AB /* Clocker-Helper.xcodeproj */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.pb-project"; name = "Clocker-Helper.xcodeproj"; path = "Clocker-Helper/Clocker-Helper.xcodeproj"; sourceTree = "<group>"; };
9A20A06F1C4E804D00FB45AB /* ServiceManagement.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = ServiceManagement.framework; path = System/Library/Frameworks/ServiceManagement.framework; sourceTree = SDKROOT; };
9A20A0751C4EA53600FB45AB /* CLOnboardingWindowController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CLOnboardingWindowController.h; path = Clocker/Onboarding/CLOnboardingWindowController.h; sourceTree = "<group>"; };
9A20A0761C4EA53600FB45AB /* CLOnboardingWindowController.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = CLOnboardingWindowController.m; path = Clocker/Onboarding/CLOnboardingWindowController.m; sourceTree = "<group>"; };
@ -226,6 +223,7 @@
9A20A07D1C4EAAEB00FB45AB /* CLIntroView.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; name = CLIntroView.xib; path = Clocker/Onboarding/CLIntroView.xib; sourceTree = "<group>"; };
9A25F7411C1A5E17007D369B /* iRate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = iRate.h; path = "Clocker/Rate App/iRate.h"; sourceTree = "<group>"; };
9A25F7441C1A5E17007D369B /* iRate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = iRate.m; path = "Clocker/Rate App/iRate.m"; sourceTree = "<group>"; };
9A3169C01D2CC5AA0079FDF8 /* com.abhishek.ClockerHelper.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = com.abhishek.ClockerHelper.plist; path = Clocker/com.abhishek.ClockerHelper.plist; sourceTree = "<group>"; };
9A3247301C25FD3A00CF6B6E /* CLCustomSliderCell.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CLCustomSliderCell.h; path = "Clocker/Custom Slider/CLCustomSliderCell.h"; sourceTree = "<group>"; };
9A3247311C25FD3A00CF6B6E /* CLCustomSliderCell.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = CLCustomSliderCell.m; path = "Clocker/Custom Slider/CLCustomSliderCell.m"; sourceTree = "<group>"; };
9A3247361C263F4F00CF6B6E /* CLAppearanceViewController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CLAppearanceViewController.h; path = "Clocker/Appearance Tab/CLAppearanceViewController.h"; sourceTree = "<group>"; };
@ -253,6 +251,10 @@
9A5951F91C1D5214009C17AA /* iVersion.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = iVersion.m; path = "Clocker/Updated Version/iVersion.m"; sourceTree = "<group>"; };
9A5951FC1C1D592D009C17AA /* iVersion.bundle */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.plug-in"; name = iVersion.bundle; path = "Clocker/Updated Version/iVersion.bundle"; sourceTree = "<group>"; };
9A5B1A8D1BECDFB700A77C68 /* Clocker.entitlements */ = {isa = PBXFileReference; lastKnownFileType = text.xml; name = Clocker.entitlements; path = Clocker/Clocker.entitlements; sourceTree = "<group>"; };
9A5B6C6C1D3DF6E4000EAAF1 /* CLParentViewController.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CLParentViewController.h; path = Clocker/CLParentViewController.h; sourceTree = "<group>"; };
9A5B6C6D1D3DF6E4000EAAF1 /* CLParentViewController.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = CLParentViewController.m; path = Clocker/CLParentViewController.m; sourceTree = "<group>"; };
9A5B6C6F1D4087A5000EAAF1 /* NSString+CLStringAdditions.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = "NSString+CLStringAdditions.h"; path = "Clocker/Utilities/NSString+CLStringAdditions.h"; sourceTree = "<group>"; };
9A5B6C701D4087A5000EAAF1 /* NSString+CLStringAdditions.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = "NSString+CLStringAdditions.m"; path = "Clocker/Utilities/NSString+CLStringAdditions.m"; sourceTree = "<group>"; };
9A5E6B9F1CAF71C1006E7C5C /* libicucore.tbd */ = {isa = PBXFileReference; lastKnownFileType = "sourcecode.text-based-dylib-definition"; name = libicucore.tbd; path = usr/lib/libicucore.tbd; sourceTree = SDKROOT; };
9A5E6BA11CAF794D006E7C5C /* zh-Hans */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = "zh-Hans"; path = "zh-Hans.lproj/InfoPlist.strings"; sourceTree = "<group>"; };
9A5E6BA21CAF794D006E7C5C /* zh-Hans */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = "zh-Hans"; path = "zh-Hans.lproj/Localizable.strings"; sourceTree = "<group>"; };
@ -264,8 +266,8 @@
9A5E6BA81CAF794D006E7C5C /* zh-Hans */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = "zh-Hans"; path = "zh-Hans.lproj/CLAppFeedbackWindow.xib"; sourceTree = "<group>"; };
9A5E6BA91CAF794D006E7C5C /* zh-Hans */ = {isa = PBXFileReference; lastKnownFileType = file.xib; name = "zh-Hans"; path = "zh-Hans.lproj/CLOnboardingWindow.xib"; sourceTree = "<group>"; };
9A5E6BAA1CAF8DFA006E7C5C /* iRate.bundle */ = {isa = PBXFileReference; lastKnownFileType = "wrapper.plug-in"; path = iRate.bundle; sourceTree = "<group>"; };
9A6362081C432F68004AD010 /* CLAPI.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CLAPI.h; path = Clocker/API/CLAPI.h; sourceTree = "<group>"; };
9A6362091C432F68004AD010 /* CLAPI.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = CLAPI.m; path = Clocker/API/CLAPI.m; sourceTree = "<group>"; };
9A6362081C432F68004AD010 /* CLAPIConnector.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CLAPIConnector.h; path = Clocker/API/CLAPIConnector.h; sourceTree = "<group>"; };
9A6362091C432F68004AD010 /* CLAPIConnector.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = CLAPIConnector.m; path = Clocker/API/CLAPIConnector.m; sourceTree = "<group>"; };
9A6D93361CF3E82F005A8690 /* CoreImage.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = CoreImage.framework; path = System/Library/Frameworks/CoreImage.framework; sourceTree = SDKROOT; };
9A7654341CDC2290000FB825 /* zh-Hant */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = "zh-Hant"; path = "zh-Hant.lproj/InfoPlist.strings"; sourceTree = "<group>"; };
9A7654351CDC2290000FB825 /* zh-Hant */ = {isa = PBXFileReference; lastKnownFileType = text.plist.strings; name = "zh-Hant"; path = "zh-Hant.lproj/Localizable.strings"; sourceTree = "<group>"; };
@ -343,8 +345,6 @@
9ABFB37F1CA6882000E10745 /* ApplicationServices.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = ApplicationServices.framework; path = System/Library/Frameworks/ApplicationServices.framework; sourceTree = SDKROOT; };
9AC678E31C1ABAB9003B4F6B /* QuartzCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = QuartzCore.framework; path = System/Library/Frameworks/QuartzCore.framework; sourceTree = SDKROOT; };
9ACE03EE1CB0ADE00039FC01 /* Firebase.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = Firebase.framework; path = Frameworks/Firebase.framework; sourceTree = "<group>"; };
9AD6DE551CE114DA007A8401 /* CLScaleUpButton.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CLScaleUpButton.h; path = Clocker/CLScaleUpButton.h; sourceTree = "<group>"; };
9AD6DE561CE114DA007A8401 /* CLScaleUpButton.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = CLScaleUpButton.m; path = Clocker/CLScaleUpButton.m; sourceTree = "<group>"; };
9AF9A1691C250AB300EE7C2A /* Reachability.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = Reachability.h; path = Clocker/Reachability/Reachability.h; sourceTree = "<group>"; };
9AF9A16A1C250AB300EE7C2A /* Reachability.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = Reachability.m; path = Clocker/Reachability/Reachability.m; sourceTree = "<group>"; };
DD4F7C0413C30F9F00825C6E /* Clocker.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Clocker.app; sourceTree = BUILT_PRODUCTS_DIR; };
@ -361,15 +361,11 @@
9A6D93371CF3E82F005A8690 /* CoreImage.framework in Frameworks */,
9A86E2C21CE04F4A00547EE7 /* PTHotKey.framework in Frameworks */,
9A86E2C11CE04F4300547EE7 /* ShortcutRecorder.framework in Frameworks */,
9A82F3441CDFF8F600CC8906 /* pop.framework in Frameworks */,
9A9E876A1C1FEDDB00A7A2DF /* SystemConfiguration.framework in Frameworks */,
9A9E87621C1FEDB500A7A2DF /* CFNetwork.framework in Frameworks */,
9A5E6BA01CAF71C1006E7C5C /* libicucore.tbd in Frameworks */,
9ABFB3801CA6882000E10745 /* ApplicationServices.framework in Frameworks */,
9A20A0701C4E804D00FB45AB /* ServiceManagement.framework in Frameworks */,
9A20A04B1C4DEED200FB45AB /* IOKit.framework in Frameworks */,
9A43792C1BEC231100F4E27F /* libz.tbd in Frameworks */,
9A9E876C1C1FEDE700A7A2DF /* libsqlite3.tbd in Frameworks */,
9A3169BC1D2CB9B40079FDF8 /* pop.framework in Frameworks */,
9A9E87681C1FEDD300A7A2DF /* Security.framework in Frameworks */,
9A5951BA1C1D0A22009C17AA /* Crashlytics.framework in Frameworks */,
9A43792A1BEC230A00F4E27F /* libc++.tbd in Frameworks */,
@ -386,32 +382,25 @@
9A2000C61BFBCEF6002BFDE8 /* Utilties */ = {
isa = PBXGroup;
children = (
9A3169C01D2CC5AA0079FDF8 /* com.abhishek.ClockerHelper.plist */,
9A86E2B21CE0351C00547EE7 /* EDSunriseSet.h */,
9A86E2B31CE0351C00547EE7 /* EDSunriseSet.m */,
9A5951BB1C1D0A8D009C17AA /* CommonStrings.m */,
9A5951BC1C1D0A8D009C17AA /* CommonStrings.h */,
9A6362081C432F68004AD010 /* CLAPI.h */,
9A6362091C432F68004AD010 /* CLAPI.m */,
9A6362081C432F68004AD010 /* CLAPIConnector.h */,
9A6362091C432F68004AD010 /* CLAPIConnector.m */,
9A13BAE21CA882FA007C6CBE /* InfoPlist.strings */,
9A13BAEC1CA88A76007C6CBE /* Localizable.strings */,
9A10C6861CDAAB3000D474F1 /* CLPausableTimer.h */,
9A10C6871CDAAB3000D474F1 /* CLPausableTimer.m */,
9A10C68D1CDAC8B500D474F1 /* CLPanelTextField.h */,
9A10C68E1CDAC8B500D474F1 /* CLPanelTextField.m */,
9AD6DE551CE114DA007A8401 /* CLScaleUpButton.h */,
9AD6DE561CE114DA007A8401 /* CLScaleUpButton.m */,
9A5B6C6F1D4087A5000EAAF1 /* NSString+CLStringAdditions.h */,
9A5B6C701D4087A5000EAAF1 /* NSString+CLStringAdditions.m */,
);
name = Utilties;
sourceTree = "<group>";
};
9A20A06A1C4E801500FB45AB /* Products */ = {
isa = PBXGroup;
children = (
9A20A06E1C4E801600FB45AB /* Clocker-Helper.app */,
);
name = Products;
sourceTree = "<group>";
};
9A25F7481C1A5E21007D369B /* Rate */ = {
isa = PBXGroup;
children = (
@ -434,6 +423,8 @@
9A20A07B1C4EAAEB00FB45AB /* CLIntroViewController.h */,
9A20A07C1C4EAAEB00FB45AB /* CLIntroViewController.m */,
9A20A07D1C4EAAEB00FB45AB /* CLIntroView.xib */,
9A5B6C6C1D3DF6E4000EAAF1 /* CLParentViewController.h */,
9A5B6C6D1D3DF6E4000EAAF1 /* CLParentViewController.m */,
);
name = "View Controllers";
sourceTree = "<group>";
@ -490,8 +481,6 @@
9A13BAD01CA879E5007C6CBE /* CLAppearanceView.xib */,
9A13BAE81CA889BB007C6CBE /* CLAppFeedbackWindow.xib */,
9A13BAD41CA87DF4007C6CBE /* CLOnboardingWindow.xib */,
9A42394C1CB0616400A8E51A /* CLFloatingWindowController.h */,
9A42394D1CB0616400A8E51A /* CLFloatingWindowController.m */,
9AB2420D1CB723650017C17C /* CLFloatingWindow.xib */,
);
name = XIB;
@ -538,6 +527,8 @@
9A8605E51BEC165400A810A4 /* Controllers */ = {
isa = PBXGroup;
children = (
9A42394C1CB0616400A8E51A /* CLFloatingWindowController.h */,
9A42394D1CB0616400A8E51A /* CLFloatingWindowController.m */,
9A20A0751C4EA53600FB45AB /* CLOnboardingWindowController.h */,
9A20A0761C4EA53600FB45AB /* CLOnboardingWindowController.m */,
9A9E63831C2C673E009A299B /* CLAppFeedbackWindowController.h */,
@ -644,7 +635,6 @@
DD4F7C0513C30F9F00825C6E /* Products */,
9A25F7481C1A5E21007D369B /* Rate */,
9A82F32B1CDFF8CE00CC8906 /* pop.xcodeproj */,
9A20A0691C4E801500FB45AB /* Clocker-Helper.xcodeproj */,
);
sourceTree = "<group>";
};
@ -700,6 +690,7 @@
buildRules = (
);
dependencies = (
9A3169BF1D2CB9B40079FDF8 /* PBXTargetDependency */,
);
name = Clocker;
productName = Popup;
@ -743,10 +734,6 @@
productRefGroup = DD4F7C0513C30F9F00825C6E /* Products */;
projectDirPath = "";
projectReferences = (
{
ProductGroup = 9A20A06A1C4E801500FB45AB /* Products */;
ProjectRef = 9A20A0691C4E801500FB45AB /* Clocker-Helper.xcodeproj */;
},
{
ProductGroup = 9A82F32C1CDFF8CE00CC8906 /* Products */;
ProjectRef = 9A82F32B1CDFF8CE00CC8906 /* pop.xcodeproj */;
@ -764,13 +751,6 @@
/* End PBXProject section */
/* Begin PBXReferenceProxy section */
9A20A06E1C4E801600FB45AB /* Clocker-Helper.app */ = {
isa = PBXReferenceProxy;
fileType = wrapper.application;
path = "Clocker-Helper.app";
remoteRef = 9A20A06D1C4E801600FB45AB /* PBXContainerItemProxy */;
sourceTree = BUILT_PRODUCTS_DIR;
};
9A82F3371CDFF8CF00CC8906 /* libpop.a */ = {
isa = PBXReferenceProxy;
fileType = archive.ar;
@ -861,6 +841,7 @@
9A13BAC61CA86A88007C6CBE /* CLAboutUsView.xib in Resources */,
9A13BACE1CA879E5007C6CBE /* CLAppearanceView.xib in Resources */,
9A13BADA1CA87F3F007C6CBE /* CLOneWindow.xib in Resources */,
9A3169C11D2CC5AA0079FDF8 /* com.abhishek.ClockerHelper.plist in Resources */,
9A56DB801C1CFB73004CE6AF /* MainMenu.xib in Resources */,
9AB2420B1CB723650017C17C /* CLFloatingWindow.xib in Resources */,
9A87DAC41C358FA800A8CF3B /* DateTools.bundle in Resources */,
@ -895,7 +876,7 @@
9A79E9901CB34B6800BA7916 /* CLParentPanelController.m in Sources */,
9A87DAC51C358FA800A8CF3B /* DTConstants.m in Sources */,
9AB9357B1C1AD8F7001285A0 /* CLRatingCellView.m in Sources */,
9A63620A1C432F68004AD010 /* CLAPI.m in Sources */,
9A63620A1C432F68004AD010 /* CLAPIConnector.m in Sources */,
9A87DAC81C358FA800A8CF3B /* DTTimePeriodChain.m in Sources */,
9A87DAC71C358FA800A8CF3B /* DTTimePeriod.m in Sources */,
9A3247321C25FD3A00CF6B6E /* CLCustomSliderCell.m in Sources */,
@ -911,12 +892,14 @@
9A25F7471C1A5E17007D369B /* iRate.m in Sources */,
9A8605C01BEC14F600A810A4 /* Panel.m in Sources */,
9A8605BA1BEC14DC00A810A4 /* StatusItemView.m in Sources */,
9A5B6C6E1D3DF6E4000EAAF1 /* CLParentViewController.m in Sources */,
9A87DAC91C358FA800A8CF3B /* DTTimePeriodCollection.m in Sources */,
9A3247391C263F4F00CF6B6E /* CLAppearanceViewController.m in Sources */,
9A86E2B41CE0351C00547EE7 /* EDSunriseSet.m in Sources */,
9ABA2B031C671D49009DC0EF /* CLMainWindowController.m in Sources */,
9A9E63861C2C673E009A299B /* CLAppFeedbackWindowController.m in Sources */,
9AA4AC911CEC112E0054ACB7 /* QCMethod.m in Sources */,
9A5B6C711D4087A5000EAAF1 /* NSString+CLStringAdditions.m in Sources */,
9A8605BB1BEC14DC00A810A4 /* PanelController.m in Sources */,
9A8605B61BEC14BE00A810A4 /* MenubarController.m in Sources */,
9A42394F1CB0616400A8E51A /* CLFloatingWindowController.m in Sources */,
@ -925,7 +908,6 @@
9A20A07E1C4EAAEB00FB45AB /* CLIntroViewController.m in Sources */,
9A8605B71BEC14BE00A810A4 /* ApplicationDelegate.m in Sources */,
9A10C6881CDAAB3000D474F1 /* CLPausableTimer.m in Sources */,
9AD6DE571CE114DA007A8401 /* CLScaleUpButton.m in Sources */,
9A5951F51C1D3D81009C17AA /* CLTimezoneCellView.m in Sources */,
9ABF58721C29A80600BD0187 /* CLTimezoneData.m in Sources */,
9A8605AE1BEC148400A810A4 /* main.m in Sources */,
@ -937,6 +919,14 @@
};
/* End PBXSourcesBuildPhase section */
/* Begin PBXTargetDependency section */
9A3169BF1D2CB9B40079FDF8 /* PBXTargetDependency */ = {
isa = PBXTargetDependency;
name = "pop-osx-framework";
targetProxy = 9A3169BE1D2CB9B40079FDF8 /* PBXContainerItemProxy */;
};
/* End PBXTargetDependency section */
/* Begin PBXVariantGroup section */
9A13BAC81CA86A88007C6CBE /* CLAboutUsView.xib */ = {
isa = PBXVariantGroup;
@ -1108,10 +1098,11 @@
"$(inherited)",
"$(PROJECT_DIR)",
"$(PROJECT_DIR)/Frameworks",
"$(PROJECT_DIR)/Clocker/Parse",
);
GCC_PRECOMPILE_PREFIX_HEADER = YES;
GCC_PREFIX_HEADER = "Clocker/Clocker-Prefix.pch";
GCC_WARN_UNUSED_LABEL = YES;
GCC_WARN_UNUSED_PARAMETER = NO;
INFOPLIST_FILE = "Clocker/Clocker-Info.plist";
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks";
MACOSX_DEPLOYMENT_TARGET = 10.10;
@ -1212,10 +1203,11 @@
"$(inherited)",
"$(PROJECT_DIR)",
"$(PROJECT_DIR)/Frameworks",
"$(PROJECT_DIR)/Clocker/Parse",
);
GCC_PRECOMPILE_PREFIX_HEADER = YES;
GCC_PREFIX_HEADER = "Clocker/Clocker-Prefix.pch";
GCC_WARN_UNUSED_LABEL = YES;
GCC_WARN_UNUSED_PARAMETER = NO;
INFOPLIST_FILE = "Clocker/Clocker-Info.plist";
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks";
MACOSX_DEPLOYMENT_TARGET = 10.10;
@ -1245,10 +1237,11 @@
"$(inherited)",
"$(PROJECT_DIR)",
"$(PROJECT_DIR)/Frameworks",
"$(PROJECT_DIR)/Clocker/Parse",
);
GCC_PRECOMPILE_PREFIX_HEADER = YES;
GCC_PREFIX_HEADER = "Clocker/Clocker-Prefix.pch";
GCC_WARN_UNUSED_LABEL = YES;
GCC_WARN_UNUSED_PARAMETER = NO;
INFOPLIST_FILE = "Clocker/Clocker-Info.plist";
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/../Frameworks";
MACOSX_DEPLOYMENT_TARGET = 10.10;

BIN
Clocker.xcodeproj/project.xcworkspace/xcuserdata/abhishekbanthia.xcuserdatad/UserInterfaceState.xcuserstate generated

Binary file not shown.

10
Clocker.xcodeproj/xcuserdata/abhishekbanthia.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist

@ -9,13 +9,13 @@
shouldBeEnabled = "Yes"
ignoreCount = "0"
continueAfterRunningActions = "No"
filePath = "Clocker/Custom Slider/CLCustomSliderCell.m"
timestampString = "485926507.475266"
filePath = "Clocker/Preferences/CLPreferencesViewController.m"
timestampString = "491092836.331017"
startingColumnNumber = "9223372036854775807"
endingColumnNumber = "9223372036854775807"
startingLineNumber = "17"
endingLineNumber = "17"
landmarkName = "-drawBarInside:flipped:"
startingLineNumber = "174"
endingLineNumber = "174"
landmarkName = "-acceptsFirstResponder"
landmarkType = "5">
</BreakpointContent>
</BreakpointProxy>

4
Clocker.xcodeproj/xcuserdata/abhishekbanthia.xcuserdatad/xcschemes/Clocker.xcscheme

@ -1,6 +1,6 @@
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
LastUpgradeVersion = "0700"
LastUpgradeVersion = "0730"
version = "1.3">
<BuildAction
parallelizeBuildables = "YES"
@ -52,7 +52,7 @@
debugServiceExtension = "internal"
allowLocationSimulation = "YES"
showNonLocalizedStrings = "YES"
language = "ja"
language = "en"
region = "US">
<BuildableProductRunnable
runnableDebuggingMode = "0">

2
Clocker/API/CLAPI.h → Clocker/API/CLAPIConnector.h

@ -8,7 +8,7 @@
#import <Foundation/Foundation.h>
@interface CLAPI : NSObject
@interface CLAPIConnector : NSObject
+ (void)dataTaskWithServicePath:(NSString *)path
bySender:(id)sender

8
Clocker/API/CLAPI.m → Clocker/API/CLAPIConnector.m

@ -6,17 +6,17 @@
//
//
#import "CLAPI.h"
#import "CLAPIConnector.h"
#import "Reachability.h"
@implementation CLAPI
@implementation CLAPIConnector
+ (void)dataTaskWithServicePath:(NSString *)path
bySender:(id)sender
withCompletionBlock:(void (^)(NSError *error, NSDictionary *dictionary))completionBlock
{
__block NSDictionary *responseDictionary = [NSDictionary dictionary];
__block NSDictionary *responseDictionary = @{};
NSURLSessionConfiguration *sessionConfig = [NSURLSessionConfiguration defaultSessionConfiguration];
@ -27,7 +27,7 @@
NSURL *url = [NSURL URLWithString:[NSString stringWithFormat:@"%@", path]];
NSMutableURLRequest *request = [[NSMutableURLRequest alloc] initWithURL:url];
[request setHTTPMethod:@"GET"];
request.HTTPMethod = @"GET";
[request setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[request setValue:@"application/json" forHTTPHeaderField:@"Accept"];

4
Clocker/AboutUsWindow/CLAboutUsViewController.h

@ -7,9 +7,9 @@
//
#import <Cocoa/Cocoa.h>
#import "CLAppFeedbackWindowController.h"
#import "CLParentViewController.h"
@interface CLAboutUsViewController : NSViewController
@interface CLAboutUsViewController : CLParentViewController

30
Clocker/AboutUsWindow/CLAboutUsViewController.m

@ -8,6 +8,7 @@
#import "CLAboutUsViewController.h"
#import "CommonStrings.h"
#import "CLAppFeedbackWindowController.h"
@interface CLAboutUsViewController ()
@ -29,11 +30,6 @@ NSString *const CLFacebookPageURL = @"https://www.facebook.com/ClockerMenubarClo
self.versionField.stringValue = NSLocalizedFormatString(@"ClockerVersion", [[NSBundle mainBundle] objectForInfoDictionaryKey:@"CFBundleShortVersionString"]);
CALayer *viewLayer = [CALayer layer];
[viewLayer setBackgroundColor:CGColorCreateGenericRGB(255.0, 255.0, 255.0, 0.8)]; //RGB plus Alpha Channel
[self.view setWantsLayer:YES]; // view's backing store is using a Core Animation Layer
[self.view setLayer:viewLayer];
// Do view setup here.
}
@ -54,28 +50,4 @@ NSString *const CLFacebookPageURL = @"https://www.facebook.com/ClockerMenubarClo
[[NSWorkspace sharedWorkspace] openURL:[NSURL URLWithString:CLFacebookPageURL]];
}
- (NSString *)getSerialNumber
{
io_service_t platformExpert = IOServiceGetMatchingService(kIOMasterPortDefault,
IOServiceMatching("IOPlatformExpertDevice"));
CFStringRef serialNumberAsCFString = NULL;
if (platformExpert) {
serialNumberAsCFString = IORegistryEntryCreateCFProperty(platformExpert,
CFSTR(kIOPlatformSerialNumberKey),
kCFAllocatorDefault, 0);
IOObjectRelease(platformExpert);
}
NSString *serialNumberAsNSString = nil;
if (serialNumberAsCFString) {
serialNumberAsNSString = [NSString stringWithString:(__bridge NSString *)serialNumberAsCFString];
CFRelease(serialNumberAsCFString);
}
return serialNumberAsNSString;
}
@end

82
Clocker/App Feedback/CLAppFeedbackWindowController.m

@ -12,11 +12,10 @@
#import <Firebase/Firebase.h>
NSString *const CLAppFeedbackNibIdentifier = @"CLAppFeedbackWindow";
NSString *const CLParseAppFeedbackClassIdentifier = @"CLAppFeedback";
NSString *const CLParseAppFeedbackNoResponseString = @"Not Provided";
NSString *const CLParseAppFeedbackNameProperty = @"name";
NSString *const CLParseAppFeedbackEmailProperty = @"email";
NSString *const CLParseAppFeedbackFeedbackProperty = @"feedback";
NSString *const CLAppFeedbackNoResponseString = @"Not Provided";
NSString *const CLAppFeedbackNameProperty = @"name";
NSString *const CLAppFeedbackEmailProperty = @"email";
NSString *const CLAppFeedbackFeedbackProperty = @"feedback";
NSString *const CLFeedbackAlertTitle = @"Thank you for helping make Clocker even better!";
NSString *const CLFeedbackAlertInformativeText = @"We owe you a candy. 😇";
NSString *const CLFeedbackAlertButtonTitle = @"Close";
@ -39,7 +38,6 @@ static CLAppFeedbackWindowController *sharedFeedbackWindow = nil;
[super windowDidLoad];
self.window.backgroundColor = [NSColor whiteColor];
self.window.titleVisibility = NSWindowTitleHidden;
// Implement this method to handle any initialization after your window controller's window has been loaded from its nib file.
@ -73,38 +71,60 @@ static CLAppFeedbackWindowController *sharedFeedbackWindow = nil;
- (IBAction)sendFeedback:(id)sender
{
[self cleanUp];
[self resetInformativeTextLabel];
self.activityInProgress = YES;
if (![self didUserEnterFeedback]){
return;
}
NSMutableDictionary *feedbackInfo = [self retrieveDataForSending];
[self sendDataToFirebase:feedbackInfo];
[self showDataConfirmation];
}
- (BOOL)didUserEnterFeedback
{
if (self.feedbackTextView.string.length == 0)
{
self.informativeText.stringValue = CLFeedbackNotEnteredErrorMessage;
[NSTimer scheduledTimerWithTimeInterval:5.0
target:self
selector:@selector(cleanUp)
selector:@selector(resetInformativeTextLabel)
userInfo:nil
repeats:NO];
self.activityInProgress = NO;
return;
return NO;
}
return YES;
}
- (NSMutableDictionary *)retrieveDataForSending
{
NSMutableDictionary *feedbackInfo = [[NSMutableDictionary alloc] init];
[feedbackInfo setObject:(self.nameField.stringValue.length > 0) ?
self.nameField.stringValue : CLParseAppFeedbackNoResponseString forKey:CLParseAppFeedbackNameProperty];
[feedbackInfo setObject:(self.emailField.stringValue.length > 0) ?
self.emailField.stringValue : CLParseAppFeedbackNoResponseString forKey:CLParseAppFeedbackEmailProperty];
[feedbackInfo setObject:self.feedbackTextView.string forKey:CLParseAppFeedbackFeedbackProperty ];
feedbackInfo[CLAppFeedbackNameProperty] = (self.nameField.stringValue.length > 0) ?
self.nameField.stringValue : CLAppFeedbackNoResponseString;
feedbackInfo[CLAppFeedbackEmailProperty] = (self.emailField.stringValue.length > 0) ?
self.emailField.stringValue : CLAppFeedbackNoResponseString;
feedbackInfo[CLAppFeedbackFeedbackProperty] = self.feedbackTextView.string;
return feedbackInfo;
}
// Create a reference to a Firebase database URL
- (void)sendDataToFirebase:(NSDictionary *)feedbackInfo
{
Firebase *myRootRef = [[Firebase alloc] initWithUrl:@"https://fiery-heat-5237.firebaseio.com/Feedback"];
Firebase *feedbackRef = [myRootRef childByAppendingPath:[self getSerialNumber]];
// Write data to Firebase
[feedbackRef setValue:feedbackInfo];
}
- (void)showDataConfirmation
{
self.activityInProgress = NO;
NSAlert *alert = [NSAlert new];
alert.messageText = NSLocalizedString(CLFeedbackAlertTitle, @"Thank you for helping make Clocker even better!");
alert.informativeText = CLFeedbackAlertInformativeText;
@ -115,7 +135,7 @@ static CLAppFeedbackWindowController *sharedFeedbackWindow = nil;
}];
}
- (void)cleanUp
- (void)resetInformativeTextLabel
{
self.informativeText.stringValue = CLEmptyString;
}
@ -127,26 +147,30 @@ static CLAppFeedbackWindowController *sharedFeedbackWindow = nil;
-(void)windowWillClose:(NSNotification *)notification
{
[self cleanUp];
[self resetInformativeTextLabel];
[self performClosingCleanUp];
[self bringPreferencesWindowToFront];
}
- (void)performClosingCleanUp
{
self.nameField.stringValue = CLEmptyString;
self.emailField.stringValue = CLEmptyString;
self.feedbackTextView.string = CLEmptyString;
self.activityInProgress = NO;
}
[[NSApplication sharedApplication].windows enumerateObjectsUsingBlock:^(NSWindow * _Nonnull window, NSUInteger idx, BOOL * _Nonnull stop) {
if ([window.windowController isMemberOfClass:[CLOneWindowController class]]) {
[window makeKeyAndOrderFront:self];
[NSApp activateIgnoringOtherApps:YES];
}
}];
-(void)bringPreferencesWindowToFront
{
CLOneWindowController *oneWindowController = [CLOneWindowController sharedWindow];
[oneWindowController.window makeKeyAndOrderFront:self];
[NSApp activateIgnoringOtherApps:YES];
}
- (NSString *)getSerialNumber
{
io_service_t platformExpert = IOServiceGetMatchingService(kIOMasterPortDefault,
IOServiceMatching("IOPlatformExpertDevice"));
io_service_t platformExpert = IOServiceGetMatchingService(kIOMasterPortDefault, IOServiceMatching("IOPlatformExpertDevice"));
CFStringRef serialNumberAsCFString = NULL;
if (platformExpert) {

3
Clocker/Appearance Tab/CLAppearanceViewController.h

@ -7,7 +7,8 @@
//
#import <Cocoa/Cocoa.h>
#import "CLParentViewController.h"
@interface CLAppearanceViewController : NSViewController
@interface CLAppearanceViewController : CLParentViewController
@end

92
Clocker/Appearance Tab/CLAppearanceViewController.m

@ -13,6 +13,11 @@
#import "CLTimezoneData.h"
#import "CLFloatingWindowController.h"
typedef NS_ENUM(NSUInteger, CLClockerMode) {
CLMenubarMode = 0,
CLFloatingMode
};
@interface CLAppearanceViewController ()
@property (weak) IBOutlet NSSegmentedControl *timeFormat;
@property (weak) IBOutlet NSSegmentedControl *theme;
@ -26,11 +31,6 @@
- (void)viewDidLoad {
[super viewDidLoad];
CALayer *viewLayer = [CALayer layer];
[viewLayer setBackgroundColor:CGColorCreateGenericRGB(255.0, 255.0, 255.0, 0.8)]; //RGB plus Alpha Channel
[self.view setWantsLayer:YES]; // view's backing store is using a Core Animation Layer
[self.view setLayer:viewLayer];
self.informationLabel.stringValue = @"Select a favourite timezone to enable menubar display options.";
self.informationLabel.textColor = [NSColor secondaryLabelColor];
@ -38,14 +38,11 @@
}
- (IBAction)timeFormatSelectionChanged:(id)sender
{
NSSegmentedControl *timeFormat = (NSSegmentedControl *)sender;
[[NSUserDefaults standardUserDefaults] setObject:[NSNumber numberWithInteger:timeFormat.selectedSegment] forKey:CL24hourFormatSelectedKey];
[[NSUserDefaults standardUserDefaults] setObject:@(timeFormat.selectedSegment) forKey:CL24hourFormatSelectedKey];
[self refreshMainTableview:YES andUpdateFloatingWindow:YES];
}
@ -57,8 +54,8 @@
//Get the current display mode
[self refreshMainTableview:NO andUpdateFloatingWindow:YES];
ApplicationDelegate *appDelegate = [[NSApplication sharedApplication] delegate];
PanelController *panelController = appDelegate.panelController;
PanelController *panelController = [PanelController getPanelControllerInstance];
[panelController.backgroundView setNeedsDisplay:YES];
if (themeSegment.selectedSegment == CLBlackTheme) {
@ -76,37 +73,37 @@
[panelController updatePanelColor];
}
[panelController.mainTableview reloadData];
[panelController updateTableContent];
}
- (IBAction)displayModeChanged:(id)sender
- (IBAction)displayModeChanged:(NSSegmentedControl *)modeSegment
{
NSSegmentedControl *modeSegment = (NSSegmentedControl *)sender;
ApplicationDelegate *sharedDelege = (ApplicationDelegate*)[NSApplication sharedApplication].delegate;
ApplicationDelegate *sharedDelegate = (ApplicationDelegate*)[NSApplication sharedApplication].delegate;
if (modeSegment.selectedSegment == 1)
if (modeSegment.selectedSegment == CLFloatingMode)
{
sharedDelege.floatingWindow = [CLFloatingWindowController sharedFloatingWindow];
[sharedDelege.floatingWindow showWindow:nil];
[sharedDelege.floatingWindow updateDefaultPreferences];
[sharedDelege.floatingWindow startWindowTimer];
sharedDelegate.floatingWindow = [CLFloatingWindowController sharedFloatingWindow];
[sharedDelegate.floatingWindow showWindow:nil];
[sharedDelegate.floatingWindow updateDefaultPreferences];
[sharedDelegate.floatingWindow startWindowTimer];
[NSApp activateIgnoringOtherApps:YES];
}
else
{
sharedDelege.floatingWindow = [CLFloatingWindowController sharedFloatingWindow];
[sharedDelege.floatingWindow.window close];
[sharedDelege.panelController updateDefaultPreferences];
sharedDelegate.floatingWindow = [CLFloatingWindowController sharedFloatingWindow];
[sharedDelegate.floatingWindow.window close];
[sharedDelegate.panelController updateDefaultPreferences];
}
}
- (IBAction)changeRelativeDayDisplay:(id)sender
- (IBAction)changeRelativeDayDisplay:(NSSegmentedControl *)relativeDayControl
{
NSSegmentedControl *relativeDayControl = (NSSegmentedControl*) sender;
NSNumber *selectedIndex = [NSNumber numberWithInteger:relativeDayControl.selectedSegment];
NSNumber *selectedIndex = @(relativeDayControl.selectedSegment);
[[NSUserDefaults standardUserDefaults] setObject:selectedIndex forKey:CLRelativeDateKey];
[self refreshMainTableview:YES andUpdateFloatingWindow:YES];
}
@ -117,15 +114,15 @@
if (panel)
{
ApplicationDelegate *appDelegate = [[NSApplication sharedApplication] delegate];
ApplicationDelegate *appDelegate = (ApplicationDelegate *)[NSApplication sharedApplication].delegate;
PanelController *panelController = appDelegate.panelController;
PanelController *panelController = [PanelController getPanelControllerInstance];
[panelController updateDefaultPreferences];
[panelController.mainTableview reloadData];
[panelController updateTableContent];
[appDelegate.menubarController shouldIconBeUpdated:YES];
[appDelegate.menubarController setUpTimerForUpdatingMenubar];
}
if (value)
@ -133,40 +130,23 @@
//Get the current display mode
NSNumber *displayMode = [[NSUserDefaults standardUserDefaults] objectForKey:CLShowAppInForeground];
if (displayMode.integerValue == 1)
if (displayMode.integerValue == CLFloatingMode)
{
//Get the Floating window instance
for (NSWindow *window in [NSApplication sharedApplication].windows)
CLFloatingWindowController *floatingWindowInstance = [CLFloatingWindowController sharedFloatingWindow];
[floatingWindowInstance updateTableContent];
//Only one instance where we need to update panel color and in that instance we pass panel as NO
if (!panel)
{
if ([window.windowController isKindOfClass:[CLFloatingWindowController class]])
{
CLFloatingWindowController *currentInstance = (CLFloatingWindowController *)window.windowController;
[currentInstance.mainTableview reloadData];
//Only one instance where we need to update panel color and in that instance we pass panel as NO
if (!panel)
{
[currentInstance updatePanelColor];
}
}
[floatingWindowInstance updatePanelColor];
}
}
}
});
}
- (IBAction)changeMenuBarDisplayPreferences:(id)sender
{
NSSegmentedControl *segmentedControl = (NSSegmentedControl *)sender;
NSNumber *shouldDayBeShown = [NSNumber numberWithBool:[segmentedControl isSelectedForSegment:0]];
NSNumber *shouldCityBeShown = [NSNumber numberWithBool:[segmentedControl isSelectedForSegment:1]];
NSUserDefaults *userDefaults = [NSUserDefaults standardUserDefaults];
[userDefaults setObject:shouldDayBeShown forKey:@"shouldDayBeShown"];
[userDefaults setObject:shouldCityBeShown forKey:@"shouldCityBeShown"];
}
- (IBAction)showFutureSlider:(id)sender
{
//Get the current display mode

18
Clocker/Appearance Tab/en.lproj/CLAppearanceView.xib

@ -89,9 +89,9 @@
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="3d9-qg-dNb">
<rect key="frame" x="130" y="170" width="179" height="18"/>
<rect key="frame" x="130" y="166" width="179" height="22"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="MdL-Dh-02n"/>
<constraint firstAttribute="height" constant="22" id="MdL-Dh-02n"/>
<constraint firstAttribute="width" constant="175" id="hHO-Wa-gmc"/>
</constraints>
<textFieldCell key="cell" scrollable="YES" lineBreakMode="clipping" sendsActionOnEndEditing="YES" alignment="center" title="Menubar Display Options" id="ZP5-1i-Bm8">
@ -101,7 +101,7 @@
</textFieldCell>
</textField>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="pqa-Qg-U8Y">
<rect key="frame" x="130" y="141" width="179" height="20"/>
<rect key="frame" x="130" y="137" width="179" height="20"/>
<constraints>
<constraint firstAttribute="width" constant="175" id="B2I-0j-0W0"/>
</constraints>
@ -115,7 +115,7 @@
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="atA-2r-FXV">
<rect key="frame" x="179" y="113" width="84" height="24"/>
<rect key="frame" x="179" y="109" width="84" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="BqM-4F-6Ta"/>
<constraint firstAttribute="width" constant="80" id="ZeK-lO-tUa"/>
@ -133,7 +133,7 @@
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="kEn-QZ-niZ">
<rect key="frame" x="130" y="88" width="179" height="22"/>
<rect key="frame" x="130" y="84" width="179" height="22"/>
<constraints>
<constraint firstAttribute="height" constant="22" id="2fd-f6-8cD"/>
<constraint firstAttribute="width" constant="175" id="D0w-xz-gkw"/>
@ -148,7 +148,7 @@
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="XwV-hy-YiP">
<rect key="frame" x="178" y="60" width="84" height="24"/>
<rect key="frame" x="178" y="56" width="84" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="80" id="dBz-ZQ-BF1"/>
<constraint firstAttribute="height" constant="21" id="y8c-hZ-MtI"/>
@ -227,7 +227,7 @@
<font key="titleFont" metaFont="system"/>
</box>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="LC1-Sx-uav">
<rect key="frame" x="130" y="36" width="179" height="18"/>
<rect key="frame" x="130" y="32" width="179" height="18"/>
<constraints>
<constraint firstAttribute="width" constant="175" id="Pdc-78-vzv"/>
<constraint firstAttribute="height" constant="18" id="hsh-i8-ULY"/>
@ -242,7 +242,7 @@
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="JR8-v7-K0w">
<rect key="frame" x="178" y="8" width="84" height="24"/>
<rect key="frame" x="178" y="4" width="84" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="Xof-eY-ZUl"/>
<constraint firstAttribute="width" constant="80" id="msH-Xd-mrp"/>
@ -291,7 +291,7 @@
<visualEffectView wantsLayer="YES" appearanceType="vibrantLight" alphaValue="0.90000000000000002" blendingMode="withinWindow" state="followsWindowActiveState" translatesAutoresizingMaskIntoConstraints="NO" id="kHi-mx-HdE">
<rect key="frame" x="0.0" y="0.0" width="439" height="196"/>
<subviews>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="WDP-d4-eNj">
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="320" translatesAutoresizingMaskIntoConstraints="NO" id="WDP-d4-eNj">
<rect key="frame" x="57" y="84" width="324" height="39"/>
<constraints>
<constraint firstAttribute="width" constant="320" id="3wp-Z6-TrB"/>

48
Clocker/Appearance Tab/ja.lproj/CLAppearanceView.xib

@ -19,7 +19,7 @@
<autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMinY="YES"/>
<subviews>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="60" translatesAutoresizingMaskIntoConstraints="NO" id="iVw-cq-zLz">
<rect key="frame" x="188" y="467" width="64" height="18"/>
<rect key="frame" x="188" y="463" width="64" height="18"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="2DP-wK-Ga8"/>
<constraint firstAttribute="width" constant="60" id="KEa-ei-G2i"/>
@ -31,9 +31,9 @@
</textFieldCell>
</textField>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="100" translatesAutoresizingMaskIntoConstraints="NO" id="5TC-RQ-gzI">
<rect key="frame" x="168" y="529" width="104" height="18"/>
<rect key="frame" x="168" y="525" width="104" height="22"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="gWc-u4-D8E"/>
<constraint firstAttribute="height" constant="22" id="gWc-u4-D8E"/>
<constraint firstAttribute="width" constant="100" id="nh0-5K-Aa0"/>
</constraints>
<textFieldCell key="cell" scrollable="YES" lineBreakMode="clipping" sendsActionOnEndEditing="YES" alignment="center" title="時間スタイル" id="Hza-PB-FEf">
@ -43,7 +43,7 @@
</textFieldCell>
</textField>
<segmentedControl toolTip="Choose a theme for the main panel!" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="5tI-fU-0lZ">
<rect key="frame" x="166" y="436" width="107" height="24"/>
<rect key="frame" x="166" y="432" width="107" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="103" id="dW5-vG-EwD"/>
</constraints>
@ -60,7 +60,7 @@
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="150" translatesAutoresizingMaskIntoConstraints="NO" id="YQi-x8-6f8">
<rect key="frame" x="143" y="405" width="154" height="18"/>
<rect key="frame" x="143" y="401" width="154" height="18"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="eY8-bV-QLM"/>
<constraint firstAttribute="width" constant="150" id="n8S-fR-UtY"/>
@ -72,7 +72,7 @@
</textFieldCell>
</textField>
<segmentedControl toolTip="Select a time-format!" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="OrL-Ix-fmY">
<rect key="frame" x="102" y="498" width="236" height="24"/>
<rect key="frame" x="102" y="494" width="236" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="232" id="uOJ-Mi-Fin"/>
</constraints>
@ -89,7 +89,7 @@
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="3d9-qg-dNb">
<rect key="frame" x="130" y="167" width="179" height="24"/>
<rect key="frame" x="130" y="163" width="179" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="24" id="MdL-Dh-02n"/>
<constraint firstAttribute="width" constant="175" id="hHO-Wa-gmc"/>
@ -101,7 +101,7 @@
</textFieldCell>
</textField>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="pqa-Qg-U8Y">
<rect key="frame" x="130" y="138" width="179" height="20"/>
<rect key="frame" x="130" y="134" width="179" height="20"/>
<constraints>
<constraint firstAttribute="width" constant="175" id="B2I-0j-0W0"/>
</constraints>
@ -115,7 +115,7 @@
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="atA-2r-FXV">
<rect key="frame" x="178" y="110" width="84" height="24"/>
<rect key="frame" x="178" y="106" width="84" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="BqM-4F-6Ta"/>
<constraint firstAttribute="width" constant="80" id="ZeK-lO-tUa"/>
@ -133,7 +133,7 @@
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="kEn-QZ-niZ">
<rect key="frame" x="130" y="89" width="179" height="18"/>
<rect key="frame" x="130" y="85" width="179" height="18"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="2fd-f6-8cD"/>
<constraint firstAttribute="width" constant="175" id="D0w-xz-gkw"/>
@ -148,7 +148,7 @@
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="XwV-hy-YiP">
<rect key="frame" x="178" y="61" width="84" height="24"/>
<rect key="frame" x="178" y="57" width="84" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="80" id="dBz-ZQ-BF1"/>
<constraint firstAttribute="height" constant="21" id="y8c-hZ-MtI"/>
@ -166,7 +166,7 @@
</connections>
</segmentedControl>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="72r-oi-X0f">
<rect key="frame" x="184" y="318" width="71" height="24"/>
<rect key="frame" x="184" y="314" width="71" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="67" id="H8w-wg-vel"/>
</constraints>
@ -183,7 +183,7 @@
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="HTZ-1V-qZb">
<rect key="frame" x="158" y="349" width="124" height="20"/>
<rect key="frame" x="158" y="345" width="124" height="20"/>
<constraints>
<constraint firstAttribute="width" constant="120" id="1Lv-wC-hEM"/>
</constraints>
@ -194,13 +194,13 @@
</textFieldCell>
</textField>
<box verticalHuggingPriority="750" title="Box" boxType="separator" titlePosition="noTitle" translatesAutoresizingMaskIntoConstraints="NO" id="MHe-dB-GZr">
<rect key="frame" x="0.0" y="193" width="439" height="5"/>
<rect key="frame" x="0.0" y="189" width="439" height="5"/>
<color key="borderColor" white="0.0" alpha="0.41999999999999998" colorSpace="calibratedWhite"/>
<color key="fillColor" white="0.0" alpha="0.0" colorSpace="calibratedWhite"/>
<font key="titleFont" metaFont="system"/>
</box>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="LC1-Sx-uav">
<rect key="frame" x="130" y="37" width="179" height="18"/>
<rect key="frame" x="130" y="33" width="179" height="18"/>
<constraints>
<constraint firstAttribute="width" constant="175" id="Pdc-78-vzv"/>
<constraint firstAttribute="height" constant="18" id="hsh-i8-ULY"/>
@ -215,7 +215,7 @@
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="JR8-v7-K0w">
<rect key="frame" x="178" y="9" width="84" height="24"/>
<rect key="frame" x="178" y="5" width="84" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="Xof-eY-ZUl"/>
<constraint firstAttribute="width" constant="80" id="msH-Xd-mrp"/>
@ -245,7 +245,7 @@
</textFieldCell>
</textField>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="1eh-BT-2fK">
<rect key="frame" x="155" y="374" width="129" height="24"/>
<rect key="frame" x="155" y="370" width="129" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="125" id="u9T-ks-rqA"/>
</constraints>
@ -262,10 +262,10 @@
</connections>
</segmentedControl>
<visualEffectView wantsLayer="YES" appearanceType="vibrantLight" alphaValue="0.90000000000000002" blendingMode="withinWindow" state="followsWindowActiveState" translatesAutoresizingMaskIntoConstraints="NO" id="kHi-mx-HdE">
<rect key="frame" x="0.0" y="0.0" width="439" height="195"/>
<rect key="frame" x="0.0" y="0.0" width="439" height="191"/>
<subviews>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="WDP-d4-eNj">
<rect key="frame" x="57" y="78" width="324" height="39"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="320" translatesAutoresizingMaskIntoConstraints="NO" id="WDP-d4-eNj">
<rect key="frame" x="57" y="76" width="324" height="39"/>
<constraints>
<constraint firstAttribute="width" constant="320" id="3wp-Z6-TrB"/>
<constraint firstAttribute="height" constant="39" id="IyN-y5-6JP"/>
@ -292,7 +292,7 @@
</connections>
</visualEffectView>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="4j5-9I-Tnd">
<rect key="frame" x="158" y="286" width="124" height="20"/>
<rect key="frame" x="158" y="282" width="124" height="20"/>
<constraints>
<constraint firstAttribute="width" constant="120" id="GzK-ID-ikO"/>
</constraints>
@ -303,7 +303,7 @@
</textFieldCell>
</textField>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="haT-zt-gJ4">
<rect key="frame" x="53" y="255" width="334" height="24"/>
<rect key="frame" x="53" y="251" width="334" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="330" id="IeS-OV-AVP"/>
</constraints>
@ -320,7 +320,7 @@
</connections>
</segmentedControl>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="AYV-9U-UMC">
<rect key="frame" x="180" y="202" width="79" height="24"/>
<rect key="frame" x="180" y="198" width="79" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="75" id="EZM-08-yj4"/>
<constraint firstAttribute="height" constant="21" id="Fpv-eR-VDX"/>
@ -337,7 +337,7 @@
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="vSg-CZ-PbR">
<rect key="frame" x="138" y="229" width="164" height="19"/>
<rect key="frame" x="138" y="225" width="164" height="19"/>
<constraints>
<constraint firstAttribute="width" constant="160" id="g35-pI-NgZ"/>
<constraint firstAttribute="height" constant="19" id="ron-iL-V0y"/>

34
Clocker/Appearance Tab/zh-Hans.lproj/CLAppearanceView.xib

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="9531" systemVersion="15E65" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="10117" systemVersion="15F34" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
<dependencies>
<plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="9531"/>
<plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="10117"/>
</dependencies>
<objects>
<customObject id="-2" userLabel="File's Owner" customClass="CLAppearanceViewController">
@ -89,9 +89,9 @@
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="3d9-qg-dNb">
<rect key="frame" x="130" y="173" width="179" height="18"/>
<rect key="frame" x="130" y="171" width="179" height="20"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="MdL-Dh-02n"/>
<constraint firstAttribute="height" constant="20" id="MdL-Dh-02n"/>
<constraint firstAttribute="width" constant="175" id="hHO-Wa-gmc"/>
</constraints>
<textFieldCell key="cell" scrollable="YES" lineBreakMode="clipping" sendsActionOnEndEditing="YES" alignment="center" title="菜单栏选项" id="ZP5-1i-Bm8">
@ -100,8 +100,8 @@
<color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
</textFieldCell>
</textField>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="pqa-Qg-U8Y">
<rect key="frame" x="130" y="145" width="179" height="19"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="pqa-Qg-U8Y">
<rect key="frame" x="130" y="142" width="179" height="20"/>
<constraints>
<constraint firstAttribute="width" constant="175" id="B2I-0j-0W0"/>
</constraints>
@ -114,8 +114,8 @@
<binding destination="-2" name="enabled" keyPath="self.enableOptions" id="wwV-Hq-RlT"/>
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="atA-2r-FXV">
<rect key="frame" x="180" y="117" width="83" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="atA-2r-FXV">
<rect key="frame" x="180" y="114" width="83" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="BqM-4F-6Ta"/>
<constraint firstAttribute="width" constant="79" id="ZeK-lO-tUa"/>
@ -132,8 +132,8 @@
<binding destination="WGI-5h-l6M" name="selectedIndex" keyPath="values.showDate" id="Qee-Dc-Piu"/>
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="kEn-QZ-niZ">
<rect key="frame" x="130" y="96" width="179" height="18"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="kEn-QZ-niZ">
<rect key="frame" x="130" y="93" width="179" height="18"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="2fd-f6-8cD"/>
<constraint firstAttribute="width" constant="175" id="D0w-xz-gkw"/>
@ -147,8 +147,8 @@
<binding destination="-2" name="enabled" keyPath="self.enableOptions" id="56M-0X-vvP"/>
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="XwV-hy-YiP">
<rect key="frame" x="179" y="68" width="83" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="XwV-hy-YiP">
<rect key="frame" x="179" y="65" width="83" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="79" id="dBz-ZQ-BF1"/>
<constraint firstAttribute="height" constant="21" id="y8c-hZ-MtI"/>
@ -199,8 +199,8 @@
<color key="fillColor" white="0.0" alpha="0.0" colorSpace="calibratedWhite"/>
<font key="titleFont" metaFont="system"/>
</box>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="LC1-Sx-uav">
<rect key="frame" x="130" y="44" width="179" height="18"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="LC1-Sx-uav">
<rect key="frame" x="130" y="41" width="179" height="18"/>
<constraints>
<constraint firstAttribute="width" constant="175" id="Pdc-78-vzv"/>
<constraint firstAttribute="height" constant="18" id="hsh-i8-ULY"/>
@ -214,8 +214,8 @@
<binding destination="-2" name="enabled" keyPath="self.enableOptions" id="3ho-kS-zgV"/>
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="JR8-v7-K0w">
<rect key="frame" x="179" y="16" width="83" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="JR8-v7-K0w">
<rect key="frame" x="179" y="13" width="83" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="Xof-eY-ZUl"/>
<constraint firstAttribute="width" constant="79" id="msH-Xd-mrp"/>
@ -264,7 +264,7 @@
<visualEffectView wantsLayer="YES" appearanceType="vibrantLight" alphaValue="0.90000000000000002" blendingMode="withinWindow" state="followsWindowActiveState" translatesAutoresizingMaskIntoConstraints="NO" id="kHi-mx-HdE">
<rect key="frame" x="0.0" y="0.0" width="439" height="195"/>
<subviews>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="WDP-d4-eNj">
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="320" translatesAutoresizingMaskIntoConstraints="NO" id="WDP-d4-eNj">
<rect key="frame" x="57" y="85" width="324" height="39"/>
<constraints>
<constraint firstAttribute="width" constant="320" id="3wp-Z6-TrB"/>

70
Clocker/Appearance Tab/zh-Hant.lproj/CLAppearanceView.xib

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="9531" systemVersion="15E65" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
<document type="com.apple.InterfaceBuilder3.Cocoa.XIB" version="3.0" toolsVersion="10117" systemVersion="15F34" targetRuntime="MacOSX.Cocoa" propertyAccessControl="none" useAutolayout="YES">
<dependencies>
<plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="9531"/>
<plugIn identifier="com.apple.InterfaceBuilder.CocoaPlugin" version="10117"/>
</dependencies>
<objects>
<customObject id="-2" userLabel="File's Owner" customClass="CLAppearanceViewController">
@ -88,10 +88,10 @@
<binding destination="WGI-5h-l6M" name="selectedIndex" keyPath="values.is24HourFormatSelected" id="UsS-ER-9M9"/>
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="3d9-qg-dNb">
<rect key="frame" x="130" y="173" width="179" height="18"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="3d9-qg-dNb">
<rect key="frame" x="130" y="167" width="179" height="22"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="MdL-Dh-02n"/>
<constraint firstAttribute="height" constant="22" id="MdL-Dh-02n"/>
<constraint firstAttribute="width" constant="175" id="hHO-Wa-gmc"/>
</constraints>
<textFieldCell key="cell" scrollable="YES" lineBreakMode="clipping" sendsActionOnEndEditing="YES" alignment="center" title="Menubar Display Options" id="ZP5-1i-Bm8">
@ -100,8 +100,8 @@
<color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
</textFieldCell>
</textField>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="pqa-Qg-U8Y">
<rect key="frame" x="130" y="145" width="179" height="19"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="pqa-Qg-U8Y">
<rect key="frame" x="130" y="138" width="179" height="20"/>
<constraints>
<constraint firstAttribute="width" constant="175" id="B2I-0j-0W0"/>
</constraints>
@ -114,8 +114,8 @@
<binding destination="-2" name="enabled" keyPath="self.enableOptions" id="wwV-Hq-RlT"/>
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="atA-2r-FXV">
<rect key="frame" x="178" y="117" width="84" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="atA-2r-FXV">
<rect key="frame" x="178" y="110" width="84" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="BqM-4F-6Ta"/>
<constraint firstAttribute="width" constant="80" id="ZeK-lO-tUa"/>
@ -132,8 +132,8 @@
<binding destination="WGI-5h-l6M" name="selectedIndex" keyPath="values.showDate" id="Qee-Dc-Piu"/>
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="kEn-QZ-niZ">
<rect key="frame" x="130" y="96" width="179" height="18"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="kEn-QZ-niZ">
<rect key="frame" x="130" y="89" width="179" height="18"/>
<constraints>
<constraint firstAttribute="height" constant="18" id="2fd-f6-8cD"/>
<constraint firstAttribute="width" constant="175" id="D0w-xz-gkw"/>
@ -147,8 +147,8 @@
<binding destination="-2" name="enabled" keyPath="self.enableOptions" id="56M-0X-vvP"/>
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="XwV-hy-YiP">
<rect key="frame" x="178" y="68" width="84" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="XwV-hy-YiP">
<rect key="frame" x="178" y="61" width="84" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="80" id="dBz-ZQ-BF1"/>
<constraint firstAttribute="height" constant="21" id="y8c-hZ-MtI"/>
@ -165,8 +165,8 @@
<binding destination="WGI-5h-l6M" name="selectedIndex" keyPath="values.showDay" id="AeO-a9-xU4"/>
</connections>
</segmentedControl>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="72r-oi-X0f">
<rect key="frame" x="180" y="310" width="79" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="72r-oi-X0f">
<rect key="frame" x="180" y="309" width="79" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="75" id="H8w-wg-vel"/>
</constraints>
@ -182,8 +182,8 @@
<binding destination="WGI-5h-l6M" name="selectedIndex" keyPath="values.displayFutureSlider" id="zRQ-mQ-qBp"/>
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="HTZ-1V-qZb">
<rect key="frame" x="158" y="341" width="124" height="19"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="HTZ-1V-qZb">
<rect key="frame" x="158" y="340" width="124" height="20"/>
<constraints>
<constraint firstAttribute="width" constant="120" id="1Lv-wC-hEM"/>
</constraints>
@ -193,8 +193,8 @@
<color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
</textFieldCell>
</textField>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="76h-05-go1">
<rect key="frame" x="158" y="285" width="124" height="19"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="76h-05-go1">
<rect key="frame" x="158" y="283" width="124" height="20"/>
<constraints>
<constraint firstAttribute="width" constant="120" id="Odw-mb-nT5"/>
</constraints>
@ -204,14 +204,14 @@
<color key="backgroundColor" name="controlColor" catalog="System" colorSpace="catalog"/>
</textFieldCell>
</textField>
<box verticalHuggingPriority="750" misplaced="YES" title="Box" boxType="separator" titlePosition="noTitle" translatesAutoresizingMaskIntoConstraints="NO" id="MHe-dB-GZr">
<rect key="frame" x="0.0" y="193" width="439" height="5"/>
<box verticalHuggingPriority="750" title="Box" boxType="separator" titlePosition="noTitle" translatesAutoresizingMaskIntoConstraints="NO" id="MHe-dB-GZr">
<rect key="frame" x="0.0" y="191" width="439" height="5"/>
<color key="borderColor" white="0.0" alpha="0.41999999999999998" colorSpace="calibratedWhite"/>
<color key="fillColor" white="0.0" alpha="0.0" colorSpace="calibratedWhite"/>
<font key="titleFont" metaFont="system"/>
</box>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="LC1-Sx-uav">
<rect key="frame" x="130" y="44" width="179" height="18"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="175" translatesAutoresizingMaskIntoConstraints="NO" id="LC1-Sx-uav">
<rect key="frame" x="130" y="37" width="179" height="18"/>
<constraints>
<constraint firstAttribute="width" constant="175" id="Pdc-78-vzv"/>
<constraint firstAttribute="height" constant="18" id="hsh-i8-ULY"/>
@ -225,8 +225,8 @@
<binding destination="-2" name="enabled" keyPath="self.enableOptions" id="3ho-kS-zgV"/>
</connections>
</textField>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="JR8-v7-K0w">
<rect key="frame" x="178" y="16" width="84" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="JR8-v7-K0w">
<rect key="frame" x="178" y="9" width="84" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="Xof-eY-ZUl"/>
<constraint firstAttribute="width" constant="80" id="msH-Xd-mrp"/>
@ -272,11 +272,11 @@
<binding destination="WGI-5h-l6M" name="selectedIndex" keyPath="values.relativeDate" id="eKo-sG-1eE"/>
</connections>
</segmentedControl>
<visualEffectView wantsLayer="YES" appearanceType="vibrantLight" misplaced="YES" alphaValue="0.90000000000000002" blendingMode="withinWindow" state="followsWindowActiveState" translatesAutoresizingMaskIntoConstraints="NO" id="kHi-mx-HdE">
<rect key="frame" x="0.0" y="0.0" width="439" height="195"/>
<visualEffectView wantsLayer="YES" appearanceType="vibrantLight" alphaValue="0.90000000000000002" blendingMode="withinWindow" state="followsWindowActiveState" translatesAutoresizingMaskIntoConstraints="NO" id="kHi-mx-HdE">
<rect key="frame" x="0.0" y="0.0" width="439" height="193"/>
<subviews>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="WDP-d4-eNj">
<rect key="frame" x="57" y="78" width="324" height="39"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="320" translatesAutoresizingMaskIntoConstraints="NO" id="WDP-d4-eNj">
<rect key="frame" x="57" y="77" width="324" height="39"/>
<constraints>
<constraint firstAttribute="width" constant="320" id="3wp-Z6-TrB"/>
<constraint firstAttribute="height" constant="39" id="IyN-y5-6JP"/>
@ -302,8 +302,8 @@
<binding destination="-2" name="hidden" keyPath="self.enableOptions" id="4El-Z9-rMM"/>
</connections>
</visualEffectView>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="SbG-Qh-ziy">
<rect key="frame" x="53" y="254" width="334" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="SbG-Qh-ziy">
<rect key="frame" x="53" y="252" width="334" height="24"/>
<constraints>
<constraint firstAttribute="width" constant="330" id="T2D-fB-93g"/>
</constraints>
@ -319,8 +319,8 @@
<binding destination="WGI-5h-l6M" name="selectedIndex" keyPath="values.displayAppAsForegroundApp" id="Fuh-BG-SYM"/>
</connections>
</segmentedControl>
<segmentedControl verticalHuggingPriority="750" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="y2b-z8-bYw">
<rect key="frame" x="180" y="202" width="79" height="24"/>
<segmentedControl verticalHuggingPriority="750" translatesAutoresizingMaskIntoConstraints="NO" id="y2b-z8-bYw">
<rect key="frame" x="180" y="200" width="79" height="24"/>
<constraints>
<constraint firstAttribute="height" constant="21" id="HEQ-jX-Sul"/>
<constraint firstAttribute="width" constant="75" id="ceX-9z-Lmv"/>
@ -336,8 +336,8 @@
<binding destination="WGI-5h-l6M" name="selectedIndex" keyPath="values.showSunriseSetTime" id="frb-I8-CTN"/>
</connections>
</segmentedControl>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" misplaced="YES" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="Huo-FT-51u">
<rect key="frame" x="138" y="229" width="164" height="19"/>
<textField horizontalHuggingPriority="251" verticalHuggingPriority="750" preferredMaxLayoutWidth="120" translatesAutoresizingMaskIntoConstraints="NO" id="Huo-FT-51u">
<rect key="frame" x="138" y="227" width="164" height="19"/>
<constraints>
<constraint firstAttribute="height" constant="19" id="Aw5-iZ-nfi"/>
<constraint firstAttribute="width" constant="160" id="l2J-qp-re8"/>

34
Clocker/ApplicationDelegate.m

@ -33,9 +33,6 @@
#import "iVersion.h"
#import "CLOnboardingWindowController.h"
#define helperAppBundleIdentifier @"com.abhishek.Clocker-Helper" // change as appropriate to help app bundle identifier
#define terminateNotification @"TERMINATEHELPER" // can be basically any string
@implementation ApplicationDelegate
@synthesize panelController = _panelController;
@ -78,37 +75,17 @@ void *kContextActivePanel = &kContextActivePanel;
- (void)applicationDidFinishLaunching:(NSNotification *)notification
{
BOOL startedAtLogin = NO;
NSNumber *opened = [[NSUserDefaults standardUserDefaults] objectForKey:@"noOfTimes"];
if (opened == nil)
{
[[NSUserDefaults standardUserDefaults] setObject:[NSMutableArray array]
forKey:CLDefaultPreferenceKey];
NSInteger noOfTimes = opened.integerValue + 1;
NSNumber *noOfTime = [NSNumber numberWithInteger:noOfTimes];
NSNumber *noOfTime = @(noOfTimes);
[[NSUserDefaults standardUserDefaults] setObject:noOfTime forKey:@"noOfTimes"];;
}
NSArray *apps = [[NSWorkspace sharedWorkspace] runningApplications];
for (NSRunningApplication *app in apps)
{
if ([app.bundleIdentifier isEqualToString:helperAppBundleIdentifier])
{
startedAtLogin = YES;
break;
}
}
if (startedAtLogin)
{
[[NSDistributedNotificationCenter defaultCenter]
postNotificationName:terminateNotification
object:[[NSBundle mainBundle] bundleIdentifier]];
}
// Install icon into the menu bar
self.menubarController = [MenubarController new];
@ -142,7 +119,7 @@ void *kContextActivePanel = &kContextActivePanel;
NSNumber *displayFutureSlider = [[NSUserDefaults standardUserDefaults] objectForKey:CLDisplayFutureSliderKey];
if (displayFutureSlider == nil)
{
[[NSUserDefaults standardUserDefaults] setObject:[NSNumber numberWithInteger:0] forKey:CLDisplayFutureSliderKey];
[[NSUserDefaults standardUserDefaults] setObject:@0 forKey:CLDisplayFutureSliderKey];
}
NSNumber *defaultTimeFormat = [[NSUserDefaults standardUserDefaults] objectForKey:CL24hourFormatSelectedKey];
@ -174,11 +151,6 @@ void *kContextActivePanel = &kContextActivePanel;
[[NSUserDefaults standardUserDefaults] setObject:@0 forKey:CLShowPlaceInMenu];
}
NSNumber *showAppInForeground = [[NSUserDefaults standardUserDefaults] objectForKey:CLShowAppInForeground];
if (showAppInForeground == nil) {
[[NSUserDefaults standardUserDefaults] setObject:@0 forKey:CLShowAppInForeground];
}
NSNumber *startClockerAtLogin = [[NSUserDefaults standardUserDefaults] objectForKey:CLStartAtLogin];
if (startClockerAtLogin == nil) {
[[NSUserDefaults standardUserDefaults] setObject:@0 forKey:CLStartAtLogin];
@ -199,7 +171,7 @@ void *kContextActivePanel = &kContextActivePanel;
{
self.floatingWindow = [CLFloatingWindowController sharedFloatingWindow];
[self.floatingWindow showWindow:nil];
[self.floatingWindow.mainTableview reloadData];
[self.floatingWindow updateTableContent];
[self.floatingWindow startWindowTimer];
[NSApp activateIgnoringOtherApps:YES];

33
Clocker/BackgroundView.m

@ -50,7 +50,7 @@
- (void)drawRect:(NSRect)dirtyRect
{
NSRect contentRect = NSInsetRect([self bounds], LINE_THICKNESS, LINE_THICKNESS);
NSRect contentRect = NSInsetRect(self.bounds, LINE_THICKNESS, LINE_THICKNESS);
NSBezierPath *path = [NSBezierPath bezierPath];
[path moveToPoint:NSMakePoint(_arrowX, NSMaxY(contentRect))];
@ -90,7 +90,7 @@
[NSGraphicsContext saveGraphicsState];
NSBezierPath *clip = [NSBezierPath bezierPathWithRect:[self bounds]];
NSBezierPath *clip = [NSBezierPath bezierPathWithRect:self.bounds];
[clip appendBezierPath:path];
[clip addClip];
@ -105,21 +105,36 @@
{
[super mouseEntered:theEvent];
ApplicationDelegate *delegate = (ApplicationDelegate*)[NSApplication sharedApplication].delegate;
PanelController *controller = delegate.panelController;
[controller showOptions:YES];
[self shouldHideButtons:YES];
}
-(void)mouseExited:(NSEvent *)theEvent
{
[super mouseExited:theEvent];
[self shouldHideButtons:NO];
}
- (void)shouldHideButtons:(BOOL)shouldHide
{
PanelController *controller = [self getPanelControllerInstance];
[controller showOptions:shouldHide];
if (!shouldHide){
[controller removeContextHelpForSlider];
}
}
- (PanelController *)getPanelControllerInstance
{
ApplicationDelegate *delegate = (ApplicationDelegate*) [NSApplication sharedApplication].delegate;
PanelController *controller = delegate.panelController;
[controller showOptions:NO];
[controller removeContextHelpForSlider];
return controller;
}
-(void)updateTrackingAreas
@ -129,7 +144,7 @@
}
int opts = (NSTrackingMouseEnteredAndExited | NSTrackingActiveAlways);
self.trackingArea = [ [NSTrackingArea alloc] initWithRect:[self bounds]
self.trackingArea = [ [NSTrackingArea alloc] initWithRect:self.bounds
options:opts
owner:self
userInfo:nil];

4
Clocker/CLMainWindowController.m

@ -18,9 +18,9 @@
[super windowDidLoad];
CALayer *viewLayer = [CALayer layer];
[viewLayer setBackgroundColor:CGColorCreateGenericRGB(255.0, 255.0, 255.0, 0.8)]; //RGB plus Alpha Channel
viewLayer.backgroundColor = CGColorCreateGenericRGB(255.0, 255.0, 255.0, 0.8); //RGB plus Alpha Channel
[self.window.contentView setWantsLayer:YES]; // view's backing store is using a Core Animation Layer
[self.window.contentView setLayer:viewLayer];
(self.window.contentView).layer = viewLayer;
self.window.titlebarAppearsTransparent = YES;

8
Clocker/CLOneWindow/CLOneWindowController.m

@ -67,10 +67,10 @@ static CLOneWindowController *sharedWindow = nil;
- (void)setWindowWithContentView:(NSView *)contentView
{
[self.window setContentSize:contentView.frame.size];
[self.window setContentView:contentView];
CGFloat xPos = NSWidth([[self.window screen] frame])/2 - NSWidth([self.window frame])/2;
CGFloat yPos = NSHeight([[self.window screen] frame])/2 - NSHeight([self.window frame])/2;
[self.window setFrame:NSMakeRect(xPos, yPos, NSWidth([self.window frame]), NSHeight([self.window frame])) display:YES];
(self.window).contentView = contentView;
CGFloat xPos = NSWidth((self.window).screen.frame)/2 - NSWidth((self.window).frame)/2;
CGFloat yPos = NSHeight((self.window).screen.frame)/2 - NSHeight((self.window).frame)/2;
[self.window setFrame:NSMakeRect(xPos, yPos, NSWidth((self.window).frame), NSHeight((self.window).frame)) display:YES];
}
- (IBAction)openAboutUsView:(id)sender

1
Clocker/CLParentPanelController.h

@ -29,5 +29,6 @@
- (void)removeContextHelpForSlider;
- (void)updatePanelColor;
- (void)openPreferenceWindowWithValue:(BOOL)value;
- (void)updateTableContent;
@end

12
Clocker/CLParentPanelController.m

@ -59,7 +59,7 @@
/*No Future Slider when no timezones duh*/
self.futureSlider.hidden = [displayFutureSlider isEqualToNumber:[NSNumber numberWithInteger:1]] || (self.defaultPreferences.count == 0) ? YES : NO;
self.futureSlider.hidden = [displayFutureSlider isEqualToNumber:@1] || (self.defaultPreferences.count == 0) ? YES : NO;
[self updatePanelColor];
}
@ -69,12 +69,12 @@
NSNumber *theme = [[NSUserDefaults standardUserDefaults] objectForKey:CLThemeKey];
if (theme.integerValue == 1)
{
[self.mainTableview setBackgroundColor:[NSColor blackColor]];
(self.mainTableview).backgroundColor = [NSColor blackColor];
self.window.alphaValue = 0.90;
}
else
{
[self.mainTableview setBackgroundColor:[NSColor whiteColor]];
(self.mainTableview).backgroundColor = [NSColor whiteColor];
self.window.alphaValue = 1;
}
}
@ -168,8 +168,6 @@
CGRect oldFrame = CGRectMake(self.oneWindow.window.frame.origin.x, 730,self.oneWindow.window.frame.size.width, self.oneWindow.window.frame.size.height);
[self performBoundsAnimationWithOldRect:oldFrame andNewRect:originalFrame andShouldOpenTimezonePanel:value];
[NSApp activateIgnoringOtherApps:YES];
@ -195,6 +193,10 @@
};
}
- (void)updateTableContent
{
[self.mainTableview reloadData];
}
@end

13
Clocker/CLParentViewController.h

@ -0,0 +1,13 @@
//
// CLParentViewController.h
// Clocker
//
// Created by Abhishek Banthia on 7/18/16.
//
//
#import <Cocoa/Cocoa.h>
@interface CLParentViewController : NSViewController
@end

27
Clocker/CLParentViewController.m

@ -0,0 +1,27 @@
//
// CLParentViewController.m
// Clocker
//
// Created by Abhishek Banthia on 7/18/16.
//
//
#import "CLParentViewController.h"
@interface CLParentViewController ()
@end
@implementation CLParentViewController
- (void)viewDidLoad {
[super viewDidLoad];
CALayer *viewLayer = [CALayer layer];
viewLayer.backgroundColor = CGColorCreateGenericRGB(255.0, 255.0, 255.0, 0.8); //RGB plus Alpha Channel
[self.view setWantsLayer:YES];
(self.view).layer = viewLayer;
}
@end

41
Clocker/CLRatingCellView.m

@ -10,7 +10,6 @@
#import "iRate.h"
#import <QuartzCore/QuartzCore.h>
#import "PanelController.h"
#import "CLAppFeedbackWindowController.h"
@implementation CLRatingCellView
@ -41,7 +40,7 @@ NSString *const CLYesWithExclamation = @"Yes!";
else
{
//Make the row disappear and call remind later
PanelController *panelRef = [[[NSApplication sharedApplication] mainWindow] windowController];
PanelController *panelRef = [PanelController getPanelControllerInstance];
panelRef.showReviewCell = NO;
[panelRef updateDefaultPreferences];
[panelRef closePanel];
@ -75,7 +74,7 @@ NSString *const CLYesWithExclamation = @"Yes!";
- (void)updateMainTableView
{
PanelController *panelRef = [[[NSApplication sharedApplication] mainWindow] windowController];
PanelController *panelRef = [PanelController getPanelControllerInstance];
panelRef.showReviewCell = NO;
[panelRef updateDefaultPreferences];
}
@ -85,37 +84,37 @@ NSString *const CLYesWithExclamation = @"Yes!";
withLeftButtonTitle:(NSString *)leftTitle
andRightButtonTitle:(NSString *)rightTitle
{
if ([[textfield stringValue] isEqual: aString])
if ([textfield.stringValue isEqual: aString])
{
return;
}
[NSAnimationContext runAnimationGroup:^(NSAnimationContext *context) {
[context setDuration: 1.0];
[context setTimingFunction: [CAMediaTimingFunction functionWithName: kCAMediaTimingFunctionEaseOut]];
[self.imageView.animator setAlphaValue:0.0];
[self.leftButton.animator setAlphaValue:0.0];
[self.rightButton.animator setAlphaValue:0.0];
[textfield.animator setAlphaValue: 0.0];
context.duration = 1.0;
context.timingFunction = [CAMediaTimingFunction functionWithName: kCAMediaTimingFunctionEaseOut];
(self.imageView.animator).alphaValue = 0.0;
(self.leftButton.animator).alphaValue = 0.0;
(self.rightButton.animator).alphaValue = 0.0;
(textfield.animator).alphaValue = 0.0;
}
completionHandler:^{
[textfield setStringValue: aString];
textfield.stringValue = aString;
[NSAnimationContext runAnimationGroup:^(NSAnimationContext *context) {
[context setDuration: 1.0];
[context setTimingFunction: [CAMediaTimingFunction functionWithName: kCAMediaTimingFunctionEaseIn]];
[self.imageView.animator setAlphaValue: 1.0];
[textfield.animator setAlphaValue: 1.0];
[self.leftButton.animator setAlphaValue:1.0];
[self.rightButton.animator setAlphaValue:1.0];
context.duration = 1.0;
context.timingFunction = [CAMediaTimingFunction functionWithName: kCAMediaTimingFunctionEaseIn];
(self.imageView.animator).alphaValue = 1.0;
(textfield.animator).alphaValue = 1.0;
(self.leftButton.animator).alphaValue = 1.0;
(self.rightButton.animator).alphaValue = 1.0;
if ([self.leftButton.title isEqualToString:@"Not Really"]) {
[self.leftButton.animator setTitle:CLNoThanksTitle];
(self.leftButton.animator).title = CLNoThanksTitle;
}
if ([self.rightButton.title isEqualToString:CLYesWithExclamation]) {
[self.rightButton.animator setTitle:@"Yes, sure"];
(self.rightButton.animator).title = @"Yes, sure";
}
[self.leftButton.animator setTitle:leftTitle];
[self.rightButton.animator setTitle:rightTitle];
(self.leftButton.animator).title = leftTitle;
(self.rightButton.animator).title = rightTitle;
} completionHandler: ^{
}];

16
Clocker/CLScaleUpButton.h

@ -1,16 +0,0 @@
//
// CLScaleUpButton.h
// Clocker
//
// Created by Abhishek Banthia on 5/9/16.
//
//
#import <Cocoa/Cocoa.h>
@interface CLScaleUpButton : NSButton
@property (strong, nonatomic) NSTrackingArea *trackingArea;
@property (nonatomic, strong) IBInspectable NSColor *textColor;
@end

74
Clocker/CLScaleUpButton.m

@ -1,74 +0,0 @@
//
// CLScaleUpButton.m
// Clocker
//
// Created by Abhishek Banthia on 5/9/16.
//
//
#import "CLScaleUpButton.h"
#import <pop/POP.h>
@implementation CLScaleUpButton
- (void)drawRect:(NSRect)dirtyRect
{
[super drawRect:dirtyRect];
NSButtonCell *cell = [self cell];
cell.backgroundColor = [NSColor clearColor];
// Drawing code here.
}
- (void)awakeFromNib
{
if (self.textColor)
{
NSMutableParagraphStyle *style = [[NSMutableParagraphStyle alloc] init];
[style setAlignment:NSCenterTextAlignment];
NSDictionary *attrsDictionary = [NSDictionary dictionaryWithObjectsAndKeys:
self.textColor, NSForegroundColorAttributeName,
self.font, NSFontAttributeName,
style, NSParagraphStyleAttributeName, nil];
NSAttributedString *attrString = [[NSAttributedString alloc]initWithString:self.title attributes:attrsDictionary];
[self setAttributedTitle:attrString];
}
[self addScaleAnimation];
}
-(void)mouseEntered:(NSEvent *)theEvent
{
[super mouseEntered:theEvent];
[self addScaleAnimation];
}
- (void) addScaleAnimation
{
POPSpringAnimation *scale = [POPSpringAnimation animationWithPropertyNamed:kPOPLayerScaleXY];
scale.velocity = [NSValue valueWithCGPoint:CGPointMake(1, 1)];
scale.springBounciness = 20.f;
[self.layer pop_addAnimation:scale forKey:@"scale"];
}
-(void)updateTrackingAreas
{
if(self.trackingArea != nil) {
[self removeTrackingArea:self.trackingArea];
}
int opts = (NSTrackingMouseEnteredAndExited | NSTrackingActiveAlways);
self.trackingArea = [ [NSTrackingArea alloc] initWithRect:[self bounds]
options:opts
owner:self
userInfo:nil];
[self addTrackingArea:self.trackingArea];
}
@end

4
Clocker/Clocker-Info.plist

@ -13,11 +13,11 @@
<key>CFBundlePackageType</key>
<string>APPL</string>
<key>CFBundleShortVersionString</key>
<string>1.3</string>
<string>1.4</string>
<key>CFBundleSignature</key>
<string>????</string>
<key>CFBundleVersion</key>
<string>22</string>
<string>24</string>
<key>Fabric</key>
<dict>
<key>APIKey</key>

36
Clocker/ColoredButton.h

@ -1,36 +0,0 @@
//
// ColoredButton.h
// Clocker
//
// Created by Abhishek Banthia on 11/4/15.
// Copyright (c) 2015 Abhishek Banthia All rights reserved.
//
// Copyright (c) 2015, Abhishek Banthia
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation and/or
// other materials provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
// IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
// INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
// HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
// OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#import <Cocoa/Cocoa.h>
@interface ColoredButton : NSButton
@end

61
Clocker/ColoredButton.m

@ -1,61 +0,0 @@
//
// ColoredButton.m
// Clocker
//
// Created by Abhishek Banthia on 11/4/15.
// Copyright (c) 2015 Abhishek Banthia All rights reserved.
//
// Copyright (c) 2015, Abhishek Banthia
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
// Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
//
// Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation and/or
// other materials provided with the distribution.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
// IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
// INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
// HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
// OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
// EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#import "ColoredButton.h"
@implementation ColoredButton
- (void)setButtonTitleFor:(NSButton*)button toString:(NSString*)title withColor:(NSColor*)color
{
NSFont *font = [NSFont fontWithName:@"HelveticaNeue-Light" size:12.0];
NSDictionary *attrsDictionary = [NSDictionary dictionaryWithObjectsAndKeys:color, NSForegroundColorAttributeName, font,NSFontAttributeName, nil];
NSMutableAttributedString *attrString = [[NSMutableAttributedString alloc]initWithString:title attributes:attrsDictionary];
[button setAttributedTitle:attrString];
}
-(void)awakeFromNib
{
NSString *title = self.title;
NSColor *color = [NSColor blackColor];
self.imagePosition = NSImageLeft;
[self setButtonTitleFor:self toString:title withColor:color];
}
@end

4
Clocker/Custom Slider/CLCustomSliderCell.m

@ -19,10 +19,10 @@
CGFloat barRadius = 2.5;
// Knob position depending on control min/max value and current control value.
CGFloat value = ([self doubleValue] - [self minValue]) / ([self maxValue] - [self minValue]);
CGFloat value = (self.doubleValue - self.minValue) / (self.maxValue - self.minValue);
// Final Left Part Width
CGFloat finalWidth = value * ([[self controlView] frame].size.width - 8);
CGFloat finalWidth = value * (self.controlView.frame.size.width - 8);
// Left Part Rect
NSRect leftRect = rect;

5
Clocker/Custom Table Cell Views/CLTimezoneCellView.h

@ -17,9 +17,8 @@
@property (weak) IBOutlet NSImageView *sunriseSetImage;
@property (nonatomic, assign) NSInteger rowNumber;
- (void)updateTextColorWithColor:(NSColor *)color andCell:(CLTimezoneCellView*)cell;
- (void)setUpAutoLayoutWithCell;
- (void)setTextColor:(NSColor *)color;
- (void)setUpLayout;
@end

76
Clocker/Custom Table Cell Views/CLTimezoneCellView.m

@ -24,36 +24,30 @@
- (IBAction)labelDidChange:(NSTextField *)sender
{
NSTextField *customLabelCell = (NSTextField*) sender;
__block PanelController *panelController;
__block CLFloatingWindowController *floatingWindow;
PanelController *panelController;
CLFloatingWindowController *floatingWindow;
NSNumber *displayMode = [[NSUserDefaults standardUserDefaults] objectForKey:CLShowAppInForeground];
[[[NSApplication sharedApplication] windows] enumerateObjectsUsingBlock:^(NSWindow * _Nonnull window, NSUInteger idx, BOOL * _Nonnull stop)
if (displayMode.integerValue == 0)
{
if (displayMode.integerValue == 0)
{
if ([window.windowController isMemberOfClass:[PanelController class]])
{
panelController = window.windowController;
}
}
else if (displayMode.integerValue == 1)
{
if ([window.windowController isMemberOfClass:[CLFloatingWindowController class]])
{
floatingWindow = window.windowController;
}
}
}];
panelController = [PanelController getPanelControllerInstance];
}
else if (displayMode.integerValue == 1)
{
floatingWindow = [CLFloatingWindowController sharedFloatingWindow];
}
NSString *originalValue = customLabelCell.stringValue;
NSString *customLabelValue = [originalValue stringByTrimmingCharactersInSet:
[NSCharacterSet whitespaceCharacterSet]];
if ([[sender superview] isKindOfClass:[self class]])
if ([sender.superview isKindOfClass:[self class]])
{
CLTimezoneCellView *cellView = (CLTimezoneCellView *)[sender superview];
CLTimezoneCellView *cellView = (CLTimezoneCellView *)sender.superview;
/*
@ -106,17 +100,17 @@
if (displayMode.integerValue == 0)
{
[panelController.defaultPreferences replaceObjectAtIndex:cellView.rowNumber withObject:newObject];
(panelController.defaultPreferences)[cellView.rowNumber] = newObject;
[[NSUserDefaults standardUserDefaults] setObject:panelController.defaultPreferences forKey:CLDefaultPreferenceKey];
[panelController updateDefaultPreferences];
[panelController.mainTableview reloadData];
[panelController updateTableContent];
}
else if(displayMode.integerValue == 1)
{
[floatingWindow.defaultPreferences replaceObjectAtIndex:cellView.rowNumber withObject:newObject];
(floatingWindow.defaultPreferences)[cellView.rowNumber] = newObject;
[[NSUserDefaults standardUserDefaults] setObject:floatingWindow.defaultPreferences forKey:CLDefaultPreferenceKey];
[floatingWindow updateDefaultPreferences];
[floatingWindow.mainTableview reloadData];
[floatingWindow updateTableContent];
}
[[NSNotificationCenter defaultCenter]
@ -130,15 +124,15 @@
[self.window endEditingFor:nil];
}
- (void)updateTextColorWithColor:(NSColor *)color andCell:(CLTimezoneCellView*)cell
- (void)setTextColor:(NSColor *)color
{
cell.relativeDate.textColor = color;
cell.customName.textColor = color;
cell.time.textColor = color;
cell.sunriseSetTime.textColor = color;
self.relativeDate.textColor = color;
self.customName.textColor = color;
self.time.textColor = color;
self.sunriseSetTime.textColor = color;
}
- (void)setUpAutoLayoutWithCell
- (void)setUpLayout
{
CGFloat width = [self.relativeDate.stringValue
sizeWithAttributes: @{NSFontAttributeName:self.relativeDate.font}].width;
@ -162,6 +156,28 @@
[self.relativeDate setNeedsUpdateConstraints:YES];
[self.sunriseSetTime setNeedsUpdateConstraints:YES];
[self setUpTheme];
}
- (void)setUpTheme
{
NSNumber *theme = [[NSUserDefaults standardUserDefaults] objectForKey:CLThemeKey];
if (theme.integerValue == 1)
{
[self setTextColor:[NSColor whiteColor]];
[self.customName setDrawsBackground:YES];
(self.customName).backgroundColor = [NSColor blackColor];
}
else
{
[self setTextColor:[NSColor blackColor]];
[self.customName setDrawsBackground:NO];
}
}
- (void)controlTextDidEndEditing:(NSNotification *)obj

20
Clocker/Date Tools/DateTools-master/DateTools/DTTimePeriod.h

@ -83,15 +83,15 @@ typedef NS_ENUM(NSUInteger, DTTimePeriodAnchor) {
+(instancetype)timePeriodWithAllTime;
#pragma mark - Time Period Information
-(BOOL)hasStartDate;
-(BOOL)hasEndDate;
-(BOOL)isMoment;
-(double)durationInYears;
-(double)durationInWeeks;
-(double)durationInDays;
-(double)durationInHours;
-(double)durationInMinutes;
-(double)durationInSeconds;
@property (NS_NONATOMIC_IOSONLY, readonly) BOOL hasStartDate;
@property (NS_NONATOMIC_IOSONLY, readonly) BOOL hasEndDate;
@property (NS_NONATOMIC_IOSONLY, getter=isMoment, readonly) BOOL moment;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInYears;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInWeeks;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInDays;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInHours;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInMinutes;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInSeconds;
#pragma mark - Time Period Relationship
-(BOOL)isEqualToPeriod:(DTTimePeriod *)period;
@ -119,5 +119,5 @@ typedef NS_ENUM(NSUInteger, DTTimePeriodAnchor) {
-(void)shortenWithAnchorDate:(DTTimePeriodAnchor)anchor size:(DTTimePeriodSize)size amount:(NSInteger)amount;
#pragma mark - Helper Methods
-(DTTimePeriod *)copy;
@property (NS_NONATOMIC_IOSONLY, readonly, strong) DTTimePeriod *copy;
@end

2
Clocker/Date Tools/DateTools-master/DateTools/DTTimePeriodCollection.h

@ -49,7 +49,7 @@
-(BOOL)isEqualToCollection:(DTTimePeriodCollection *)collection considerOrder:(BOOL)considerOrder;
#pragma mark - Helper Methods
-(DTTimePeriodCollection *)copy;
@property (NS_NONATOMIC_IOSONLY, readonly, strong) DTTimePeriodCollection *copy;
#pragma mark - Updates
-(void)updateVariables;

14
Clocker/Date Tools/DateTools-master/DateTools/DTTimePeriodGroup.h

@ -38,15 +38,15 @@
- (void)setObject:(id)obj atIndexedSubscript:(NSUInteger)index; //setter
#pragma mark - Group Info
-(double)durationInYears;
-(double)durationInWeeks;
-(double)durationInDays;
-(double)durationInHours;
-(double)durationInMinutes;
-(double)durationInSeconds;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInYears;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInWeeks;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInDays;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInHours;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInMinutes;
@property (NS_NONATOMIC_IOSONLY, readonly) double durationInSeconds;
-(NSDate *)StartDate;
-(NSDate *)EndDate;
-(NSInteger)count;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger count;
#pragma mark - Chain Time Manipulation
-(void)shiftEarlierWithSize:(DTTimePeriodSize)size;

2
Clocker/Date Tools/DateTools-master/DateTools/DTTimePeriodGroup.m

@ -29,7 +29,7 @@
@implementation DTTimePeriodGroup
-(id) init
-(instancetype) init
{
if (self = [super init]) {
periods = [[NSMutableArray alloc] init];

74
Clocker/Date Tools/DateTools-master/DateTools/NSDate+DateTools.h

@ -33,8 +33,8 @@ NSLocalizedStringFromTableInBundle(key, @"DateTools", [NSBundle bundleWithPath:[
#pragma mark - Time Ago
+ (NSString*)timeAgoSinceDate:(NSDate*)date;
+ (NSString*)shortTimeAgoSinceDate:(NSDate*)date;
- (NSString*)timeAgoSinceNow;
- (NSString *)shortTimeAgoSinceNow;
@property (NS_NONATOMIC_IOSONLY, readonly, copy) NSString *timeAgoSinceNow;
@property (NS_NONATOMIC_IOSONLY, readonly, copy) NSString *shortTimeAgoSinceNow;
- (NSString *)timeAgoSinceDate:(NSDate *)date;
- (NSString *)timeAgoSinceDate:(NSDate *)date numericDates:(BOOL)useNumericDates;
- (NSString *)timeAgoSinceDate:(NSDate *)date numericDates:(BOOL)useNumericDates numericTimes:(BOOL)useNumericTimes;
@ -42,27 +42,27 @@ NSLocalizedStringFromTableInBundle(key, @"DateTools", [NSBundle bundleWithPath:[
#pragma mark - Date Components Without Calendar
- (NSInteger)era;
- (NSInteger)year;
- (NSInteger)month;
- (NSInteger)day;
- (NSInteger)hour;
- (NSInteger)minute;
- (NSInteger)second;
- (NSInteger)weekday;
- (NSInteger)weekdayOrdinal;
- (NSInteger)quarter;
- (NSInteger)weekOfMonth;
- (NSInteger)weekOfYear;
- (NSInteger)yearForWeekOfYear;
- (NSInteger)daysInMonth;
- (NSInteger)dayOfYear;
-(NSInteger)daysInYear;
-(BOOL)isInLeapYear;
- (BOOL)isToday;
- (BOOL)isTomorrow;
-(BOOL)isYesterday;
- (BOOL)isWeekend;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger era;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger year;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger month;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger day;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger hour;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger minute;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger second;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger weekday;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger weekdayOrdinal;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger quarter;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger weekOfMonth;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger weekOfYear;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger yearForWeekOfYear;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger daysInMonth;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger dayOfYear;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger daysInYear;
@property (NS_NONATOMIC_IOSONLY, getter=isInLeapYear, readonly) BOOL inLeapYear;
@property (NS_NONATOMIC_IOSONLY, getter=isToday, readonly) BOOL today;
@property (NS_NONATOMIC_IOSONLY, getter=isTomorrow, readonly) BOOL tomorrow;
@property (NS_NONATOMIC_IOSONLY, getter=isYesterday, readonly) BOOL yesterday;
@property (NS_NONATOMIC_IOSONLY, getter=isWeekend, readonly) BOOL weekend;
-(BOOL)isSameDay:(NSDate *)date;
+ (BOOL)isSameDay:(NSDate *)date asDate:(NSDate *)compareDate;
@ -125,21 +125,21 @@ NSLocalizedStringFromTableInBundle(key, @"DateTools", [NSBundle bundleWithPath:[
-(NSInteger)daysFrom:(NSDate *)date calendar:(NSCalendar *)calendar;
#pragma mark Time Until
-(NSInteger)yearsUntil;
-(NSInteger)monthsUntil;
-(NSInteger)weeksUntil;
-(NSInteger)daysUntil;
-(double)hoursUntil;
-(double)minutesUntil;
-(double)secondsUntil;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger yearsUntil;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger monthsUntil;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger weeksUntil;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger daysUntil;
@property (NS_NONATOMIC_IOSONLY, readonly) double hoursUntil;
@property (NS_NONATOMIC_IOSONLY, readonly) double minutesUntil;
@property (NS_NONATOMIC_IOSONLY, readonly) double secondsUntil;
#pragma mark Time Ago
-(NSInteger)yearsAgo;
-(NSInteger)monthsAgo;
-(NSInteger)weeksAgo;
-(NSInteger)daysAgo;
-(double)hoursAgo;
-(double)minutesAgo;
-(double)secondsAgo;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger yearsAgo;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger monthsAgo;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger weeksAgo;
@property (NS_NONATOMIC_IOSONLY, readonly) NSInteger daysAgo;
@property (NS_NONATOMIC_IOSONLY, readonly) double hoursAgo;
@property (NS_NONATOMIC_IOSONLY, readonly) double minutesAgo;
@property (NS_NONATOMIC_IOSONLY, readonly) double secondsAgo;
#pragma mark Earlier Than
-(NSInteger)yearsEarlierThan:(NSDate *)date;
-(NSInteger)monthsEarlierThan:(NSDate *)date;

70
Clocker/Date Tools/DateTools-master/DateTools/NSDate+DateTools.m

@ -267,7 +267,7 @@ static NSCalendar *implicitCalendar = nil;
}
- (NSString *)getLocaleFormatUnderscoresWithValue:(double)value{
NSString *localeCode = [[[NSBundle mainBundle] preferredLocalizations] objectAtIndex:0];
NSString *localeCode = [NSBundle mainBundle].preferredLocalizations[0];
// Russian (ru) and Ukrainian (uk)
if([localeCode isEqualToString:@"ru"] || [localeCode isEqualToString:@"uk"]) {
@ -502,7 +502,7 @@ static NSCalendar *implicitCalendar = nil;
NSRange weekdayRange = [calendar maximumRangeOfUnit:NSCalendarUnitWeekday];
NSDateComponents *components = [calendar components:NSCalendarUnitWeekday
fromDate:self];
NSUInteger weekdayOfSomeDate = [components weekday];
NSUInteger weekdayOfSomeDate = components.weekday;
BOOL result = NO;
@ -727,31 +727,31 @@ static NSCalendar *implicitCalendar = nil;
switch (component) {
case DTDateComponentEra:
return [dateComponents era];
return dateComponents.era;
case DTDateComponentYear:
return [dateComponents year];
return dateComponents.year;
case DTDateComponentMonth:
return [dateComponents month];
return dateComponents.month;
case DTDateComponentDay:
return [dateComponents day];
return dateComponents.day;
case DTDateComponentHour:
return [dateComponents hour];
return dateComponents.hour;
case DTDateComponentMinute:
return [dateComponents minute];
return dateComponents.minute;
case DTDateComponentSecond:
return [dateComponents second];
return dateComponents.second;
case DTDateComponentWeekday:
return [dateComponents weekday];
return dateComponents.weekday;
case DTDateComponentWeekdayOrdinal:
return [dateComponents weekdayOrdinal];
return dateComponents.weekdayOrdinal;
case DTDateComponentQuarter:
return [dateComponents quarter];
return dateComponents.quarter;
case DTDateComponentWeekOfMonth:
return [dateComponents weekOfMonth];
return dateComponents.weekOfMonth;
case DTDateComponentWeekOfYear:
return [dateComponents weekOfYear];
return dateComponents.weekOfYear;
case DTDateComponentYearForWeekOfYear:
return [dateComponents yearForWeekOfYear];
return dateComponents.yearForWeekOfYear;
case DTDateComponentDayOfYear:
return [calendar ordinalityOfUnit:NSCalendarUnitDay inUnit:NSCalendarUnitYear forDate:date];
default:
@ -818,7 +818,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateByAddingYears:(NSInteger)years{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setYear:years];
components.year = years;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -833,7 +833,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateByAddingMonths:(NSInteger)months{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setMonth:months];
components.month = months;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -848,7 +848,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateByAddingWeeks:(NSInteger)weeks{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setWeekOfYear:weeks];
components.weekOfYear = weeks;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -863,7 +863,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateByAddingDays:(NSInteger)days{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setDay:days];
components.day = days;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -878,7 +878,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateByAddingHours:(NSInteger)hours{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setHour:hours];
components.hour = hours;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -893,7 +893,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateByAddingMinutes:(NSInteger)minutes{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setMinute:minutes];
components.minute = minutes;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -908,7 +908,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateByAddingSeconds:(NSInteger)seconds{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setSecond:seconds];
components.second = seconds;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -924,7 +924,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateBySubtractingYears:(NSInteger)years{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setYear:-1*years];
components.year = -1*years;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -939,7 +939,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateBySubtractingMonths:(NSInteger)months{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setMonth:-1*months];
components.month = -1*months;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -954,7 +954,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateBySubtractingWeeks:(NSInteger)weeks{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setWeekOfYear:-1*weeks];
components.weekOfYear = -1*weeks;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -969,7 +969,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateBySubtractingDays:(NSInteger)days{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setDay:-1*days];
components.day = -1*days;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -984,7 +984,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateBySubtractingHours:(NSInteger)hours{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setHour:-1*hours];
components.hour = -1*hours;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -999,7 +999,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateBySubtractingMinutes:(NSInteger)minutes{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setMinute:-1*minutes];
components.minute = -1*minutes;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -1014,7 +1014,7 @@ static NSCalendar *implicitCalendar = nil;
- (NSDate *)dateBySubtractingSeconds:(NSInteger)seconds{
NSCalendar *calendar = [[self class] implicitCalendar];
NSDateComponents *components = [[NSDateComponents alloc] init];
[components setSecond:-1*seconds];
components.second = -1*seconds;
return [calendar dateByAddingComponents:components toDate:self options:0];
}
@ -1603,9 +1603,9 @@ static NSCalendar *implicitCalendar = nil;
formatter = [[NSDateFormatter alloc] init];
});
[formatter setDateStyle:style];
[formatter setTimeZone:timeZone];
[formatter setLocale:locale];
formatter.dateStyle = style;
formatter.timeZone = timeZone;
formatter.locale = locale;
return [formatter stringFromDate:self];
}
@ -1661,9 +1661,9 @@ static NSCalendar *implicitCalendar = nil;
formatter = [[NSDateFormatter alloc] init];
});
[formatter setDateFormat:format];
[formatter setTimeZone:timeZone];
[formatter setLocale:locale];
formatter.dateFormat = format;
formatter.timeZone = timeZone;
formatter.locale = locale;
return [formatter stringFromDate:self];
}

19
Clocker/EDSunriseSet.m

@ -147,7 +147,7 @@
-(void) sun_RA_decAtDay:(double)d RA:(double*)RA decl:(double *)dec r:(double *)r
{
double lon, obl_ecl;
double xs, ys, zs;
double xs, ys;
double xe, ye, ze;
/* Compute Sun's ecliptical coordinates */
@ -157,7 +157,6 @@
/* Compute ecliptic rectangular coordinates */
xs = *r * cosd(lon);
ys = *r * sind(lon);
zs = 0; /* because the Sun is always in the ecliptic plane! */
/* Compute obliquity of ecliptic (inclination of Earth's axis) */
obl_ecl = 23.4393 - 3.563E-7 * d;
@ -314,13 +313,13 @@ static const int kSecondsInHour= 60.0*60.0;
-(NSDate*)utcTime:(NSDateComponents*)dateComponents withOffset:(NSTimeInterval)interval
{
[self.calendar setTimeZone:self.utcTimeZone];
(self.calendar).timeZone = self.utcTimeZone;
return [[self.calendar dateFromComponents:dateComponents] dateByAddingTimeInterval:(NSTimeInterval)(interval)];
}
-(NSDateComponents*)localTime:(NSDate*)refDate
{
[self.calendar setTimeZone:self.timezone];
(self.calendar).timeZone = self.timezone;
// Return only hour, minute, seconds
NSDateComponents *dc = [self.calendar components:( NSCalendarUnitHour | NSCalendarUnitMinute | NSCalendarUnitSecond) fromDate:refDate] ;
@ -357,12 +356,12 @@ static const int kSecondsInHour= 60.0*60.0;
-(void)calculateSunriseSunset
{
// Get date components
[self.calendar setTimeZone:self.timezone];
(self.calendar).timeZone = self.timezone;
NSDateComponents *dateComponents = [self.calendar components:( NSCalendarUnitYear | NSCalendarUnitMonth | NSCalendarUnitDay ) fromDate:self.date];
// Calculate sunrise and sunset
double rise=0.0, set=0.0;
[self sunRiseSetForYear:(int)[dateComponents year] month:(int)[dateComponents month] day:(int)[dateComponents day] longitude:self.longitude latitude:self.latitude
[self sunRiseSetForYear:(int)dateComponents.year month:(int)dateComponents.month day:(int)dateComponents.day longitude:self.longitude latitude:self.latitude
trise:&rise tset:&set ];
NSTimeInterval secondsRise = rise*kSecondsInHour;
NSTimeInterval secondsSet = set*kSecondsInHour;
@ -376,12 +375,12 @@ static const int kSecondsInHour= 60.0*60.0;
-(void)calculateTwilight
{
// Get date components
[self.calendar setTimeZone:self.timezone];
(self.calendar).timeZone = self.timezone;
NSDateComponents *dateComponents = [self.calendar components:( NSCalendarUnitYear | NSCalendarUnitMonth | NSCalendarUnitDay ) fromDate:self.date];
double start=0.0, end=0.0;
// Civil twilight
[self civilTwilightForYear:(int)[dateComponents year] month:(int)[dateComponents month] day:(int)[dateComponents day] longitude:self.longitude latitude:self.latitude
[self civilTwilightForYear:(int)dateComponents.year month:(int)dateComponents.month day:(int)dateComponents.day longitude:self.longitude latitude:self.latitude
trise:&start tset:&end ];
self.civilTwilightStart = [self utcTime:dateComponents withOffset:(NSTimeInterval)(start*kSecondsInHour)];
self.civilTwilightEnd = [self utcTime:dateComponents withOffset:(NSTimeInterval)(end*kSecondsInHour)];
@ -389,14 +388,14 @@ static const int kSecondsInHour= 60.0*60.0;
self.localCivilTwilightEnd = [self localTime:self.civilTwilightEnd];
// Nautical twilight
[self nauticalTwilightForYear:(int)[dateComponents year] month:(int)[dateComponents month] day:(int)[dateComponents day] longitude:self.longitude latitude:self.latitude
[self nauticalTwilightForYear:(int)dateComponents.year month:(int)dateComponents.month day:(int)dateComponents.day longitude:self.longitude latitude:self.latitude
trise:&start tset:&end ];
self.nauticalTwilightStart = [self utcTime:dateComponents withOffset:(NSTimeInterval)(start*kSecondsInHour)];
self.nauticalTwilightEnd = [self utcTime:dateComponents withOffset:(NSTimeInterval)(end*kSecondsInHour)];
self.localNauticalTwilightStart = [self localTime:self.nauticalTwilightStart];
self.localNauticalTwilightEnd = [self localTime:self.nauticalTwilightEnd];
// Astronomical twilight
[self astronomicalTwilightForYear:(int)[dateComponents year] month:(int)[dateComponents month] day:(int)[dateComponents day] longitude:self.longitude latitude:self.latitude
[self astronomicalTwilightForYear:(int)dateComponents.year month:(int)dateComponents.month day:(int)dateComponents.day longitude:self.longitude latitude:self.latitude
trise:&start tset:&end ];
self.astronomicalTwilightStart = [self utcTime:dateComponents withOffset:(NSTimeInterval)(start*kSecondsInHour)];
self.astronomicalTwilightEnd = [self utcTime:dateComponents withOffset:(NSTimeInterval)(end*kSecondsInHour)];

1
Clocker/Floating Window/CLFloatingWindowController.h

@ -18,5 +18,4 @@
- (void)updatePanelColor;
- (void)startWindowTimer;
@end

39
Clocker/Floating Window/CLFloatingWindowController.m

@ -37,7 +37,7 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
[[NSUserDefaults standardUserDefaults] setObject:@0 forKey:CLThemeKey];
}
NSPanel *panel = (id)[self window];
NSPanel *panel = (id)self.window;
[panel setAcceptsMouseMovedEvents:YES];
[panel setLevel:NSPopUpMenuWindowLevel];
[panel setOpaque:NO];
@ -49,20 +49,20 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
self.shutdownButton.image = [NSImage imageNamed:@"PowerIcon-White"];
self.preferencesButton.image = [NSImage imageNamed:@"Settings-White"];
self.window.backgroundColor = [NSColor blackColor];
[panel setBackgroundColor:[NSColor blackColor]];
panel.backgroundColor = [NSColor blackColor];
}
else
{
self.shutdownButton.image = [NSImage imageNamed:@"PowerIcon"];
self.preferencesButton.image = [NSImage imageNamed:NSImageNameActionTemplate];
self.window.backgroundColor = [NSColor whiteColor];
[panel setBackgroundColor:[NSColor whiteColor]];
panel.backgroundColor = [NSColor whiteColor];
}
[self updateDefaultPreferences];
//Register for drag and drop
[self.mainTableview registerForDraggedTypes: [NSArray arrayWithObject:CLDragSessionKey]];
[self.mainTableview registerForDraggedTypes: @[CLDragSessionKey]];
self.window.titlebarAppearsTransparent = YES;
self.window.titleVisibility = NSWindowTitleHidden;
@ -120,11 +120,8 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
NSNumber *theme = [[NSUserDefaults standardUserDefaults] objectForKey:CLThemeKey];
if (theme.integerValue == 1)
{
[cell updateTextColorWithColor:[NSColor whiteColor] andCell:cell];
[self.mainTableview setBackgroundColor:[NSColor blackColor]];
(self.mainTableview).backgroundColor = [NSColor blackColor];
self.window.alphaValue = 0.90;
[cell.customName setDrawsBackground:YES];
[cell.customName setBackgroundColor:[NSColor blackColor]];
customLabel.insertionPointColor = [NSColor whiteColor];
cell.sunriseSetImage.image = dataObject.sunriseOrSunset ?
[NSImage imageNamed:@"White Sunrise"] : [NSImage imageNamed:@"White Sunset"];
@ -132,9 +129,7 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
else
{
[cell updateTextColorWithColor:[NSColor blackColor] andCell:cell];
[cell.customName setDrawsBackground:NO];
[self.mainTableview setBackgroundColor:[NSColor whiteColor]];
(self.mainTableview).backgroundColor = [NSColor whiteColor];
self.window.alphaValue = 1;
customLabel.insertionPointColor = [NSColor blackColor];
cell.sunriseSetImage.image = dataObject.sunriseOrSunset ?
@ -151,7 +146,7 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
NSNumber *displayFutureSlider = [[NSUserDefaults standardUserDefaults] objectForKey:CLDisplayFutureSliderKey];
self.futureSlider.hidden = [displayFutureSlider isEqualToNumber:[NSNumber numberWithInteger:1]] ? YES : NO;
self.futureSlider.hidden = [displayFutureSlider isEqualToNumber:@1] ? YES : NO;
NSNumber *displaySunriseSunsetTime = [[NSUserDefaults standardUserDefaults] objectForKey:CLSunriseSunsetTime];
@ -168,7 +163,7 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
cell.sunriseSetTime.hidden = YES;
}
[cell setUpAutoLayoutWithCell];
[cell setUpLayout];
return cell;
}
@ -180,7 +175,7 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
- (BOOL)tableView:(NSTableView *)tableView writeRowsWithIndexes:(NSIndexSet *)rowIndexes toPasteboard:(NSPasteboard *)pboard
{
NSData *data = [NSKeyedArchiver archivedDataWithRootObject:rowIndexes];
[pboard declareTypes:[NSArray arrayWithObject:CLDragSessionKey] owner:self];
[pboard declareTypes:@[CLDragSessionKey] owner:self];
[pboard setData:data forType:CLDragSessionKey];
return YES;
}
@ -198,7 +193,7 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
}
dataObject.customLabel = object;
[self.defaultPreferences replaceObjectAtIndex:row withObject:dataObject];
(self.defaultPreferences)[row] = dataObject;
[[NSUserDefaults standardUserDefaults] setObject:self.defaultPreferences forKey:CLDefaultPreferenceKey];
[self.mainTableview reloadData];
}
@ -228,8 +223,8 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
[[NSApplication sharedApplication].windows enumerateObjectsUsingBlock:^(NSWindow * _Nonnull window, NSUInteger idx, BOOL * _Nonnull stop) {
if ([window.windowController isMemberOfClass:[CLOneWindowController class]]) {
CLOneWindowController *ref = (CLOneWindowController *) window.windowController;
[ref.preferencesView refereshTimezoneTableView];
CLOneWindowController *oneWindowController = (CLOneWindowController *) window.windowController;
[oneWindowController.preferencesView refereshTimezoneTableView];
}
}];
@ -248,11 +243,11 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
{
[super updateDefaultPreferences];
NSRect frame = [self.window frame];
NSRect frame = (self.window).frame;
frame.size = NSMakeSize(self.window.frame.size.width, self.scrollViewHeight.constant+10);
[self.window setFrame: frame display: YES animate:YES];
[self.window setContentMaxSize:NSMakeSize(self.window.frame.size.width+50, self.scrollViewHeight.constant+100)];
(self.window).contentMaxSize = NSMakeSize(self.window.frame.size.width+50, self.scrollViewHeight.constant+100);
[self updateTime];
}
@ -341,7 +336,7 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
{
[super updatePanelColor];
NSPanel *panel = (id)[self window];
NSPanel *panel = (id)self.window;
[panel setAcceptsMouseMovedEvents:YES];
[panel setLevel:NSPopUpMenuWindowLevel];
[panel setOpaque:NO];
@ -354,14 +349,14 @@ NSString *const CLTimezoneCellIdentifier = @"timeZoneCell";
self.shutdownButton.image = [NSImage imageNamed:@"PowerIcon-White"];
self.preferencesButton.image = [NSImage imageNamed:@"Settings-White"];
self.window.backgroundColor = [NSColor blackColor];
[panel setBackgroundColor:[NSColor blackColor]];
panel.backgroundColor = [NSColor blackColor];
}
else
{
self.shutdownButton.image = [NSImage imageNamed:@"PowerIcon"];
self.preferencesButton.image = [NSImage imageNamed:NSImageNameActionTemplate];
self.window.backgroundColor = [NSColor whiteColor];
[panel setBackgroundColor:[NSColor whiteColor]];
panel.backgroundColor = [NSColor whiteColor];
}
}

6
Clocker/MenubarController.h

@ -40,9 +40,9 @@
@property (nonatomic) BOOL hasActiveIcon;
@property (nonatomic, strong, readonly) NSStatusItem *statusItem;
@property (nonatomic, strong, readonly) StatusItemView *statusItemView;
@property (nonatomic, strong) NSTimer *iconUpdateTimer;
@property (nonatomic, strong) NSTimer *menubarUpdateTimer;
- (void)setInitialTimezoneData;
- (void)shouldIconBeUpdated:(BOOL)value;
- (void)setUpTimerForUpdatingMenubar;
- (void)invalidateTimerForMenubar;
@end

78
Clocker/MenubarController.m

@ -11,14 +11,13 @@
#pragma mark -
- (id)init
- (instancetype)init
{
self = [super init];
if (self != nil)
{
// Install status item into the menu bar
NSData *dataObject = [[NSUserDefaults standardUserDefaults] objectForKey:@"favouriteTimezone"];
NSString *menuTitle = [NSString new];
NSStatusItem *statusItem;
NSTextField *textField;
@ -26,78 +25,77 @@
if (dataObject)
{
CLTimezoneData *timezoneObject = [CLTimezoneData getCustomObject:dataObject];
menuTitle = [timezoneObject getMenuTitle];
NSString *menuTitle = [timezoneObject getMenuTitle];
textField= [[NSTextField alloc] initWithFrame:NSMakeRect(0, 0, STATUS_ITEM_VIEW_WIDTH, 18)];
textField.backgroundColor = [NSColor whiteColor];
textField.bordered = NO;
textField.textColor = [NSColor blackColor];
textField.alignment = NSTextAlignmentCenter;
textField = [self setUpTextfieldForMenubar];
textField.stringValue = (menuTitle.length > 0) ? menuTitle : @"Icon";
[textField sizeToFit];
statusItem = [[NSStatusBar systemStatusBar] statusItemWithLength:textField.frame.size.width+3];
[self shouldIconBeUpdated:YES];
[self setUpTimerForUpdatingMenubar];
}
else
{
statusItem = [[NSStatusBar systemStatusBar] statusItemWithLength:STATUS_ITEM_VIEW_WIDTH];
[self shouldIconBeUpdated:NO];
[self invalidateTimerForMenubar];
}
_statusItemView = [[StatusItemView alloc] initWithStatusItem:statusItem];
_statusItemView.image = dataObject ? [self imageWithSubviewsWithTextField:textField] : [NSImage imageNamed:@"MenuIcon"];
_statusItemView.image = dataObject ? [self convertTextfieldRepresentationToImage:textField] : [NSImage imageNamed:@"MenuIcon"];
_statusItemView.alternateImage = [NSImage imageNamed:@"StatusHighlighted"];
_statusItemView.action = @selector(togglePanel:);
}
}
return self;
}
- (void)setInitialTimezoneData
- (NSTextField *)setUpTextfieldForMenubar
{
[CLTimezoneData setInitialTimezoneData];
NSTextField *textField= [[NSTextField alloc] initWithFrame:NSMakeRect(0, 0, STATUS_ITEM_VIEW_WIDTH, 18)];
textField.backgroundColor = [NSColor whiteColor];
textField.bordered = NO;
textField.textColor = [NSColor blackColor];
textField.alignment = NSTextAlignmentCenter;
return textField;
}
- (void)updateIconDisplay
- (void)updateMenubar
{
[self.statusItemView setNeedsDisplay:YES];
}
- (void)shouldIconBeUpdated:(BOOL)value
- (void)setUpTimerForUpdatingMenubar
{
if (value)
{
self.iconUpdateTimer = [NSTimer scheduledTimerWithTimeInterval:1.0
target:self
selector:@selector(updateIconDisplay)
userInfo:nil
repeats:YES];
self.menubarUpdateTimer = [NSTimer scheduledTimerWithTimeInterval:1.0
target:self
selector:@selector(updateMenubar)
userInfo:nil
repeats:YES];
}
}
else
{
//Call setNeedsDisplay to change the icon and then invalidate the timer
[self.statusItemView setNeedsDisplay:YES];
[self.iconUpdateTimer invalidate];
self.iconUpdateTimer = nil;
}
- (void)invalidateTimerForMenubar
{
[self.statusItemView setNeedsDisplay:YES];
[self.menubarUpdateTimer invalidate];
self.menubarUpdateTimer = nil;
}
- (NSImage *)imageWithSubviewsWithTextField:(NSTextField *)textField
- (NSImage *)convertTextfieldRepresentationToImage:(NSTextField *)textField
{
NSSize mySize = textField.bounds.size;
NSSize imgSize = NSMakeSize( mySize.width, mySize.height );
NSSize textfieldSize = textField.bounds.size;
NSSize imgSize = NSMakeSize(textfieldSize.width, textfieldSize.height);
NSBitmapImageRep *bir = [textField bitmapImageRepForCachingDisplayInRect:[textField bounds]];
[bir setSize:imgSize];
[textField cacheDisplayInRect:[textField bounds] toBitmapImageRep:bir];
NSBitmapImageRep *bitmapRepresentation = [textField bitmapImageRepForCachingDisplayInRect:textField.bounds];
bitmapRepresentation.size = imgSize;
[textField cacheDisplayInRect:textField.bounds toBitmapImageRep:bitmapRepresentation];
NSImage* image = [[NSImage alloc]initWithSize:imgSize];
[image addRepresentation:bir];
NSImage* image = [[NSImage alloc] initWithSize:imgSize];
[image addRepresentation:bitmapRepresentation];
return image;
}

19
Clocker/Model/CLTimezoneData.h

@ -9,15 +9,15 @@
#import <Foundation/Foundation.h>
#import "CLTimezoneCellView.h"
typedef enum : NSUInteger {
typedef NS_ENUM(NSUInteger, CLDateDisplayType) {
CLPanelDisplay,
CLMenuDisplay
} CLDateDisplayType;
};
typedef enum : NSUInteger {
typedef NS_ENUM(NSUInteger, CLSelection) {
CLCitySelection,
CLTimezoneSelection
} CLSelection;
};
@interface CLTimezoneData : NSObject<NSCoding>
@ -35,21 +35,14 @@ typedef enum : NSUInteger {
@property (assign, nonatomic) CLSelection selectionType;
+ (instancetype)getCustomObject:(NSData *)encodedData;
+ (void)setInitialTimezoneData;
- (instancetype)initWithDictionary:(NSDictionary *)dictionary;
- (BOOL)saveObjectToPreferences;
- (NSString *)getTimeForTimeZoneWithFutureSliderValue:(NSInteger)futureSliderValue;
- (NSString *)getLocalCurrentDate;
- (NSString *)compareSystemDate:(NSString *)systemDate toTimezoneDate:(NSString *)date;
- (NSString *)getDateForTimeZoneWithFutureSliderValue:(NSInteger)futureSliderValue andDisplayType:(CLDateDisplayType)type;
- (NSString *)formatStringShouldContainCity:(BOOL)value;
- (NSString *)getMenuTitle;
@property (NS_NONATOMIC_IOSONLY, getter=getMenuTitle, readonly, copy) NSString *menuTitle;
-(NSString *)getFormattedSunriseOrSunsetTimeAndSliderValue:(NSInteger)sliderValue;
/*
- (NSString *)getFormattedSunriseOrSunsetTimeAndSunImage:(CLTimezoneCellView *)cell;
*/
- (void)save;
@end

71
Clocker/Model/CLTimezoneData.m

@ -6,7 +6,7 @@
//
//
#import "CLAPI.h"
#import "CLAPIConnector.h"
#import "CLTimezoneData.h"
#import "CommonStrings.h"
#import "DateTools.h"
@ -29,34 +29,13 @@
self.longitude = dictionary[@"longitude"];
self.place_id = dictionary[CLPlaceIdentifier];
self.formattedAddress = dictionary[CLTimezoneName];
self.isFavourite = [NSNumber numberWithInt:NSOffState];
self.isFavourite = @(NSOffState);
self.selectionType = CLCitySelection;
}
return self;
}
+ (void)setInitialTimezoneData
{
CLTimezoneData *newData = [self new];
newData.timezoneID = [[NSTimeZone systemTimeZone] name];
newData.formattedAddress = newData.timezoneID;
[newData saveObjectToPreferences];
}
- (BOOL)saveObjectToPreferences
{
NSData *encodedObject = [NSKeyedArchiver archivedDataWithRootObject:self];
NSMutableArray *array = [NSMutableArray new];
[array addObject:encodedObject];
[[NSUserDefaults standardUserDefaults] setObject:array forKey:CLDefaultPreferenceKey];
return YES;
}
+ (instancetype)getCustomObject:(NSData *)encodedData
{
@ -67,13 +46,13 @@
CLTimezoneData *newObject = [[self alloc] initWithDictionary:(NSDictionary *)encodedData];
return newObject;
}
CLTimezoneData *object = [NSKeyedUnarchiver unarchiveObjectWithData:encodedData];
return object;
}
return nil;
}
- (void)encodeWithCoder:(NSCoder *)coder
@ -168,7 +147,7 @@
NSNumber *is24HourFormatSelected = [[NSUserDefaults standardUserDefaults] objectForKey:CL24hourFormatSelectedKey];
is24HourFormatSelected.boolValue ? [dateFormatter setDateFormat:@"HH:mm"] : [dateFormatter setDateFormat:@"hh:mm a"];
dateFormatter.dateFormat = is24HourFormatSelected.boolValue ? @"HH:mm" : @"hh:mm a";
dateFormatter.timeZone = [NSTimeZone timeZoneWithName:self.timezoneID];
//In the format 22:10
@ -180,7 +159,7 @@
{
NSString *preferredLanguage = [NSLocale preferredLanguages][0];
if (![CLAPI isUserConnectedToInternet])
if (![CLAPIConnector isUserConnectedToInternet])
{
/*Show some kind of information label*/
return;
@ -192,7 +171,7 @@
NSString *urlString = [NSString stringWithFormat:CLLocationSearchURL, formattedString, preferredLanguage];
[CLAPI dataTaskWithServicePath:urlString
[CLAPIConnector dataTaskWithServicePath:urlString
bySender:self
withCompletionBlock:^(NSError *error, NSDictionary *json) {
@ -212,7 +191,7 @@
{
//We have a match
NSDictionary *latLang = [[dictionary objectForKey:@"geometry"] objectForKey:@"location"];
NSDictionary *latLang = dictionary[@"geometry"][@"location"];
self.latitude = [NSString stringWithFormat:@"%@", latLang[@"lat"]];
self.longitude = [NSString stringWithFormat:@"%@", latLang[@"lng"]];
}
@ -268,18 +247,12 @@
newDataObject.customLabel = self.customLabel;
newDataObject.place_id = self.place_id;
newDataObject.nextUpdate = tomorrowMidnight;
newDataObject.isFavourite = [NSNumber numberWithInt:NSOffState];
newDataObject.isFavourite = @(NSOffState);
__block PanelController *panelController;
PanelController *panelController = [PanelController getPanelControllerInstance];
[[NSApplication sharedApplication].windows enumerateObjectsUsingBlock:^(NSWindow * _Nonnull window, NSUInteger idx, BOOL * _Nonnull stop) {
if ([window.windowController isMemberOfClass:[PanelController class]])
{
panelController = window.windowController;
}
}];
(panelController.defaultPreferences)[[panelController.defaultPreferences indexOfObject:self]] = newDataObject;
[panelController.defaultPreferences replaceObjectAtIndex:[panelController.defaultPreferences indexOfObject:self] withObject:newDataObject];
[[NSUserDefaults standardUserDefaults] setObject:panelController.defaultPreferences forKey:CLDefaultPreferenceKey];
}
@ -482,11 +455,11 @@
dateFormatter.dateStyle = kCFDateFormatterNoStyle;
[dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:self.timezoneID]];
dateFormatter.timeZone = [NSTimeZone timeZoneWithName:self.timezoneID];
NSNumber *is24HourFormatSelected = [[NSUserDefaults standardUserDefaults] objectForKey:CL24hourFormatSelectedKey];
is24HourFormatSelected.boolValue ? [dateFormatter setDateFormat:@"HH:mm"] : [dateFormatter setDateFormat:@"hh:mm a"];
dateFormatter.dateFormat = is24HourFormatSelected.boolValue ? @"HH:mm" : @"hh:mm a";
//In the format 22:10
@ -494,22 +467,22 @@
}
- (NSString *)getFullFledgedDateForTimeWithDate:(NSDate *)date
- (void)save
{
NSCalendar *currentCalendar = [NSCalendar autoupdatingCurrentCalendar];
NSArray *defaultPreference = [[NSUserDefaults standardUserDefaults] objectForKey:CLDefaultPreferenceKey];
NSDate *newDate = [currentCalendar dateByAddingUnit:NSCalendarUnitMinute
value:0
toDate:date
options:kNilOptions];
if (defaultPreference == nil)
{
defaultPreference = [NSMutableArray new];
}
NSDateFormatter *dateFormatter = [NSDateFormatter new];
NSData *encodedObject = [NSKeyedArchiver archivedDataWithRootObject:self];
[dateFormatter setDateFormat:@"yyyy-MM-dd hh:mm a"];
NSMutableArray *newArray = [[NSMutableArray alloc] initWithArray:defaultPreference];
[dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:self.timezoneID]];
[newArray addObject:encodedObject];
return [dateFormatter stringFromDate:newDate];
[[NSUserDefaults standardUserDefaults] setObject:newArray forKey:CLDefaultPreferenceKey];
}
@end

8
Clocker/Onboarding/CLIntroViewController.h

@ -7,12 +7,14 @@
//
#import <Cocoa/Cocoa.h>
#import "CLParentViewController.h"
typedef enum : NSUInteger {
typedef NS_ENUM(NSUInteger, CLFeature) {
CLFloatingViewFeature,
CLKeyboardShortcutFeature,
CLFavouriteFeature
} CLFeature;
};
@interface CLIntroViewController : CLParentViewController
@interface CLIntroViewController : NSViewController
@end

23
Clocker/Onboarding/CLIntroViewController.m

@ -34,28 +34,15 @@
- (void)viewDidLoad
{
[super viewDidLoad];
// Do view setup here.
// self.view.window.titleVisibility = NSWindowTitleHidden;
self.headerLabelString = @[@"Now, Clocker stays on top of all the windows", @"Access Clocker through keyboard shortcuts", @"Customize your menubar with Favourites"];
[self.headerView setWantsLayer:YES];
CALayer *viewLayer = [CALayer layer];
[viewLayer setBackgroundColor:CGColorCreateGenericRGB(255.0, 255.0, 255.0, 0.8)]; //RGB plus Alpha Channel
[self.view setWantsLayer:YES]; // view's backing store is using a Core Animation Layer
[self.view setLayer:viewLayer];
self.view.window.styleMask = NSFullSizeContentViewWindowMask;
[self initializeViews];
/*
Hide continue button until the animations are over.
Faltu me animations waste hoga nahi toh.
*/
self.nextActionButton.hidden = YES;
[self addAnimationInOrderWithTag:CLFloatingViewFeature];
@ -164,15 +151,15 @@
- (IBAction)continueOnboarding:(NSButton *)sender
{
if ([[sender title] isEqualToString:@"Continue"])
if ([sender.title isEqualToString:@"Continue"])
{
[self performContinueButtonAnimationWithValue:YES];
[self addAnimationInOrderWithTag:CLKeyboardShortcutFeature];
[sender setTitle:@"Next"];
sender.title = @"Next";
}
else if ([[sender title] isEqualToString:@"Next"])
else if ([sender.title isEqualToString:@"Next"])
{
[self performContinueButtonAnimationWithValue:YES];
@ -226,15 +213,13 @@
[self performSkipEvent];
}
- (BOOL) performSkipEvent
- (void) performSkipEvent
{
[self.view.window close];
ApplicationDelegate *delegate = (ApplicationDelegate*)[NSApplication sharedApplication].delegate;
[delegate togglePanel:nil];
return YES;
}
- (void)openPreferences

7
Clocker/Onboarding/CLOnboardingWindowController.m

@ -58,15 +58,10 @@ static CLOnboardingWindowController *sharedOnboardingWindow;
CGRect newFrame = self.introViewController.view.frame;
[self performBoundsAnimationWithOldRect:oldFrame andNewRect:newFrame];
}
- (void)performBoundsAnimationWithOldRect:(CGRect)fromRect andNewRect:(CGRect)newRect
{
[self.window setFrame:fromRect display:NO animate:NO];
self.window.contentView.wantsLayer = YES;
@ -81,7 +76,7 @@ static CLOnboardingWindowController *sharedOnboardingWindow;
[self.window setContentSize:self.introViewController.view.frame.size];
[self.window setContentView:self.introViewController.view];
(self.window).contentView = self.introViewController.view;
}

4
Clocker/Onboarding/Onboarding Animated Views/QCMethod.h

@ -40,11 +40,11 @@
#if (TARGET_IPHONE_SIMULATOR || TARGET_OS_IPHONE)
#else
@interface NSBezierPath (Path)
- (CGPathRef)quartzPath;
@property (NS_NONATOMIC_IOSONLY, readonly) CGPathRef quartzPath;
@end
@interface NSImage (cgImage)
-(CGImageRef)cgImage;
@property (NS_NONATOMIC_IOSONLY, readonly) CGImageRef cgImage;
@end

12
Clocker/Onboarding/Onboarding Animated Views/QCMethod.m

@ -52,7 +52,7 @@
CAKeyframeAnimation *keyAnim = (CAKeyframeAnimation*)anim;
if (!anim.autoreverses) {
NSArray *values = [[keyAnim.values reverseObjectEnumerator] allObjects];
NSArray *values = [keyAnim.values reverseObjectEnumerator].allObjects;
keyAnim.values = values;
reverseTimingFunction(keyAnim);
}
@ -226,7 +226,7 @@
}
groupAnim.animations = newSubAnimations;
NSArray *animations = [(CAAnimationGroup*)groupAnim animations];
NSArray *animations = ((CAAnimationGroup*)groupAnim).animations;
for (CABasicAnimation *sub in animations) {
setBeginTime(sub, idx);
@ -277,10 +277,11 @@
#else
@implementation NSBezierPath (Path)
- (CGPathRef)quartzPath{
- (CGPathRef)quartzPath
{
NSInteger i, numElements;
CGPathRef immutablePath = NULL;
numElements = [self elementCount];
numElements = self.elementCount;
if (numElements > 0)
{
@ -321,6 +322,7 @@
immutablePath = CGPathCreateCopy(path);
CGPathRelease(path);
}
return immutablePath;
}
@ -329,7 +331,7 @@
@implementation NSImage (cgImage)
-(CGImageRef)cgImage{
NSData* data = [self TIFFRepresentation];
NSData* data = self.TIFFRepresentation;
CGImageRef imageRef = NULL;
CGImageSourceRef sourceRef;

3
Clocker/PanelController.h

@ -58,7 +58,8 @@
@property (nonatomic, unsafe_unretained) IBOutlet BackgroundView *backgroundView;
@property (strong, nonatomic) PanelController *panelWindow;
- (id)initWithDelegate:(id<PanelControllerDelegate>)delegate;
+ (instancetype)getPanelControllerInstance;
- (instancetype)initWithDelegate:(id<PanelControllerDelegate>)delegate;
- (void)openPanel;
- (void)closePanel;
- (void)updateDefaultPreferences;

74
Clocker/PanelController.m

@ -66,7 +66,7 @@ static PanelController *sharedPanel = nil;
#pragma mark -
- (id)initWithDelegate:(id<PanelControllerDelegate>)delegate
- (instancetype)initWithDelegate:(id<PanelControllerDelegate>)delegate
{
self = [super initWithWindowNibName:CLPanelNibIdentifier];
if (self != nil)
@ -90,14 +90,16 @@ static PanelController *sharedPanel = nil;
self.dateFormatter = [NSDateFormatter new];
}
NSPanel *panel = (id)[self window];
self.mainTableview.delegate = self;
NSPanel *panel = (id)self.window;
[panel setAcceptsMouseMovedEvents:YES];
[panel setLevel:NSPopUpMenuWindowLevel];
[panel setOpaque:NO];
[panel setBackgroundColor:[NSColor clearColor]];
panel.backgroundColor = [NSColor clearColor];
//Register for drag and drop
[self.mainTableview registerForDraggedTypes: [NSArray arrayWithObject:CLDragSessionKey]];
[self.mainTableview registerForDraggedTypes: @[CLDragSessionKey]];
[super updatePanelColor];
@ -141,7 +143,7 @@ static PanelController *sharedPanel = nil;
- (void)windowDidResignKey:(NSNotification *)notification;
{
if ([[self window] isVisible])
if (self.window.visible)
{
self.hasActivePanel = NO;
}
@ -149,9 +151,9 @@ static PanelController *sharedPanel = nil;
- (void)windowDidResize:(NSNotification *)notification
{
NSWindow *panel = [self window];
NSWindow *panel = self.window;
NSRect statusRect = [self statusRectForWindow:panel];
NSRect panelRect = [panel frame];
NSRect panelRect = panel.frame;
CGFloat statusX = roundf(NSMidX(statusRect));
CGFloat panelX = statusX - NSMinX(panelRect);
@ -170,7 +172,7 @@ static PanelController *sharedPanel = nil;
- (NSRect)statusRectForWindow:(NSWindow *)window
{
NSRect screenRect = [[[NSScreen screens] objectAtIndex:0] frame];
NSRect screenRect = [NSScreen screens][0].frame;
NSRect statusRect = NSZeroRect;
StatusItemView *statusItemView = nil;
@ -186,7 +188,7 @@ static PanelController *sharedPanel = nil;
}
else
{
statusRect.size = NSMakeSize(STATUS_ITEM_VIEW_WIDTH, [[NSStatusBar systemStatusBar] thickness]);
statusRect.size = NSMakeSize(STATUS_ITEM_VIEW_WIDTH, [NSStatusBar systemStatusBar].thickness);
statusRect.origin.x = roundf((NSWidth(screenRect) - NSWidth(statusRect)) / 2);
statusRect.origin.y = NSHeight(screenRect) - NSHeight(statusRect) * 2;
}
@ -197,12 +199,12 @@ static PanelController *sharedPanel = nil;
{
self.futureSliderValue = 0;
NSWindow *panel = [self window];
NSWindow *panel = self.window;
NSRect screenRect = [[[NSScreen screens] objectAtIndex:0] frame];
NSRect screenRect = [NSScreen screens][0].frame;
NSRect statusRect = [self statusRectForWindow:panel];
NSRect panelRect = [panel frame];
NSRect panelRect = panel.frame;
panelRect.size.width = PANEL_WIDTH;
panelRect.size.height = self.showReviewCell ? (self.defaultPreferences.count+1)*55+40: self.defaultPreferences.count*55 + 30;
@ -214,16 +216,16 @@ static PanelController *sharedPanel = nil;
panelRect.origin.x -= NSMaxX(panelRect) - (NSMaxX(screenRect) - ARROW_HEIGHT);
[NSApp activateIgnoringOtherApps:NO];
[panel setAlphaValue:0];
panel.alphaValue = 0;
[panel setFrame:statusRect display:YES];
[panel makeKeyAndOrderFront:nil];
NSTimeInterval openDuration = OPEN_DURATION;
NSEvent *currentEvent = [NSApp currentEvent];
if ([currentEvent type] == NSLeftMouseDown)
NSEvent *currentEvent = NSApp.currentEvent;
if (currentEvent.type == NSLeftMouseDown)
{
NSUInteger clearFlags = ([currentEvent modifierFlags] & NSDeviceIndependentModifierFlagsMask);
NSUInteger clearFlags = (currentEvent.modifierFlags & NSDeviceIndependentModifierFlagsMask);
BOOL shiftPressed = (clearFlags == NSShiftKeyMask);
BOOL shiftOptionPressed = (clearFlags == (NSShiftKeyMask | NSAlternateKeyMask));
if (shiftPressed || shiftOptionPressed)
@ -234,9 +236,9 @@ static PanelController *sharedPanel = nil;
}
[NSAnimationContext beginGrouping];
[[NSAnimationContext currentContext] setDuration:openDuration];
[NSAnimationContext currentContext].duration = openDuration;
[[panel animator] setFrame:panelRect display:YES];
[[panel animator] setAlphaValue:1];
[panel animator].alphaValue = 1;
[NSAnimationContext endGrouping];
[self.mainTableview reloadData];
@ -247,7 +249,7 @@ static PanelController *sharedPanel = nil;
{
[NSAnimationContext beginGrouping];
[[NSAnimationContext currentContext] setDuration:CLOSE_DURATION];
[[[self window] animator] setAlphaValue:0];
[self.window animator].alphaValue = 0;
[NSAnimationContext endGrouping];
dispatch_after(dispatch_walltime(NULL, NSEC_PER_SEC * CLOSE_DURATION * 2), dispatch_get_main_queue(), ^{
@ -268,8 +270,6 @@ static PanelController *sharedPanel = nil;
return self.defaultPreferences.count;
}
-(NSView*)tableView:(NSTableView *)tableView viewForTableColumn:(NSTableColumn *)tableColumn row:(NSInteger)row
{
if (self.showReviewCell && row == self.defaultPreferences.count) {
@ -290,13 +290,11 @@ static PanelController *sharedPanel = nil;
forObject:cell.relativeDate];
NSNumber *theme = [[NSUserDefaults standardUserDefaults] objectForKey:CLThemeKey];
if (theme.integerValue == 1)
{
[cell updateTextColorWithColor:[NSColor whiteColor] andCell:cell];
[self.mainTableview setBackgroundColor:[NSColor blackColor]];
(self.mainTableview).backgroundColor = [NSColor blackColor];
self.window.alphaValue = 0.90;
[cell.customName setDrawsBackground:YES];
[cell.customName setBackgroundColor:[NSColor blackColor]];
customLabel.insertionPointColor = [NSColor whiteColor];
cell.sunriseSetImage.image = dataObject.sunriseOrSunset ?
[NSImage imageNamed:@"White Sunrise"] : [NSImage imageNamed:@"White Sunset"];
@ -304,9 +302,7 @@ static PanelController *sharedPanel = nil;
else
{
[cell updateTextColorWithColor:[NSColor blackColor] andCell:cell];
[cell.customName setDrawsBackground:NO];
[self.mainTableview setBackgroundColor:[NSColor whiteColor]];
(self.mainTableview).backgroundColor = [NSColor whiteColor];
self.window.alphaValue = 1;
customLabel.insertionPointColor = [NSColor blackColor];
cell.sunriseSetImage.image = dataObject.sunriseOrSunset ?
@ -324,7 +320,7 @@ static PanelController *sharedPanel = nil;
NSNumber *displayFutureSlider = [[NSUserDefaults standardUserDefaults] objectForKey:CLDisplayFutureSliderKey];
self.futureSlider.hidden = [displayFutureSlider isEqualToNumber:[NSNumber numberWithInteger:1]] ? YES : NO;
self.futureSlider.hidden = [displayFutureSlider isEqualToNumber:@1] ? YES : NO;
NSNumber *displaySunriseSunsetTime = [[NSUserDefaults standardUserDefaults] objectForKey:CLSunriseSunsetTime];
@ -341,7 +337,7 @@ static PanelController *sharedPanel = nil;
cell.sunriseSetTime.hidden = YES;
}
[cell setUpAutoLayoutWithCell];
[cell setUpLayout];
return cell;
}
@ -362,7 +358,7 @@ static PanelController *sharedPanel = nil;
}
dataObject.customLabel = object;
[self.defaultPreferences replaceObjectAtIndex:row withObject:dataObject];
(self.defaultPreferences)[row] = dataObject;
[[NSUserDefaults standardUserDefaults] setObject:self.defaultPreferences forKey:CLDefaultPreferenceKey];
[self.mainTableview reloadData];
}
@ -400,7 +396,6 @@ static PanelController *sharedPanel = nil;
- (IBAction)openPreferences:(id)sender
{
// [self.mainTableview abortEditing];
self.oneWindow = [CLOneWindowController sharedWindow];
[self.oneWindow showWindow:nil];
[NSApp activateIgnoringOtherApps:YES];
@ -423,4 +418,19 @@ static PanelController *sharedPanel = nil;
}
+ (instancetype)getPanelControllerInstance
{
__block PanelController *panelController;
[[NSApplication sharedApplication].windows enumerateObjectsUsingBlock:^(NSWindow * _Nonnull window, NSUInteger idx, BOOL * _Nonnull stop) {
if ([window.windowController isMemberOfClass:[PanelController class]])
{
panelController = window.windowController;
}
}];
return panelController;
}
@end

1
Clocker/Parse/Bolts.framework/Bolts

@ -1 +0,0 @@
Versions/Current/Bolts

1
Clocker/Parse/Bolts.framework/Headers

@ -1 +0,0 @@
Versions/Current/Headers

1
Clocker/Parse/Bolts.framework/Modules

@ -1 +0,0 @@
Versions/Current/Modules

1
Clocker/Parse/Bolts.framework/Resources

@ -1 +0,0 @@
Versions/Current/Resources

BIN
Clocker/Parse/Bolts.framework/Versions/A/Bolts

Binary file not shown.

42
Clocker/Parse/Bolts.framework/Versions/A/Headers/BFCancellationToken.h

@ -1,42 +0,0 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFCancellationTokenRegistration.h>
NS_ASSUME_NONNULL_BEGIN
/*!
A block that will be called when a token is cancelled.
*/
typedef void(^BFCancellationBlock)();
/*!
The consumer view of a CancellationToken.
Propagates notification that operations should be canceled.
A BFCancellationToken has methods to inspect whether the token has been cancelled.
*/
@interface BFCancellationToken : NSObject
/*!
Whether cancellation has been requested for this token source.
*/
@property (nonatomic, assign, readonly, getter=isCancellationRequested) BOOL cancellationRequested;
/*!
Register a block to be notified when the token is cancelled.
If the token is already cancelled the delegate will be notified immediately.
*/
- (BFCancellationTokenRegistration *)registerCancellationObserverWithBlock:(BFCancellationBlock)block;
@end
NS_ASSUME_NONNULL_END

29
Clocker/Parse/Bolts.framework/Versions/A/Headers/BFCancellationTokenRegistration.h

@ -1,29 +0,0 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/
#import <Foundation/Foundation.h>
NS_ASSUME_NONNULL_BEGIN
/*!
Represents the registration of a cancellation observer with a cancellation token.
Can be used to unregister the observer at a later time.
*/
@interface BFCancellationTokenRegistration : NSObject
/*!
Removes the cancellation observer registered with the token
and releases all resources associated with this registration.
*/
- (void)dispose;
@end
NS_ASSUME_NONNULL_END

60
Clocker/Parse/Bolts.framework/Versions/A/Headers/BFCancellationTokenSource.h

@ -1,60 +0,0 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/
#import <Foundation/Foundation.h>
NS_ASSUME_NONNULL_BEGIN
@class BFCancellationToken;
/*!
BFCancellationTokenSource represents the producer side of a CancellationToken.
Signals to a CancellationToken that it should be canceled.
It is a cancellation token that also has methods
for changing the state of a token by cancelling it.
*/
@interface BFCancellationTokenSource : NSObject
/*!
Creates a new cancellation token source.
*/
+ (instancetype)cancellationTokenSource;
/*!
The cancellation token associated with this CancellationTokenSource.
*/
@property (nonatomic, strong, readonly) BFCancellationToken *token;
/*!
Whether cancellation has been requested for this token source.
*/
@property (nonatomic, assign, readonly, getter=isCancellationRequested) BOOL cancellationRequested;
/*!
Cancels the token if it has not already been cancelled.
*/
- (void)cancel;
/*!
Schedules a cancel operation on this CancellationTokenSource after the specified number of milliseconds.
@param millis The number of milliseconds to wait before completing the returned task.
If delay is `0` the cancel is executed immediately. If delay is `-1` any scheduled cancellation is stopped.
*/
- (void)cancelAfterDelay:(int)millis;
/*!
Releases all resources associated with this token source,
including disposing of all registrations.
*/
- (void)dispose;
@end
NS_ASSUME_NONNULL_END

18
Clocker/Parse/Bolts.framework/Versions/A/Headers/BFDefines.h

@ -1,18 +0,0 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/
#import <Foundation/Foundation.h>
#if __has_feature(objc_generics) || __has_extension(objc_generics)
# define BF_GENERIC(type) <type>
#else
# define BF_GENERIC(type)
# define BFGenericType id
#endif

62
Clocker/Parse/Bolts.framework/Versions/A/Headers/BFExecutor.h

@ -1,62 +0,0 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/
#import <Foundation/Foundation.h>
NS_ASSUME_NONNULL_BEGIN
/*!
An object that can run a given block.
*/
@interface BFExecutor : NSObject
/*!
Returns a default executor, which runs continuations immediately until the call stack gets too
deep, then dispatches to a new GCD queue.
*/
+ (instancetype)defaultExecutor;
/*!
Returns an executor that runs continuations on the thread where the previous task was completed.
*/
+ (instancetype)immediateExecutor;
/*!
Returns an executor that runs continuations on the main thread.
*/
+ (instancetype)mainThreadExecutor;
/*!
Returns a new executor that uses the given block to execute continuations.
@param block The block to use.
*/
+ (instancetype)executorWithBlock:(void(^)(void(^block)()))block;
/*!
Returns a new executor that runs continuations on the given queue.
@param queue The instance of `dispatch_queue_t` to dispatch all continuations onto.
*/
+ (instancetype)executorWithDispatchQueue:(dispatch_queue_t)queue;
/*!
Returns a new executor that runs continuations on the given queue.
@param queue The instance of `NSOperationQueue` to run all continuations on.
*/
+ (instancetype)executorWithOperationQueue:(NSOperationQueue *)queue;
/*!
Runs the given block using this executor's particular strategy.
@param block The block to execute.
*/
- (void)execute:(void(^)())block;
@end
NS_ASSUME_NONNULL_END

257
Clocker/Parse/Bolts.framework/Versions/A/Headers/BFTask.h

@ -1,257 +0,0 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFCancellationToken.h>
#import <Bolts/BFDefines.h>
NS_ASSUME_NONNULL_BEGIN
/*!
Error domain used if there was multiple errors on <BFTask taskForCompletionOfAllTasks:>.
*/
extern NSString *const BFTaskErrorDomain;
/*!
An exception that is thrown if there was multiple exceptions on <BFTask taskForCompletionOfAllTasks:>.
*/
extern NSString *const BFTaskMultipleExceptionsException;
@class BFExecutor;
@class BFTask;
/*!
The consumer view of a Task. A BFTask has methods to
inspect the state of the task, and to add continuations to
be run once the task is complete.
*/
@interface BFTask BF_GENERIC(__covariant BFGenericType) : NSObject
/*!
A block that can act as a continuation for a task.
*/
typedef __nullable id(^BFContinuationBlock)(BFTask BF_GENERIC(BFGenericType) *task);
/*!
Creates a task that is already completed with the given result.
@param result The result for the task.
*/
+ (instancetype)taskWithResult:(nullable BFGenericType)result;
/*!
Creates a task that is already completed with the given error.
@param error The error for the task.
*/
+ (instancetype)taskWithError:(NSError *)error;
/*!
Creates a task that is already completed with the given exception.
@param exception The exception for the task.
*/
+ (instancetype)taskWithException:(NSException *)exception;
/*!
Creates a task that is already cancelled.
*/
+ (instancetype)cancelledTask;
/*!
Returns a task that will be completed (with result == nil) once
all of the input tasks have completed.
@param tasks An `NSArray` of the tasks to use as an input.
*/
+ (instancetype)taskForCompletionOfAllTasks:(nullable NSArray *)tasks;
/*!
Returns a task that will be completed once all of the input tasks have completed.
If all tasks complete successfully without being faulted or cancelled the result will be
an `NSArray` of all task results in the order they were provided.
@param tasks An `NSArray` of the tasks to use as an input.
*/
+ (instancetype)taskForCompletionOfAllTasksWithResults:(nullable NSArray *)tasks;
/*!
Returns a task that will be completed a certain amount of time in the future.
@param millis The approximate number of milliseconds to wait before the
task will be finished (with result == nil).
*/
+ (instancetype)taskWithDelay:(int)millis;
/*!
Returns a task that will be completed a certain amount of time in the future.
@param millis The approximate number of milliseconds to wait before the
task will be finished (with result == nil).
@param token The cancellation token (optional).
*/
+ (instancetype)taskWithDelay:(int)millis cancellationToken:(nullable BFCancellationToken *)token;
/*!
Returns a task that will be completed after the given block completes with
the specified executor.
@param executor A BFExecutor responsible for determining how the
continuation block will be run.
@param block The block to immediately schedule to run with the given executor.
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
this method will not be completed until that task is completed.
*/
+ (instancetype)taskFromExecutor:(BFExecutor *)executor withBlock:(id (^)())block;
// Properties that will be set on the task once it is completed.
/*!
The result of a successful task.
*/
@property (nullable, nonatomic, strong, readonly) BFGenericType result;
/*!
The error of a failed task.
*/
@property (nullable, nonatomic, strong, readonly) NSError *error;
/*!
The exception of a failed task.
*/
@property (nullable, nonatomic, strong, readonly) NSException *exception;
/*!
Whether this task has been cancelled.
*/
@property (nonatomic, assign, readonly, getter=isCancelled) BOOL cancelled;
/*!
Whether this task has completed due to an error or exception.
*/
@property (nonatomic, assign, readonly, getter=isFaulted) BOOL faulted;
/*!
Whether this task has completed.
*/
@property (nonatomic, assign, readonly, getter=isCompleted) BOOL completed;
/*!
Enqueues the given block to be run once this task is complete.
This method uses a default execution strategy. The block will be
run on the thread where the previous task completes, unless the
the stack depth is too deep, in which case it will be run on a
dispatch queue with default priority.
@param block The block to be run once this task is complete.
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
this method will not be completed until that task is completed.
*/
- (BFTask *)continueWithBlock:(BFContinuationBlock)block;
/*!
Enqueues the given block to be run once this task is complete.
This method uses a default execution strategy. The block will be
run on the thread where the previous task completes, unless the
the stack depth is too deep, in which case it will be run on a
dispatch queue with default priority.
@param block The block to be run once this task is complete.
@param cancellationToken The cancellation token (optional).
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
this method will not be completed until that task is completed.
*/
- (BFTask *)continueWithBlock:(BFContinuationBlock)block cancellationToken:(nullable BFCancellationToken *)cancellationToken;
/*!
Enqueues the given block to be run once this task is complete.
@param executor A BFExecutor responsible for determining how the
continuation block will be run.
@param block The block to be run once this task is complete.
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
this method will not be completed until that task is completed.
*/
- (BFTask *)continueWithExecutor:(BFExecutor *)executor withBlock:(BFContinuationBlock)block;
/*!
Enqueues the given block to be run once this task is complete.
@param executor A BFExecutor responsible for determining how the
continuation block will be run.
@param block The block to be run once this task is complete.
@param cancellationToken The cancellation token (optional).
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
his method will not be completed until that task is completed.
*/
- (BFTask *)continueWithExecutor:(BFExecutor *)executor
block:(BFContinuationBlock)block
cancellationToken:(nullable BFCancellationToken *)cancellationToken;
/*!
Identical to continueWithBlock:, except that the block is only run
if this task did not produce a cancellation, error, or exception.
If it did, then the failure will be propagated to the returned
task.
@param block The block to be run once this task is complete.
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
this method will not be completed until that task is completed.
*/
- (BFTask *)continueWithSuccessBlock:(BFContinuationBlock)block;
/*!
Identical to continueWithBlock:, except that the block is only run
if this task did not produce a cancellation, error, or exception.
If it did, then the failure will be propagated to the returned
task.
@param block The block to be run once this task is complete.
@param cancellationToken The cancellation token (optional).
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
this method will not be completed until that task is completed.
*/
- (BFTask *)continueWithSuccessBlock:(BFContinuationBlock)block cancellationToken:(nullable BFCancellationToken *)cancellationToken;
/*!
Identical to continueWithExecutor:withBlock:, except that the block
is only run if this task did not produce a cancellation, error, or
exception. If it did, then the failure will be propagated to the
returned task.
@param executor A BFExecutor responsible for determining how the
continuation block will be run.
@param block The block to be run once this task is complete.
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
this method will not be completed until that task is completed.
*/
- (BFTask *)continueWithExecutor:(BFExecutor *)executor withSuccessBlock:(BFContinuationBlock)block;
/*!
Identical to continueWithExecutor:withBlock:, except that the block
is only run if this task did not produce a cancellation, error, or
exception. If it did, then the failure will be propagated to the
returned task.
@param executor A BFExecutor responsible for determining how the
continuation block will be run.
@param block The block to be run once this task is complete.
@param cancellationToken The cancellation token (optional).
@returns A task that will be completed after block has run.
If block returns a BFTask, then the task returned from
this method will not be completed until that task is completed.
*/
- (BFTask *)continueWithExecutor:(BFExecutor *)executor
successBlock:(BFContinuationBlock)block
cancellationToken:(nullable BFCancellationToken *)cancellationToken;
/*!
Waits until this operation is completed.
This method is inefficient and consumes a thread resource while
it's running. It should be avoided. This method logs a warning
message if it is used on the main thread.
*/
- (void)waitUntilFinished;
@end
NS_ASSUME_NONNULL_END

91
Clocker/Parse/Bolts.framework/Versions/A/Headers/BFTaskCompletionSource.h

@ -1,91 +0,0 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFDefines.h>
NS_ASSUME_NONNULL_BEGIN
@class BFTask BF_GENERIC(BFGenericType);
/*!
A BFTaskCompletionSource represents the producer side of tasks.
It is a task that also has methods for changing the state of the
task by settings its completion values.
*/
@interface BFTaskCompletionSource BF_GENERIC(__covariant BFGenericType) : NSObject
/*!
Creates a new unfinished task.
*/
+ (instancetype)taskCompletionSource;
/*!
The task associated with this TaskCompletionSource.
*/
@property (nonatomic, strong, readonly) BFTask BF_GENERIC(BFGenericType) *task;
/*!
Completes the task by setting the result.
Attempting to set this for a completed task will raise an exception.
@param result The result of the task.
*/
- (void)setResult:(nullable BFGenericType)result;
/*!
Completes the task by setting the error.
Attempting to set this for a completed task will raise an exception.
@param error The error for the task.
*/
- (void)setError:(NSError *)error;
/*!
Completes the task by setting an exception.
Attempting to set this for a completed task will raise an exception.
@param exception The exception for the task.
*/
- (void)setException:(NSException *)exception;
/*!
Completes the task by marking it as cancelled.
Attempting to set this for a completed task will raise an exception.
*/
- (void)cancel;
/*!
Sets the result of the task if it wasn't already completed.
@returns whether the new value was set.
*/
- (BOOL)trySetResult:(nullable BFGenericType)result;
/*!
Sets the error of the task if it wasn't already completed.
@param error The error for the task.
@returns whether the new value was set.
*/
- (BOOL)trySetError:(NSError *)error;
/*!
Sets the exception of the task if it wasn't already completed.
@param exception The exception for the task.
@returns whether the new value was set.
*/
- (BOOL)trySetException:(NSException *)exception;
/*!
Sets the cancellation state of the task if it wasn't already completed.
@returns whether the new value was set.
*/
- (BOOL)trySetCancelled;
@end
NS_ASSUME_NONNULL_END

47
Clocker/Parse/Bolts.framework/Versions/A/Headers/Bolts.h

@ -1,47 +0,0 @@
/*
* Copyright (c) 2014, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*
*/
#import <Bolts/BoltsVersion.h>
#import <Bolts/BFCancellationToken.h>
#import <Bolts/BFCancellationTokenRegistration.h>
#import <Bolts/BFCancellationTokenSource.h>
#import <Bolts/BFDefines.h>
#import <Bolts/BFExecutor.h>
#import <Bolts/BFTask.h>
#import <Bolts/BFTaskCompletionSource.h>
#if __has_include(<Bolts/BFAppLink.h>) && TARGET_OS_IPHONE && !TARGET_OS_WATCH && !TARGET_OS_TV
#import <Bolts/BFAppLink.h>
#import <Bolts/BFAppLinkNavigation.h>
#import <Bolts/BFAppLinkResolving.h>
#import <Bolts/BFAppLinkReturnToRefererController.h>
#import <Bolts/BFAppLinkReturnToRefererView.h>
#import <Bolts/BFAppLinkTarget.h>
#import <Bolts/BFMeasurementEvent.h>
#import <Bolts/BFURL.h>
#import <Bolts/BFWebViewAppLinkResolver.h>
#endif
NS_ASSUME_NONNULL_BEGIN
/*! @abstract 80175001: There were multiple errors. */
extern NSInteger const kBFMultipleErrorsError;
@interface Bolts : NSObject
/*!
Returns the version of the Bolts Framework as an NSString.
@returns The NSString representation of the current version.
*/
+ (NSString *)version;
@end
NS_ASSUME_NONNULL_END

1
Clocker/Parse/Bolts.framework/Versions/A/Headers/BoltsVersion.h

@ -1 +0,0 @@
#define BOLTS_VERSION @"1.5.0"

6
Clocker/Parse/Bolts.framework/Versions/A/Modules/module.modulemap

@ -1,6 +0,0 @@
framework module Bolts {
umbrella header "Bolts.h"
export *
module * { export * }
}

44
Clocker/Parse/Bolts.framework/Versions/A/Resources/Info.plist

@ -1,44 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>BuildMachineOSBuild</key>
<string>15C50</string>
<key>CFBundleDevelopmentRegion</key>
<string>en</string>
<key>CFBundleExecutable</key>
<string>Bolts</string>
<key>CFBundleIdentifier</key>
<string>com.bolts.boltsmac</string>
<key>CFBundleInfoDictionaryVersion</key>
<string>6.0</string>
<key>CFBundleName</key>
<string>Bolts</string>
<key>CFBundlePackageType</key>
<string>FMWK</string>
<key>CFBundleShortVersionString</key>
<string>1.5.0</string>
<key>CFBundleSignature</key>
<string>????</string>
<key>CFBundleSupportedPlatforms</key>
<array>
<string>MacOSX</string>
</array>
<key>CFBundleVersion</key>
<string>1.5.0</string>
<key>DTCompiler</key>
<string>com.apple.compilers.llvm.clang.1_0</string>
<key>DTPlatformBuild</key>
<string>7C68</string>
<key>DTPlatformVersion</key>
<string>GM</string>
<key>DTSDKBuild</key>
<string>15C43</string>
<key>DTSDKName</key>
<string>macosx10.11</string>
<key>DTXcode</key>
<string>0720</string>
<key>DTXcodeBuild</key>
<string>7C68</string>
</dict>
</plist>

1
Clocker/Parse/Bolts.framework/Versions/Current

@ -1 +0,0 @@
A

1
Clocker/Parse/Parse.framework/Headers

@ -1 +0,0 @@
Versions/Current/Headers

1
Clocker/Parse/Parse.framework/Modules

@ -1 +0,0 @@
Versions/Current/Modules

1
Clocker/Parse/Parse.framework/Parse

@ -1 +0,0 @@
Versions/Current/Parse

1
Clocker/Parse/Parse.framework/Resources

@ -1 +0,0 @@
Versions/Current/Resources

244
Clocker/Parse/Parse.framework/Versions/A/Headers/PFACL.h

@ -1,244 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
NS_ASSUME_NONNULL_BEGIN
@class PFRole;
@class PFUser;
/**
The `PFACL` class is used to control which users can access or modify a particular object.
Each `PFObject` can have its own `PFACL`. You can grant read and write permissions separately to specific users,
to groups of users that belong to roles, or you can grant permissions to "the public" so that,
for example, any user could read a particular object but only a particular set of users could write to that object.
*/
@interface PFACL : NSObject <NSCopying, NSCoding>
///--------------------------------------
/// @name Creating an ACL
///--------------------------------------
/**
Creates an ACL with no permissions granted.
@return Returns a new `PFACL`.
*/
+ (instancetype)ACL;
/**
Creates an ACL where only the provided user has access.
@param user The user to assign access.
*/
+ (instancetype)ACLWithUser:(PFUser *)user;
///--------------------------------------
/// @name Controlling Public Access
///--------------------------------------
/**
Controls whether the public is allowed to read this object.
*/
@property (nonatomic, assign, getter=getPublicReadAccess) BOOL publicReadAccess;
/**
Controls whether the public is allowed to write this object.
*/
@property (nonatomic, assign, getter=getPublicWriteAccess) BOOL publicWriteAccess;
///--------------------------------------
/// @name Controlling Access Per-User
///--------------------------------------
/**
Set whether the given user id is allowed to read this object.
@param allowed Whether the given user can write this object.
@param userId The `PFObject.objectId` of the user to assign access.
*/
- (void)setReadAccess:(BOOL)allowed forUserId:(NSString *)userId;
/**
Gets whether the given user id is *explicitly* allowed to read this object.
Even if this returns `NO`, the user may still be able to access it if `publicReadAccess` returns `YES`
or if the user belongs to a role that has access.
@param userId The `PFObject.objectId` of the user for which to retrive access.
@return `YES` if the user with this `objectId` has *explicit* read access, otherwise `NO`.
*/
- (BOOL)getReadAccessForUserId:(NSString *)userId;
/**
Set whether the given user id is allowed to write this object.
@param allowed Whether the given user can read this object.
@param userId The `PFObject.objectId` of the user to assign access.
*/
- (void)setWriteAccess:(BOOL)allowed forUserId:(NSString *)userId;
/**
Gets whether the given user id is *explicitly* allowed to write this object.
Even if this returns NO, the user may still be able to write it if `publicWriteAccess` returns `YES`
or if the user belongs to a role that has access.
@param userId The `PFObject.objectId` of the user for which to retrive access.
@return `YES` if the user with this `PFObject.objectId` has *explicit* write access, otherwise `NO`.
*/
- (BOOL)getWriteAccessForUserId:(NSString *)userId;
/**
Set whether the given user is allowed to read this object.
@param allowed Whether the given user can read this object.
@param user The user to assign access.
*/
- (void)setReadAccess:(BOOL)allowed forUser:(PFUser *)user;
/**
Gets whether the given user is *explicitly* allowed to read this object.
Even if this returns `NO`, the user may still be able to access it if `publicReadAccess` returns `YES`
or if the user belongs to a role that has access.
@param user The user for which to retrive access.
@return `YES` if the user has *explicit* read access, otherwise `NO`.
*/
- (BOOL)getReadAccessForUser:(PFUser *)user;
/**
Set whether the given user is allowed to write this object.
@param allowed Whether the given user can write this object.
@param user The user to assign access.
*/
- (void)setWriteAccess:(BOOL)allowed forUser:(PFUser *)user;
/**
Gets whether the given user is *explicitly* allowed to write this object.
Even if this returns `NO`, the user may still be able to write it if `publicWriteAccess` returns `YES`
or if the user belongs to a role that has access.
@param user The user for which to retrive access.
@return `YES` if the user has *explicit* write access, otherwise `NO`.
*/
- (BOOL)getWriteAccessForUser:(PFUser *)user;
///--------------------------------------
/// @name Controlling Access Per-Role
///--------------------------------------
/**
Get whether users belonging to the role with the given name are allowed to read this object.
Even if this returns `NO`, the role may still be able to read it if a parent role has read access.
@param name The name of the role.
@return `YES` if the role has read access, otherwise `NO`.
*/
- (BOOL)getReadAccessForRoleWithName:(NSString *)name;
/**
Set whether users belonging to the role with the given name are allowed to read this object.
@param allowed Whether the given role can read this object.
@param name The name of the role.
*/
- (void)setReadAccess:(BOOL)allowed forRoleWithName:(NSString *)name;
/**
Get whether users belonging to the role with the given name are allowed to write this object.
Even if this returns `NO`, the role may still be able to write it if a parent role has write access.
@param name The name of the role.
@return `YES` if the role has read access, otherwise `NO`.
*/
- (BOOL)getWriteAccessForRoleWithName:(NSString *)name;
/**
Set whether users belonging to the role with the given name are allowed to write this object.
@param allowed Whether the given role can write this object.
@param name The name of the role.
*/
- (void)setWriteAccess:(BOOL)allowed forRoleWithName:(NSString *)name;
/**
Get whether users belonging to the given role are allowed to read this object.
Even if this returns `NO`, the role may still be able to read it if a parent role has read access.
The role must already be saved on the server and
it's data must have been fetched in order to use this method.
@param role The name of the role.
@return `YES` if the role has read access, otherwise `NO`.
*/
- (BOOL)getReadAccessForRole:(PFRole *)role;
/**
Set whether users belonging to the given role are allowed to read this object.
The role must already be saved on the server and
it's data must have been fetched in order to use this method.
@param allowed Whether the given role can read this object.
@param role The role to assign access.
*/
- (void)setReadAccess:(BOOL)allowed forRole:(PFRole *)role;
/**
Get whether users belonging to the given role are allowed to write this object.
Even if this returns `NO`, the role may still be able to write it if a parent role has write access.
The role must already be saved on the server and
it's data must have been fetched in order to use this method.
@param role The name of the role.
@return `YES` if the role has write access, otherwise `NO`.
*/
- (BOOL)getWriteAccessForRole:(PFRole *)role;
/**
Set whether users belonging to the given role are allowed to write this object.
The role must already be saved on the server and
it's data must have been fetched in order to use this method.
@param allowed Whether the given role can write this object.
@param role The role to assign access.
*/
- (void)setWriteAccess:(BOOL)allowed forRole:(PFRole *)role;
///--------------------------------------
/// @name Setting Access Defaults
///--------------------------------------
/**
Sets a default ACL that will be applied to all instances of `PFObject` when they are created.
@param acl The ACL to use as a template for all instance of `PFObject` created after this method has been called.
This value will be copied and used as a template for the creation of new ACLs, so changes to the
instance after this method has been called will not be reflected in new instance of `PFObject`.
@param currentUserAccess - If `YES`, the `PFACL` that is applied to newly-created instance of `PFObject` will
provide read and write access to the `PFUser.+currentUser` at the time of creation.
- If `NO`, the provided `acl` will be used without modification.
- If `acl` is `nil`, this value is ignored.
*/
+ (void)setDefaultACL:(nullable PFACL *)acl withAccessForCurrentUser:(BOOL)currentUserAccess;
@end
NS_ASSUME_NONNULL_END

167
Clocker/Parse/Parse.framework/Versions/A/Headers/PFAnalytics.h

@ -1,167 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
NS_ASSUME_NONNULL_BEGIN
/**
`PFAnalytics` provides an interface to Parse's logging and analytics backend.
Methods will return immediately and cache the request (+ timestamp) to be
handled "eventually." That is, the request will be sent immediately if possible
or the next time a network connection is available.
*/
@interface PFAnalytics : NSObject
///--------------------------------------
/// @name App-Open / Push Analytics
///--------------------------------------
/**
Tracks this application being launched. If this happened as the result of the
user opening a push notification, this method sends along information to
correlate this open with that push.
Pass in `nil` to track a standard "application opened" event.
@param launchOptions The `NSDictionary` indicating the reason the application was
launched, if any. This value can be found as a parameter to various
`UIApplicationDelegate` methods, and can be empty or `nil`.
@return Returns the task encapsulating the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)trackAppOpenedWithLaunchOptions:(nullable NSDictionary *)launchOptions;
/**
Tracks this application being launched.
If this happened as the result of the user opening a push notification,
this method sends along information to correlate this open with that push.
Pass in `nil` to track a standard "application opened" event.
@param launchOptions The dictionary indicating the reason the application was
launched, if any. This value can be found as a parameter to various
`UIApplicationDelegate` methods, and can be empty or `nil`.
@param block The block to execute on server response.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)trackAppOpenedWithLaunchOptionsInBackground:(nullable NSDictionary *)launchOptions
block:(nullable PFBooleanResultBlock)block;
/**
Tracks this application being launched. If this happened as the result of the
user opening a push notification, this method sends along information to
correlate this open with that push.
@param userInfo The Remote Notification payload, if any. This value can be
found either under `UIApplicationLaunchOptionsRemoteNotificationKey` on `launchOptions`,
or as a parameter to `application:didReceiveRemoteNotification:`.
This can be empty or `nil`.
@return Returns the task encapsulating the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)trackAppOpenedWithRemoteNotificationPayload:(nullable NSDictionary *)userInfo;
/**
Tracks this application being launched. If this happened as the result of the
user opening a push notification, this method sends along information to
correlate this open with that push.
@param userInfo The Remote Notification payload, if any. This value can be
found either under `UIApplicationLaunchOptionsRemoteNotificationKey` on `launchOptions`,
or as a parameter to `application:didReceiveRemoteNotification:`. This can be empty or `nil`.
@param block The block to execute on server response.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)trackAppOpenedWithRemoteNotificationPayloadInBackground:(nullable NSDictionary *)userInfo
block:(nullable PFBooleanResultBlock)block;
///--------------------------------------
/// @name Custom Analytics
///--------------------------------------
/**
Tracks the occurrence of a custom event.
Parse will store a data point at the time of invocation with the given event name.
@param name The name of the custom event to report to Parse as having happened.
@return Returns the task encapsulating the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)trackEvent:(NSString *)name;
/**
Tracks the occurrence of a custom event. Parse will store a data point at the
time of invocation with the given event name. The event will be sent at some
unspecified time in the future, even if Parse is currently inaccessible.
@param name The name of the custom event to report to Parse as having happened.
@param block The block to execute on server response.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)trackEventInBackground:(NSString *)name block:(nullable PFBooleanResultBlock)block;
/**
Tracks the occurrence of a custom event with additional dimensions. Parse will
store a data point at the time of invocation with the given event name.
Dimensions will allow segmentation of the occurrences of this custom event.
Keys and values should be NSStrings, and will throw otherwise.
To track a user signup along with additional metadata, consider the following:
NSDictionary *dimensions = @{ @"gender": @"m",
@"source": @"web",
@"dayType": @"weekend" };
[PFAnalytics trackEvent:@"signup" dimensions:dimensions];
@warning There is a default limit of 8 dimensions per event tracked.
@param name The name of the custom event to report to Parse as having happened.
@param dimensions The `NSDictionary` of information by which to segment this event.
@return Returns the task encapsulating the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)trackEvent:(NSString *)name
dimensions:(nullable NSDictionary PF_GENERIC(NSString *, NSString *)*)dimensions;
/**
Tracks the occurrence of a custom event with additional dimensions. Parse will
store a data point at the time of invocation with the given event name. The
event will be sent at some unspecified time in the future, even if Parse is currently inaccessible.
@discussionDimensions will allow segmentation of the occurrences of this custom event.
Keys and values should be NSStrings, and will throw otherwise.
To track a user signup along with additional metadata, consider the following:
NSDictionary *dimensions = @{ @"gender": @"m",
@"source": @"web",
@"dayType": @"weekend" };
[PFAnalytics trackEvent:@"signup" dimensions:dimensions];
There is a default limit of 8 dimensions per event tracked.
@param name The name of the custom event to report to Parse as having happened.
@param dimensions The `NSDictionary` of information by which to segment this event.
@param block The block to execute on server response.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)trackEventInBackground:(NSString *)name
dimensions:(nullable NSDictionary PF_GENERIC(NSString *, NSString *)*)dimensions
block:(nullable PFBooleanResultBlock)block;
@end
NS_ASSUME_NONNULL_END

82
Clocker/Parse/Parse.framework/Versions/A/Headers/PFAnonymousUtils.h

@ -1,82 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
#import <Parse/PFUser.h>
NS_ASSUME_NONNULL_BEGIN
/**
Provides utility functions for working with Anonymously logged-in users.
Anonymous users have some unique characteristics:
- Anonymous users don't need a user name or password.
- Once logged out, an anonymous user cannot be recovered.
- When the current user is anonymous, the following methods can be used to switch
to a different user or convert the anonymous user into a regular one:
- signUp converts an anonymous user to a standard user with the given username and password.
Data associated with the anonymous user is retained.
- logIn switches users without converting the anonymous user.
Data associated with the anonymous user will be lost.
- Service logIn (e.g. Facebook, Twitter) will attempt to convert
the anonymous user into a standard user by linking it to the service.
If a user already exists that is linked to the service, it will instead switch to the existing user.
- Service linking (e.g. Facebook, Twitter) will convert the anonymous user
into a standard user by linking it to the service.
*/
@interface PFAnonymousUtils : NSObject
///--------------------------------------
/// @name Creating an Anonymous User
///--------------------------------------
/**
Creates an anonymous user asynchronously and sets as a result to `BFTask`.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(PFUser *)*)logInInBackground;
/**
Creates an anonymous user.
@param block The block to execute when anonymous user creation is complete.
It should have the following argument signature: `^(PFUser *user, NSError *error)`.
*/
+ (void)logInWithBlock:(nullable PFUserResultBlock)block;
/*
Creates an anonymous user.
@param target Target object for the selector.
@param selector The selector that will be called when the asynchronous request is complete.
It should have the following signature: `(void)callbackWithUser:(PFUser *)user error:(NSError *)error`.
*/
+ (void)logInWithTarget:(nullable id)target selector:(nullable SEL)selector;
///--------------------------------------
/// @name Determining Whether a User is Anonymous
///--------------------------------------
/**
Whether the `PFUser` object is logged in anonymously.
@param user `PFUser` object to check for anonymity. The user must be logged in on this device.
@return `YES` if the user is anonymous. `NO` if the user is not the current user or is not anonymous.
*/
+ (BOOL)isLinkedWithUser:(nullable PFUser *)user;
@end
NS_ASSUME_NONNULL_END

90
Clocker/Parse/Parse.framework/Versions/A/Headers/PFCloud.h

@ -1,90 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
NS_ASSUME_NONNULL_BEGIN
/**
The `PFCloud` class provides methods for interacting with Parse Cloud Functions.
*/
@interface PFCloud : NSObject
/**
Calls the given cloud function *synchronously* with the parameters provided.
@param function The function name to call.
@param parameters The parameters to send to the function.
@return The response from the cloud function.
*/
+ (nullable id)callFunction:(NSString *)function withParameters:(nullable NSDictionary *)parameters PF_SWIFT_UNAVAILABLE;
/**
Calls the given cloud function *synchronously* with the parameters provided and
sets the error if there is one.
@param function The function name to call.
@param parameters The parameters to send to the function.
@param error Pointer to an `NSError` that will be set if necessary.
@return The response from the cloud function.
This result could be a `NSDictionary`, an `NSArray`, `NSNumber` or `NSString`.
*/
+ (nullable id)callFunction:(NSString *)function
withParameters:(nullable NSDictionary *)parameters
error:(NSError **)error;
/**
Calls the given cloud function *asynchronously* with the parameters provided.
@param function The function name to call.
@param parameters The parameters to send to the function.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(id) *)callFunctionInBackground:(NSString *)function
withParameters:(nullable NSDictionary *)parameters;
/**
Calls the given cloud function *asynchronously* with the parameters provided
and executes the given block when it is done.
@param function The function name to call.
@param parameters The parameters to send to the function.
@param block The block to execute when the function call finished.
It should have the following argument signature: `^(id result, NSError *error)`.
*/
+ (void)callFunctionInBackground:(NSString *)function
withParameters:(nullable NSDictionary *)parameters
block:(nullable PFIdResultBlock)block;
/*
Calls the given cloud function *asynchronously* with the parameters provided
and then executes the given selector when it is done.
@param function The function name to call.
@param parameters The parameters to send to the function.
@param target The object to call the selector on.
@param selector The selector to call when the function call finished.
It should have the following signature: `(void)callbackWithResult:(id)result error:(NSError *)error`.
Result will be `nil` if error is set and vice versa.
*/
+ (void)callFunctionInBackground:(NSString *)function
withParameters:(nullable NSDictionary *)parameters
target:(nullable id)target
selector:(nullable SEL)selector;
@end
NS_ASSUME_NONNULL_END

105
Clocker/Parse/Parse.framework/Versions/A/Headers/PFConfig.h

@ -1,105 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
NS_ASSUME_NONNULL_BEGIN
@class PFConfig;
typedef void(^PFConfigResultBlock)(PFConfig *__nullable config, NSError *__nullable error);
/**
`PFConfig` is a representation of the remote configuration object.
It enables you to add things like feature gating, a/b testing or simple "Message of the day".
*/
@interface PFConfig : NSObject
///--------------------------------------
/// @name Current Config
///--------------------------------------
/**
Returns the most recently fetched config.
If there was no config fetched - this method will return an empty instance of `PFConfig`.
@return Current, last fetched instance of PFConfig.
*/
+ (PFConfig *)currentConfig;
///--------------------------------------
/// @name Retrieving Config
///--------------------------------------
/**
Gets the `PFConfig` object *synchronously* from the server.
@return Instance of `PFConfig` if the operation succeeded, otherwise `nil`.
*/
+ (nullable PFConfig *)getConfig PF_SWIFT_UNAVAILABLE;
/**
Gets the `PFConfig` object *synchronously* from the server and sets an error if it occurs.
@param error Pointer to an `NSError` that will be set if necessary.
@return Instance of PFConfig if the operation succeeded, otherwise `nil`.
*/
+ (nullable PFConfig *)getConfig:(NSError **)error;
/**
Gets the `PFConfig` *asynchronously* and sets it as a result of a task.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(PFConfig *)*)getConfigInBackground;
/**
Gets the `PFConfig` *asynchronously* and executes the given callback block.
@param block The block to execute.
It should have the following argument signature: `^(PFConfig *config, NSError *error)`.
*/
+ (void)getConfigInBackgroundWithBlock:(nullable PFConfigResultBlock)block;
///--------------------------------------
/// @name Parameters
///--------------------------------------
/**
Returns the object associated with a given key.
@param key The key for which to return the corresponding configuration value.
@return The value associated with `key`, or `nil` if there is no such value.
*/
- (nullable id)objectForKey:(NSString *)key;
/**
Returns the object associated with a given key.
This method enables usage of literal syntax on `PFConfig`.
E.g. `NSString *value = config[@"key"];`
@see objectForKey:
@param keyedSubscript The keyed subscript for which to return the corresponding configuration value.
@return The value associated with `key`, or `nil` if there is no such value.
*/
- (nullable id)objectForKeyedSubscript:(NSString *)keyedSubscript;
@end
NS_ASSUME_NONNULL_END

557
Clocker/Parse/Parse.framework/Versions/A/Headers/PFConstants.h

@ -1,557 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
@class PFObject;
@class PFUser;
///--------------------------------------
/// @name Version
///--------------------------------------
#define PARSE_VERSION @"1.11.0"
extern NSInteger const PARSE_API_VERSION;
///--------------------------------------
/// @name Platform
///--------------------------------------
#define PARSE_IOS_ONLY (TARGET_OS_IPHONE)
#define PARSE_OSX_ONLY (TARGET_OS_MAC && !(TARGET_OS_IPHONE))
extern NSString *const __nonnull kPFDeviceType;
///--------------------------------------
/// @name Server
///--------------------------------------
extern NSString *const __nonnull kPFParseServer;
///--------------------------------------
/// @name Cache Policies
///--------------------------------------
/**
`PFCachePolicy` specifies different caching policies that could be used with `PFQuery`.
This lets you show data when the user's device is offline,
or when the app has just started and network requests have not yet had time to complete.
Parse takes care of automatically flushing the cache when it takes up too much space.
@warning Cache policy could only be set when Local Datastore is not enabled.
@see PFQuery
*/
typedef NS_ENUM(uint8_t, PFCachePolicy) {
/**
The query does not load from the cache or save results to the cache.
This is the default cache policy.
*/
kPFCachePolicyIgnoreCache = 0,
/**
The query only loads from the cache, ignoring the network.
If there are no cached results, this causes a `NSError` with `kPFErrorCacheMiss` code.
*/
kPFCachePolicyCacheOnly,
/**
The query does not load from the cache, but it will save results to the cache.
*/
kPFCachePolicyNetworkOnly,
/**
The query first tries to load from the cache, but if that fails, it loads results from the network.
If there are no cached results, this causes a `NSError` with `kPFErrorCacheMiss` code.
*/
kPFCachePolicyCacheElseNetwork,
/**
The query first tries to load from the network, but if that fails, it loads results from the cache.
If there are no cached results, this causes a `NSError` with `kPFErrorCacheMiss` code.
*/
kPFCachePolicyNetworkElseCache,
/**
The query first loads from the cache, then loads from the network.
The callback will be called twice - first with the cached results, then with the network results.
Since it returns two results at different times, this cache policy cannot be used with synchronous or task methods.
*/
kPFCachePolicyCacheThenNetwork
};
///--------------------------------------
/// @name Logging Levels
///--------------------------------------
/**
`PFLogLevel` enum specifies different levels of logging that could be used to limit or display more messages in logs.
@see `Parse.+setLogLevel:`
@see `Parse.+logLevel`
*/
typedef NS_ENUM(uint8_t, PFLogLevel) {
/**
Log level that disables all logging.
*/
PFLogLevelNone = 0,
/**
Log level that if set is going to output error messages to the log.
*/
PFLogLevelError = 1,
/**
Log level that if set is going to output the following messages to log:
- Errors
- Warnings
*/
PFLogLevelWarning = 2,
/**
Log level that if set is going to output the following messages to log:
- Errors
- Warnings
- Informational messages
*/
PFLogLevelInfo = 3,
/**
Log level that if set is going to output the following messages to log:
- Errors
- Warnings
- Informational messages
- Debug messages
*/
PFLogLevelDebug = 4
};
///--------------------------------------
/// @name Errors
///--------------------------------------
extern NSString *const __nonnull PFParseErrorDomain;
/**
`PFErrorCode` enum contains all custom error codes that are used as `code` for `NSError` for callbacks on all classes.
These codes are used when `domain` of `NSError` that you receive is set to `PFParseErrorDomain`.
*/
typedef NS_ENUM(NSInteger, PFErrorCode) {
/**
Internal server error. No information available.
*/
kPFErrorInternalServer = 1,
/**
The connection to the Parse servers failed.
*/
kPFErrorConnectionFailed = 100,
/**
Object doesn't exist, or has an incorrect password.
*/
kPFErrorObjectNotFound = 101,
/**
You tried to find values matching a datatype that doesn't
support exact database matching, like an array or a dictionary.
*/
kPFErrorInvalidQuery = 102,
/**
Missing or invalid classname. Classnames are case-sensitive.
They must start with a letter, and `a-zA-Z0-9_` are the only valid characters.
*/
kPFErrorInvalidClassName = 103,
/**
Missing object id.
*/
kPFErrorMissingObjectId = 104,
/**
Invalid key name. Keys are case-sensitive.
They must start with a letter, and `a-zA-Z0-9_` are the only valid characters.
*/
kPFErrorInvalidKeyName = 105,
/**
Malformed pointer. Pointers must be arrays of a classname and an object id.
*/
kPFErrorInvalidPointer = 106,
/**
Malformed json object. A json dictionary is expected.
*/
kPFErrorInvalidJSON = 107,
/**
Tried to access a feature only available internally.
*/
kPFErrorCommandUnavailable = 108,
/**
Field set to incorrect type.
*/
kPFErrorIncorrectType = 111,
/**
Invalid channel name. A channel name is either an empty string (the broadcast channel)
or contains only `a-zA-Z0-9_` characters and starts with a letter.
*/
kPFErrorInvalidChannelName = 112,
/**
Invalid device token.
*/
kPFErrorInvalidDeviceToken = 114,
/**
Push is misconfigured. See details to find out how.
*/
kPFErrorPushMisconfigured = 115,
/**
The object is too large.
*/
kPFErrorObjectTooLarge = 116,
/**
That operation isn't allowed for clients.
*/
kPFErrorOperationForbidden = 119,
/**
The results were not found in the cache.
*/
kPFErrorCacheMiss = 120,
/**
Keys in `NSDictionary` values may not include `$` or `.`.
*/
kPFErrorInvalidNestedKey = 121,
/**
Invalid file name.
A file name can contain only `a-zA-Z0-9_.` characters and should be between 1 and 36 characters.
*/
kPFErrorInvalidFileName = 122,
/**
Invalid ACL. An ACL with an invalid format was saved. This should not happen if you use `PFACL`.
*/
kPFErrorInvalidACL = 123,
/**
The request timed out on the server. Typically this indicates the request is too expensive.
*/
kPFErrorTimeout = 124,
/**
The email address was invalid.
*/
kPFErrorInvalidEmailAddress = 125,
/**
A unique field was given a value that is already taken.
*/
kPFErrorDuplicateValue = 137,
/**
Role's name is invalid.
*/
kPFErrorInvalidRoleName = 139,
/**
Exceeded an application quota. Upgrade to resolve.
*/
kPFErrorExceededQuota = 140,
/**
Cloud Code script had an error.
*/
kPFScriptError = 141,
/**
Cloud Code validation failed.
*/
kPFValidationError = 142,
/**
Product purchase receipt is missing.
*/
kPFErrorReceiptMissing = 143,
/**
Product purchase receipt is invalid.
*/
kPFErrorInvalidPurchaseReceipt = 144,
/**
Payment is disabled on this device.
*/
kPFErrorPaymentDisabled = 145,
/**
The product identifier is invalid.
*/
kPFErrorInvalidProductIdentifier = 146,
/**
The product is not found in the App Store.
*/
kPFErrorProductNotFoundInAppStore = 147,
/**
The Apple server response is not valid.
*/
kPFErrorInvalidServerResponse = 148,
/**
Product fails to download due to file system error.
*/
kPFErrorProductDownloadFileSystemFailure = 149,
/**
Fail to convert data to image.
*/
kPFErrorInvalidImageData = 150,
/**
Unsaved file.
*/
kPFErrorUnsavedFile = 151,
/**
Fail to delete file.
*/
kPFErrorFileDeleteFailure = 153,
/**
Application has exceeded its request limit.
*/
kPFErrorRequestLimitExceeded = 155,
/**
Invalid event name.
*/
kPFErrorInvalidEventName = 160,
/**
Username is missing or empty.
*/
kPFErrorUsernameMissing = 200,
/**
Password is missing or empty.
*/
kPFErrorUserPasswordMissing = 201,
/**
Username has already been taken.
*/
kPFErrorUsernameTaken = 202,
/**
Email has already been taken.
*/
kPFErrorUserEmailTaken = 203,
/**
The email is missing, and must be specified.
*/
kPFErrorUserEmailMissing = 204,
/**
A user with the specified email was not found.
*/
kPFErrorUserWithEmailNotFound = 205,
/**
The user cannot be altered by a client without the session.
*/
kPFErrorUserCannotBeAlteredWithoutSession = 206,
/**
Users can only be created through sign up.
*/
kPFErrorUserCanOnlyBeCreatedThroughSignUp = 207,
/**
An existing Facebook account already linked to another user.
*/
kPFErrorFacebookAccountAlreadyLinked = 208,
/**
An existing account already linked to another user.
*/
kPFErrorAccountAlreadyLinked = 208,
/**
Error code indicating that the current session token is invalid.
*/
kPFErrorInvalidSessionToken = 209,
kPFErrorUserIdMismatch = 209,
/**
Facebook id missing from request.
*/
kPFErrorFacebookIdMissing = 250,
/**
Linked id missing from request.
*/
kPFErrorLinkedIdMissing = 250,
/**
Invalid Facebook session.
*/
kPFErrorFacebookInvalidSession = 251,
/**
Invalid linked session.
*/
kPFErrorInvalidLinkedSession = 251,
};
///--------------------------------------
/// @name Blocks
///--------------------------------------
typedef void (^PFBooleanResultBlock)(BOOL succeeded, NSError *__nullable error);
typedef void (^PFIntegerResultBlock)(int number, NSError *__nullable error);
typedef void (^PFArrayResultBlock)(NSArray *__nullable objects, NSError *__nullable error);
typedef void (^PFObjectResultBlock)(PFObject *__nullable object, NSError *__nullable error);
typedef void (^PFSetResultBlock)(NSSet *__nullable channels, NSError *__nullable error);
typedef void (^PFUserResultBlock)(PFUser *__nullable user, NSError *__nullable error);
typedef void (^PFDataResultBlock)(NSData *__nullable data, NSError *__nullable error);
typedef void (^PFDataStreamResultBlock)(NSInputStream *__nullable stream, NSError *__nullable error);
typedef void (^PFFilePathResultBlock)(NSString *__nullable filePath, NSError *__nullable error);
typedef void (^PFStringResultBlock)(NSString *__nullable string, NSError *__nullable error);
typedef void (^PFIdResultBlock)(__nullable id object, NSError *__nullable error);
typedef void (^PFProgressBlock)(int percentDone);
///--------------------------------------
/// @name Network Notifications
///--------------------------------------
/**
The name of the notification that is going to be sent before any URL request is sent.
*/
extern NSString *const __nonnull PFNetworkWillSendURLRequestNotification;
/**
The name of the notification that is going to be sent after any URL response is received.
*/
extern NSString *const __nonnull PFNetworkDidReceiveURLResponseNotification;
/**
The key of request(NSURLRequest) in the userInfo dictionary of a notification.
@note This key is populated in userInfo, only if `PFLogLevel` on `Parse` is set to `PFLogLevelDebug`.
*/
extern NSString *const __nonnull PFNetworkNotificationURLRequestUserInfoKey;
/**
The key of response(NSHTTPURLResponse) in the userInfo dictionary of a notification.
@note This key is populated in userInfo, only if `PFLogLevel` on `Parse` is set to `PFLogLevelDebug`.
*/
extern NSString *const __nonnull PFNetworkNotificationURLResponseUserInfoKey;
/**
The key of repsonse body (usually `NSString` with JSON) in the userInfo dictionary of a notification.
@note This key is populated in userInfo, only if `PFLogLevel` on `Parse` is set to `PFLogLevelDebug`.
*/
extern NSString *const __nonnull PFNetworkNotificationURLResponseBodyUserInfoKey;
///--------------------------------------
/// @name Deprecated Macros
///--------------------------------------
#ifndef PARSE_DEPRECATED
# ifdef __deprecated_msg
# define PARSE_DEPRECATED(_MSG) __deprecated_msg(_MSG)
# else
# ifdef __deprecated
# define PARSE_DEPRECATED(_MSG) __attribute__((deprecated))
# else
# define PARSE_DEPRECATED(_MSG)
# endif
# endif
#endif
///--------------------------------------
/// @name Extensions Macros
///--------------------------------------
#ifndef PF_EXTENSION_UNAVAILABLE
# if PARSE_IOS_ONLY
# ifdef NS_EXTENSION_UNAVAILABLE_IOS
# define PF_EXTENSION_UNAVAILABLE(_msg) NS_EXTENSION_UNAVAILABLE_IOS(_msg)
# else
# define PF_EXTENSION_UNAVAILABLE(_msg)
# endif
# else
# ifdef NS_EXTENSION_UNAVAILABLE_MAC
# define PF_EXTENSION_UNAVAILABLE(_msg) NS_EXTENSION_UNAVAILABLE_MAC(_msg)
# else
# define PF_EXTENSION_UNAVAILABLE(_msg)
# endif
# endif
#endif
///--------------------------------------
/// @name Swift Macros
///--------------------------------------
#ifndef PF_SWIFT_UNAVAILABLE
# ifdef NS_SWIFT_UNAVAILABLE
# define PF_SWIFT_UNAVAILABLE NS_SWIFT_UNAVAILABLE("")
# else
# define PF_SWIFT_UNAVAILABLE
# endif
#endif
///--------------------------------------
/// @name Obj-C Generics Macros
///--------------------------------------
#if __has_feature(objc_generics) || __has_extension(objc_generics)
# define PF_GENERIC(...) <__VA_ARGS__>
#else
# define PF_GENERIC(...)
# define PFGenericObject PFObject *
#endif
///--------------------------------------
/// @name Platform Availability Defines
///--------------------------------------
#ifndef TARGET_OS_IOS
# define TARGET_OS_IOS TARGET_OS_IPHONE
#endif
#ifndef TARGET_OS_WATCH
# define TARGET_OS_WATCH 0
#endif
#ifndef TARGET_OS_TV
# define TARGET_OS_TV 0
#endif
#ifndef PF_TARGET_OS_OSX
# define PF_TARGET_OS_OSX TARGET_OS_MAC && !TARGET_OS_IOS && !TARGET_OS_WATCH && !TARGET_OS_TV
#endif
///--------------------------------------
/// @name Avaiability Macros
///--------------------------------------
#ifndef PF_IOS_UNAVAILABLE
# ifdef __IOS_UNAVILABLE
# define PF_IOS_UNAVAILABLE __IOS_UNAVAILABLE
# else
# define PF_IOS_UNAVAILABLE
# endif
#endif
#ifndef PF_IOS_UNAVAILABLE_WARNING
# if TARGET_OS_IOS
# define PF_IOS_UNAVAILABLE_WARNING _Pragma("GCC warning \"This file is unavailable on iOS.\"")
# else
# define PF_IOS_UNAVAILABLE_WARNING
# endif
#endif
#ifndef PF_OSX_UNAVAILABLE
# if PF_TARGET_OS_OSX
# define PF_OSX_UNAVAILABLE __OSX_UNAVAILABLE
# else
# define PF_OSX_UNAVAILABLE
# endif
#endif
#ifndef PF_OSX_UNAVAILABLE_WARNING
# if PF_TARGET_OS_OSX
# define PF_OSX_UNAVAILABLE_WARNING _Pragma("GCC warning \"This file is unavailable on OS X.\"")
# else
# define PF_OSX_UNAVAILABLE_WARNING
# endif
#endif
#ifndef PF_WATCH_UNAVAILABLE
# ifdef __WATCHOS_UNAVAILABLE
# define PF_WATCH_UNAVAILABLE __WATCHOS_UNAVAILABLE
# else
# define PF_WATCH_UNAVAILABLE
# endif
#endif
#ifndef PF_WATCH_UNAVAILABLE_WARNING
# if TARGET_OS_WATCH
# define PF_WATCH_UNAVAILABLE_WARNING _Pragma("GCC warning \"This file is unavailable on watchOS.\"")
# else
# define PF_WATCH_UNAVAILABLE_WARNING
# endif
#endif
#ifndef PF_TV_UNAVAILABLE
# ifdef __TVOS_PROHIBITED
# define PF_TV_UNAVAILABLE __TVOS_PROHIBITED
# else
# define PF_TV_UNAVAILABLE
# endif
#endif
#ifndef PF_TV_UNAVAILABLE_WARNING
# if TARGET_OS_TV
# define PF_TV_UNAVAILABLE_WARNING _Pragma("GCC warning \"This file is unavailable on tvOS.\"")
# else
# define PF_TV_UNAVAILABLE_WARNING
# endif
#endif

444
Clocker/Parse/Parse.framework/Versions/A/Headers/PFFile.h

@ -1,444 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
NS_ASSUME_NONNULL_BEGIN
/**
`PFFile` representes a file of binary data stored on the Parse servers.
This can be a image, video, or anything else that an application needs to reference in a non-relational way.
*/
@interface PFFile : NSObject
///--------------------------------------
/// @name Creating a PFFile
///--------------------------------------
- (instancetype)init NS_UNAVAILABLE;
+ (instancetype)new NS_UNAVAILABLE;
/**
Creates a file with given data. A name will be assigned to it by the server.
@param data The contents of the new `PFFile`.
@return A new `PFFile`.
*/
+ (nullable instancetype)fileWithData:(NSData *)data;
/**
Creates a file with given data and name.
@param name The name of the new PFFile. The file name must begin with and
alphanumeric character, and consist of alphanumeric characters, periods,
spaces, underscores, or dashes.
@param data The contents of the new `PFFile`.
@return A new `PFFile` object.
*/
+ (nullable instancetype)fileWithName:(nullable NSString *)name data:(NSData *)data;
/**
Creates a file with the contents of another file.
@warning This method raises an exception if the file at path is not accessible
or if there is not enough disk space left.
@param name The name of the new `PFFile`. The file name must begin with and alphanumeric character,
and consist of alphanumeric characters, periods, spaces, underscores, or dashes.
@param path The path to the file that will be uploaded to Parse.
@return A new `PFFile` instance.
*/
+ (nullable instancetype)fileWithName:(nullable NSString *)name
contentsAtPath:(NSString *)path PF_SWIFT_UNAVAILABLE;
/**
Creates a file with the contents of another file.
@param name The name of the new `PFFile`. The file name must begin with and alphanumeric character,
and consist of alphanumeric characters, periods, spaces, underscores, or dashes.
@param path The path to the file that will be uploaded to Parse.
@param error On input, a pointer to an error object.
If an error occurs, this pointer is set to an actual error object containing the error information.
You may specify `nil` for this parameter if you do not want the error information.
@return A new `PFFile` instance or `nil` if the error occured.
*/
+ (nullable instancetype)fileWithName:(nullable NSString *)name
contentsAtPath:(NSString *)path
error:(NSError **)error;
/**
Creates a file with given data, name and content type.
@warning This method raises an exception if the data supplied is not accessible or could not be saved.
@param name The name of the new `PFFile`. The file name must begin with and alphanumeric character,
and consist of alphanumeric characters, periods, spaces, underscores, or dashes.
@param data The contents of the new `PFFile`.
@param contentType Represents MIME type of the data.
@return A new `PFFile` instance.
*/
+ (nullable instancetype)fileWithName:(nullable NSString *)name
data:(NSData *)data
contentType:(nullable NSString *)contentType PF_SWIFT_UNAVAILABLE;
/**
Creates a file with given data, name and content type.
@param name The name of the new `PFFile`. The file name must begin with and alphanumeric character,
and consist of alphanumeric characters, periods, spaces, underscores, or dashes.
@param data The contents of the new `PFFile`.
@param contentType Represents MIME type of the data.
@param error On input, a pointer to an error object.
If an error occurs, this pointer is set to an actual error object containing the error information.
You may specify `nil` for this parameter if you do not want the error information.
@return A new `PFFile` instance or `nil` if the error occured.
*/
+ (nullable instancetype)fileWithName:(nullable NSString *)name
data:(NSData *)data
contentType:(nullable NSString *)contentType
error:(NSError **)error;
/**
Creates a file with given data and content type.
@param data The contents of the new `PFFile`.
@param contentType Represents MIME type of the data.
@return A new `PFFile` object.
*/
+ (instancetype)fileWithData:(NSData *)data contentType:(nullable NSString *)contentType;
///--------------------------------------
/// @name File Properties
///--------------------------------------
/**
The name of the file.
Before the file is saved, this is the filename given by
the user. After the file is saved, that name gets prefixed with a unique
identifier.
*/
@property (nonatomic, copy, readonly) NSString *name;
/**
The url of the file.
*/
@property (nullable, nonatomic, copy, readonly) NSString *url;
/**
Whether the file has been uploaded for the first time.
*/
@property (nonatomic, assign, readonly, getter=isDirty) BOOL dirty;
///--------------------------------------
/// @name Storing Data with Parse
///--------------------------------------
/**
Saves the file *synchronously*.
@return Returns whether the save succeeded.
*/
- (BOOL)save PF_SWIFT_UNAVAILABLE;
/**
Saves the file *synchronously* and sets an error if it occurs.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the save succeeded.
*/
- (BOOL)save:(NSError **)error;
/**
Saves the file *asynchronously*.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSNumber *)*)saveInBackground;
/**
Saves the file *asynchronously*
@param progressBlock The block should have the following argument signature: `^(int percentDone)`
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSNumber *)*)saveInBackgroundWithProgressBlock:(nullable PFProgressBlock)progressBlock;
/**
Saves the file *asynchronously* and executes the given block.
@param block The block should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
- (void)saveInBackgroundWithBlock:(nullable PFBooleanResultBlock)block;
/**
Saves the file *asynchronously* and executes the given block.
This method will execute the progressBlock periodically with the percent progress.
`progressBlock` will get called with `100` before `resultBlock` is called.
@param block The block should have the following argument signature: `^(BOOL succeeded, NSError *error)`
@param progressBlock The block should have the following argument signature: `^(int percentDone)`
*/
- (void)saveInBackgroundWithBlock:(nullable PFBooleanResultBlock)block
progressBlock:(nullable PFProgressBlock)progressBlock;
/*
Saves the file *asynchronously* and calls the given callback.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
- (void)saveInBackgroundWithTarget:(nullable id)target selector:(nullable SEL)selector;
///--------------------------------------
/// @name Getting Data from Parse
///--------------------------------------
/**
Whether the data is available in memory or needs to be downloaded.
*/
@property (nonatomic, assign, readonly, getter=isDataAvailable) BOOL dataAvailable;
/**
*Synchronously* gets the data from cache if available or fetches its contents from the network.
@return The `NSData` object containing file data. Returns `nil` if there was an error in fetching.
*/
- (nullable NSData *)getData PF_SWIFT_UNAVAILABLE;
/**
This method is like `-getData` but avoids ever holding the entire `PFFile` contents in memory at once.
This can help applications with many large files avoid memory warnings.
@return A stream containing the data. Returns `nil` if there was an error in fetching.
*/
- (nullable NSInputStream *)getDataStream PF_SWIFT_UNAVAILABLE;
/**
*Synchronously* gets the data from cache if available or fetches its contents from the network.
Sets an error if it occurs.
@param error Pointer to an `NSError` that will be set if necessary.
@return The `NSData` object containing file data. Returns `nil` if there was an error in fetching.
*/
- (nullable NSData *)getData:(NSError **)error;
/**
This method is like `-getData` but avoids ever holding the entire `PFFile` contents in memory at once.
@param error Pointer to an `NSError` that will be set if necessary.
@return A stream containing the data. Returns nil if there was an error in
fetching.
*/
- (nullable NSInputStream *)getDataStream:(NSError **)error;
/**
This method is like `-getData` but it fetches asynchronously to avoid blocking the current thread.
@see getData
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSData *)*)getDataInBackground;
/**
This method is like `-getData` but it fetches asynchronously to avoid blocking the current thread.
This can help applications with many large files avoid memory warnings.
@see getData
@param progressBlock The block should have the following argument signature: ^(int percentDone)
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSData *)*)getDataInBackgroundWithProgressBlock:(nullable PFProgressBlock)progressBlock;
/**
This method is like `-getDataInBackground` but avoids ever holding the entire `PFFile` contents in memory at once.
This can help applications with many large files avoid memory warnings.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSInputStream *)*)getDataStreamInBackground;
/**
This method is like `-getDataStreamInBackground`, but yields a live-updating stream.
Instead of `-getDataStream`, which yields a stream that can be read from only after the request has
completed, this method gives you a stream directly written to by the HTTP session. As this stream is not pre-buffered,
it is strongly advised to use the `NSStreamDelegate` methods, in combination with a run loop, to consume the data in
the stream, to do proper async file downloading.
@note You MUST open this stream before reading from it.
@note Do NOT call `waitUntilFinished` on this task from the main thread. It may result in a deadlock.
@return A task that produces a *live* stream that is being written to with the data from the server.
*/
- (BFTask PF_GENERIC(NSInputStream *)*)getDataDownloadStreamInBackground;
/**
This method is like `-getDataInBackground` but avoids
ever holding the entire `PFFile` contents in memory at once.
This can help applications with many large files avoid memory warnings.
@param progressBlock The block should have the following argument signature: ^(int percentDone)
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSInputStream *)*)getDataStreamInBackgroundWithProgressBlock:(nullable PFProgressBlock)progressBlock;
/**
This method is like `-getDataStreamInBackgroundWithProgressBlock:`, but yields a live-updating stream.
Instead of `-getDataStream`, which yields a stream that can be read from only after the request has
completed, this method gives you a stream directly written to by the HTTP session. As this stream is not pre-buffered,
it is strongly advised to use the `NSStreamDelegate` methods, in combination with a run loop, to consume the data in
the stream, to do proper async file downloading.
@note You MUST open this stream before reading from it.
@note Do NOT call `waitUntilFinished` on this task from the main thread. It may result in a deadlock.
@param progressBlock The block should have the following argument signature: `^(int percentDone)`
@return A task that produces a *live* stream that is being written to with the data from the server.
*/
- (BFTask PF_GENERIC(NSInputStream *)*)getDataDownloadStreamInBackgroundWithProgressBlock:(nullable PFProgressBlock)progressBlock;
/**
*Asynchronously* gets the data from cache if available or fetches its contents from the network.
@param block The block should have the following argument signature: `^(NSData *result, NSError *error)`
*/
- (void)getDataInBackgroundWithBlock:(nullable PFDataResultBlock)block;
/**
This method is like `-getDataInBackgroundWithBlock:` but avoids ever holding the entire `PFFile` contents in memory at once.
This can help applications with many large files avoid memory warnings.
@param block The block should have the following argument signature: `(NSInputStream *result, NSError *error)`
*/
- (void)getDataStreamInBackgroundWithBlock:(nullable PFDataStreamResultBlock)block;
/**
*Asynchronously* gets the data from cache if available or fetches its contents from the network.
This method will execute the progressBlock periodically with the percent progress.
`progressBlock` will get called with `100` before `resultBlock` is called.
@param resultBlock The block should have the following argument signature: ^(NSData *result, NSError *error)
@param progressBlock The block should have the following argument signature: ^(int percentDone)
*/
- (void)getDataInBackgroundWithBlock:(nullable PFDataResultBlock)resultBlock
progressBlock:(nullable PFProgressBlock)progressBlock;
/**
This method is like `-getDataInBackgroundWithBlock:progressBlock:` but avoids
ever holding the entire `PFFile` contents in memory at once.
This can help applications with many large files avoid memory warnings.
@param resultBlock The block should have the following argument signature: `^(NSInputStream *result, NSError *error)`.
@param progressBlock The block should have the following argument signature: `^(int percentDone)`.
*/
- (void)getDataStreamInBackgroundWithBlock:(nullable PFDataStreamResultBlock)resultBlock
progressBlock:(nullable PFProgressBlock)progressBlock;
/*
*Asynchronously* gets the data from cache if available or fetches its contents from the network.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSData *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
*/
- (void)getDataInBackgroundWithTarget:(nullable id)target selector:(nullable SEL)selector;
/**
*Asynchronously* gets the file path for file from cache if available or fetches its contents from the network.
@note The file path may change between versions of SDK.
@note If you overwrite the contents of the file at returned path it will persist those change
until the file cache is cleared.
@return The task, with the result set to `NSString` representation of a file path.
*/
- (BFTask PF_GENERIC(NSString *)*)getFilePathInBackground;
/**
*Asynchronously* gets the file path for file from cache if available or fetches its contents from the network.
@note The file path may change between versions of SDK.
@note If you overwrite the contents of the file at returned path it will persist those change
until the file cache is cleared.
@param progressBlock The block should have the following argument signature: `^(int percentDone)`.
@return The task, with the result set to `NSString` representation of a file path.
*/
- (BFTask PF_GENERIC(NSString *)*)getFilePathInBackgroundWithProgressBlock:(nullable PFProgressBlock)progressBlock;
/**
*Asynchronously* gets the file path for file from cache if available or fetches its contents from the network.
@note The file path may change between versions of SDK.
@note If you overwrite the contents of the file at returned path it will persist those change
until the file cache is cleared.
@param block The block should have the following argument signature: `^(NSString *filePath, NSError *error)`.
*/
- (void)getFilePathInBackgroundWithBlock:(nullable PFFilePathResultBlock)block;
/**
*Asynchronously* gets the file path for file from cache if available or fetches its contents from the network.
@note The file path may change between versions of SDK.
@note If you overwrite the contents of the file at returned path it will persist those change
until the file cache is cleared.
@param block The block should have the following argument signature: `^(NSString *filePath, NSError *error)`.
@param progressBlock The block should have the following argument signature: `^(int percentDone)`.
*/
- (void)getFilePathInBackgroundWithBlock:(nullable PFFilePathResultBlock)block
progressBlock:(nullable PFProgressBlock)progressBlock;
///--------------------------------------
/// @name Interrupting a Transfer
///--------------------------------------
/**
Cancels the current request (upload or download of file).
*/
- (void)cancel;
@end
NS_ASSUME_NONNULL_END

112
Clocker/Parse/Parse.framework/Versions/A/Headers/PFGeoPoint.h

@ -1,112 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <CoreLocation/CoreLocation.h>
#import <Foundation/Foundation.h>
NS_ASSUME_NONNULL_BEGIN
@class PFGeoPoint;
typedef void(^PFGeoPointResultBlock)(PFGeoPoint *__nullable geoPoint, NSError *__nullable error);
/**
`PFGeoPoint` may be used to embed a latitude / longitude point as the value for a key in a `PFObject`.
It could be used to perform queries in a geospatial manner using `PFQuery.-whereKey:nearGeoPoint:`.
Currently, instances of `PFObject` may only have one key associated with a `PFGeoPoint` type.
*/
@interface PFGeoPoint : NSObject <NSCopying, NSCoding>
///--------------------------------------
/// @name Creating a Geo Point
///--------------------------------------
/**
Create a PFGeoPoint object. Latitude and longitude are set to `0.0`.
@return Returns a new `PFGeoPoint`.
*/
+ (instancetype)geoPoint;
/**
Creates a new `PFGeoPoint` object for the given `CLLocation`, set to the location's coordinates.
@param location Instace of `CLLocation`, with set latitude and longitude.
@return Returns a new PFGeoPoint at specified location.
*/
+ (instancetype)geoPointWithLocation:(nullable CLLocation *)location;
/**
Create a new `PFGeoPoint` object with the specified latitude and longitude.
@param latitude Latitude of point in degrees.
@param longitude Longitude of point in degrees.
@return New point object with specified latitude and longitude.
*/
+ (instancetype)geoPointWithLatitude:(double)latitude longitude:(double)longitude;
/**
Fetches the current device location and executes a block with a new `PFGeoPoint` object.
@param resultBlock A block which takes the newly created `PFGeoPoint` as an argument.
It should have the following argument signature: `^(PFGeoPoint *geoPoint, NSError *error)`
*/
+ (void)geoPointForCurrentLocationInBackground:(nullable PFGeoPointResultBlock)resultBlock;
///--------------------------------------
/// @name Controlling Position
///--------------------------------------
/**
Latitude of point in degrees. Valid range is from `-90.0` to `90.0`.
*/
@property (nonatomic, assign) double latitude;
/**
Longitude of point in degrees. Valid range is from `-180.0` to `180.0`.
*/
@property (nonatomic, assign) double longitude;
///--------------------------------------
/// @name Calculating Distance
///--------------------------------------
/**
Get distance in radians from this point to specified point.
@param point `PFGeoPoint` that represents the location of other point.
@return Distance in radians between the receiver and `point`.
*/
- (double)distanceInRadiansTo:(nullable PFGeoPoint *)point;
/**
Get distance in miles from this point to specified point.
@param point `PFGeoPoint` that represents the location of other point.
@return Distance in miles between the receiver and `point`.
*/
- (double)distanceInMilesTo:(nullable PFGeoPoint *)point;
/**
Get distance in kilometers from this point to specified point.
@param point `PFGeoPoint` that represents the location of other point.
@return Distance in kilometers between the receiver and `point`.
*/
- (double)distanceInKilometersTo:(nullable PFGeoPoint *)point;
@end
NS_ASSUME_NONNULL_END

115
Clocker/Parse/Parse.framework/Versions/A/Headers/PFInstallation.h

@ -1,115 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Parse/PFObject.h>
#import <Parse/PFSubclassing.h>
PF_TV_UNAVAILABLE_WARNING
PF_WATCH_UNAVAILABLE_WARNING
NS_ASSUME_NONNULL_BEGIN
/**
A Parse Framework Installation Object that is a local representation of an
installation persisted to the Parse cloud. This class is a subclass of a
`PFObject`, and retains the same functionality of a PFObject, but also extends
it with installation-specific fields and related immutability and validity
checks.
A valid `PFInstallation` can only be instantiated via
`+currentInstallation` because the required identifier fields
are readonly. The `timeZone` and `badge` fields are also readonly properties which
are automatically updated to match the device's time zone and application badge
when the `PFInstallation` is saved, thus these fields might not reflect the
latest device state if the installation has not recently been saved.
`PFInstallation` objects which have a valid `deviceToken` and are saved to
the Parse cloud can be used to target push notifications.
*/
PF_TV_UNAVAILABLE PF_WATCH_UNAVAILABLE @interface PFInstallation : PFObject<PFSubclassing>
///--------------------------------------
/// @name Accessing the Current Installation
///--------------------------------------
/**
Gets the currently-running installation from disk and returns an instance of it.
If this installation is not stored on disk, returns a `PFInstallation`
with `deviceType` and `installationId` fields set to those of the
current installation.
@result Returns a `PFInstallation` that represents the currently-running installation.
*/
+ (instancetype)currentInstallation;
///--------------------------------------
/// @name Installation Properties
///--------------------------------------
/**
The device type for the `PFInstallation`.
*/
@property (nonatomic, copy, readonly) NSString *deviceType;
/**
The installationId for the `PFInstallation`.
*/
@property (nonatomic, copy, readonly) NSString *installationId;
/**
The device token for the `PFInstallation`.
*/
@property (nullable, nonatomic, copy) NSString *deviceToken;
/**
The badge for the `PFInstallation`.
*/
@property (nonatomic, assign) NSInteger badge;
/**
The name of the time zone for the `PFInstallation`.
*/
@property (nullable, nonatomic, copy, readonly) NSString *timeZone;
/**
The channels for the `PFInstallation`.
*/
@property (nullable, nonatomic, copy) NSArray PF_GENERIC(NSString *)*channels;
/**
Sets the device token string property from an `NSData`-encoded token.
@param deviceTokenData A token that identifies the device.
*/
- (void)setDeviceTokenFromData:(nullable NSData *)deviceTokenData;
///--------------------------------------
/// @name Querying for Installations
///--------------------------------------
/**
Creates a `PFQuery` for `PFInstallation` objects.
Only the following types of queries are allowed for installations:
- `[query getObjectWithId:<value>]`
- `[query whereKey:@"installationId" equalTo:<value>]`
- `[query whereKey:@"installationId" matchesKey:<key in query> inQuery:<query>]`
You can add additional query conditions, but one of the above must appear as a top-level `AND` clause in the query.
*/
+ (nullable PFQuery *)query;
@end
NS_ASSUME_NONNULL_END

126
Clocker/Parse/Parse.framework/Versions/A/Headers/PFObject+Subclass.h

@ -1,126 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Parse/PFObject.h>
@class PFQuery PF_GENERIC(PFGenericObject : PFObject *);
NS_ASSUME_NONNULL_BEGIN
/**
### Subclassing Notes
Developers can subclass `PFObject` for a more native object-oriented class structure.
Strongly-typed subclasses of `PFObject` must conform to the `PFSubclassing` protocol
and must call `PFSubclassing.+registerSubclass` before `Parse.+setApplicationId:clientKey:` is called.
After this it will be returned by `PFQuery` and other `PFObject` factories.
All methods in `PFSubclassing` except for `PFSubclassing.+parseClassName`
are already implemented in the `PFObject(Subclass)` category.
Including `PFObject+Subclass.h` in your implementation file provides these implementations automatically.
Subclasses support simpler initializers, query syntax, and dynamic synthesizers.
The following shows an example subclass:
\@interface MYGame : PFObject <PFSubclassing>
// Accessing this property is the same as objectForKey:@"title"
@property (nonatomic, copy) NSString *title;
+ (NSString *)parseClassName;
@end
@implementation MYGame
@dynamic title;
+ (NSString *)parseClassName {
return @"Game";
}
@end
MYGame *game = [[MYGame alloc] init];
game.title = @"Bughouse";
[game saveInBackground];
*/
@interface PFObject (Subclass)
///--------------------------------------
/// @name Methods for Subclasses
///--------------------------------------
/**
Creates an instance of the registered subclass with this class's `PFSubclassing.+parseClassName`.
This helps a subclass ensure that it can be subclassed itself.
For example, `[PFUser object]` will return a `MyUser` object if `MyUser` is a registered subclass of `PFUser`.
For this reason, `[MyClass object]` is preferred to `[[MyClass alloc] init]`.
This method can only be called on subclasses which conform to `PFSubclassing`.
A default implementation is provided by `PFObject` which should always be sufficient.
*/
+ (instancetype)object;
/**
Creates a reference to an existing `PFObject` for use in creating associations between `PFObjects`.
Calling `dataAvailable` on this object will return `NO` until `-fetchIfNeeded` or `-fetch` has been called.
This method can only be called on subclasses which conform to `PFSubclassing`.
A default implementation is provided by `PFObject` which should always be sufficient.
No network request will be made.
@param objectId The object id for the referenced object.
@return An instance of `PFObject` without data.
*/
+ (instancetype)objectWithoutDataWithObjectId:(nullable NSString *)objectId;
/**
Registers an Objective-C class for Parse to use for representing a given Parse class.
Once this is called on a `PFObject` subclass, any `PFObject` Parse creates with a class name
that matches `[self parseClassName]` will be an instance of subclass.
This method can only be called on subclasses which conform to `PFSubclassing`.
A default implementation is provided by `PFObject` which should always be sufficient.
*/
+ (void)registerSubclass;
/**
Returns a query for objects of type `PFSubclassing.+parseClassName`.
This method can only be called on subclasses which conform to `PFSubclassing`.
A default implementation is provided by `PFObject` which should always be sufficient.
@see `PFQuery`
*/
+ (nullable PFQuery *)query;
/**
Returns a query for objects of type `PFSubclassing.+parseClassName` with a given predicate.
A default implementation is provided by `PFObject` which should always be sufficient.
@warning This method can only be called on subclasses which conform to `PFSubclassing`.
@param predicate The predicate to create conditions from.
@return An instance of `PFQuery`.
@see `PFQuery.+queryWithClassName:predicate:`
*/
+ (nullable PFQuery *)queryWithPredicate:(nullable NSPredicate *)predicate;
@end
NS_ASSUME_NONNULL_END

1420
Clocker/Parse/Parse.framework/Versions/A/Headers/PFObject.h

File diff suppressed because it is too large Load Diff

543
Clocker/Parse/Parse.framework/Versions/A/Headers/PFPush.h

@ -1,543 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
#import <Parse/PFInstallation.h>
PF_TV_UNAVAILABLE_WARNING
PF_WATCH_UNAVAILABLE_WARNING
@class PFQuery PF_GENERIC(PFGenericObject : PFObject *);
NS_ASSUME_NONNULL_BEGIN
/**
The `PFPush` class defines a push notification that can be sent from a client device.
The preferred way of modifying or retrieving channel subscriptions is to use
the `PFInstallation` class, instead of the class methods in `PFPush`.
*/
PF_TV_UNAVAILABLE PF_WATCH_UNAVAILABLE @interface PFPush : NSObject <NSCopying>
///--------------------------------------
/// @name Creating a Push Notification
///--------------------------------------
+ (instancetype)push;
///--------------------------------------
/// @name Configuring a Push Notification
///--------------------------------------
/**
Sets the channel on which this push notification will be sent.
@param channel The channel to set for this push.
The channel name must start with a letter and contain only letters, numbers, dashes, and underscores.
*/
- (void)setChannel:(nullable NSString *)channel;
/**
Sets the array of channels on which this push notification will be sent.
@param channels The array of channels to set for this push.
Each channel name must start with a letter and contain only letters, numbers, dashes, and underscores.
*/
- (void)setChannels:(nullable NSArray PF_GENERIC(NSString *)*)channels;
/**
Sets an installation query to which this push notification will be sent.
The query should be created via `PFInstallation.+query` and should not specify a skip, limit, or order.
@param query The installation query to set for this push.
*/
- (void)setQuery:(nullable PFQuery PF_GENERIC(PFInstallation *)*)query;
/**
Sets an alert message for this push notification.
@warning This will overwrite any data specified in setData.
@param message The message to send in this push.
*/
- (void)setMessage:(nullable NSString *)message;
/**
Sets an arbitrary data payload for this push notification.
See the guide for information about the dictionary structure.
@warning This will overwrite any data specified in setMessage.
@param data The data to send in this push.
*/
- (void)setData:(nullable NSDictionary *)data;
/**
Sets whether this push will go to Android devices.
@param pushToAndroid Whether this push will go to Android devices.
@deprecated Please use a `PFInstallation.+query` with a constraint on deviceType instead.
*/
- (void)setPushToAndroid:(BOOL)pushToAndroid PARSE_DEPRECATED("Please use a [PFInstallation query] with a constraint on deviceType. This method is deprecated and won't do anything.");
/**
Sets whether this push will go to iOS devices.
@param pushToIOS Whether this push will go to iOS devices.
@deprecated Please use a `PFInstallation.+query` with a constraint on deviceType instead.
*/
- (void)setPushToIOS:(BOOL)pushToIOS PARSE_DEPRECATED("Please use a [PFInstallation query] with a constraint on deviceType. This method is deprecated and won't do anything.");
/**
Sets the expiration time for this notification.
The notification will be sent to devices which are either online
at the time the notification is sent, or which come online before the expiration time is reached.
Because device clocks are not guaranteed to be accurate,
most applications should instead use `-expireAfterTimeInterval:`.
@see expireAfterTimeInterval:
@param date The time at which the notification should expire.
*/
- (void)expireAtDate:(nullable NSDate *)date;
/**
Sets the time interval after which this notification should expire.
This notification will be sent to devices which are either online at
the time the notification is sent, or which come online within the given
time interval of the notification being received by Parse's server.
An interval which is less than or equal to zero indicates that the
message should only be sent to devices which are currently online.
@param timeInterval The interval after which the notification should expire.
*/
- (void)expireAfterTimeInterval:(NSTimeInterval)timeInterval;
/**
Clears both expiration values, indicating that the notification should never expire.
*/
- (void)clearExpiration;
/**
Date at which to send this push notification.
Push notificaitons with this date will be delivered at the local time matching the `PFInstallation.timeZone`.
@warning The date cannot be in the past, and can be up to two weeks in the future.
*/
@property (nullable, nonatomic, strong) NSDate *pushDate;
///--------------------------------------
/// @name Sending Push Notifications
///--------------------------------------
/**
*Synchronously* send a push message to a channel.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param message The message to send.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the send succeeded.
*/
+ (BOOL)sendPushMessageToChannel:(NSString *)channel
withMessage:(NSString *)message
error:(NSError **)error;
/**
*Asynchronously* send a push message to a channel.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param message The message to send.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)sendPushMessageToChannelInBackground:(NSString *)channel
withMessage:(NSString *)message;
/**
*Asynchronously* sends a push message to a channel and calls the given block.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param message The message to send.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)sendPushMessageToChannelInBackground:(NSString *)channel
withMessage:(NSString *)message
block:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* send a push message to a channel.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param message The message to send.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)sendPushMessageToChannelInBackground:(NSString *)channel
withMessage:(NSString *)message
target:(__nullable id)target
selector:(__nullable SEL)selector;
/**
Send a push message to a query.
@param query The query to send to. The query must be a `PFInstallation` query created with `PFInstallation.+query`.
@param message The message to send.
@param error Pointer to an NSError that will be set if necessary.
@return Returns whether the send succeeded.
*/
+ (BOOL)sendPushMessageToQuery:(PFQuery PF_GENERIC(PFInstallation *)*)query
withMessage:(NSString *)message
error:(NSError **)error;
/**
*Asynchronously* send a push message to a query.
@param query The query to send to. The query must be a `PFInstallation` query created with `PFInstallation.+query`.
@param message The message to send.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)sendPushMessageToQueryInBackground:(PFQuery PF_GENERIC(PFInstallation *)*)query
withMessage:(NSString *)message;
/**
*Asynchronously* sends a push message to a query and calls the given block.
@param query The query to send to. The query must be a PFInstallation query
created with [PFInstallation query].
@param message The message to send.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)sendPushMessageToQueryInBackground:(PFQuery PF_GENERIC(PFInstallation *)*)query
withMessage:(NSString *)message
block:(nullable PFBooleanResultBlock)block;
/**
*Synchronously* send this push message.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the send succeeded.
*/
- (BOOL)sendPush:(NSError **)error;
/**
*Asynchronously* send this push message.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSNumber *)*)sendPushInBackground;
/**
*Asynchronously* send this push message and executes the given callback block.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
- (void)sendPushInBackgroundWithBlock:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* send this push message and calls the given callback.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
- (void)sendPushInBackgroundWithTarget:(__nullable id)target selector:(__nullable SEL)selector;
/**
*Synchronously* send a push message with arbitrary data to a channel.
See the guide for information about the dictionary structure.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param data The data to send.
@param error Pointer to an NSError that will be set if necessary.
@return Returns whether the send succeeded.
*/
+ (BOOL)sendPushDataToChannel:(NSString *)channel
withData:(NSDictionary *)data
error:(NSError **)error;
/**
*Asynchronously* send a push message with arbitrary data to a channel.
See the guide for information about the dictionary structure.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param data The data to send.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)sendPushDataToChannelInBackground:(NSString *)channel
withData:(NSDictionary *)data;
/**
Asynchronously sends a push message with arbitrary data to a channel and calls the given block.
See the guide for information about the dictionary structure.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param data The data to send.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
+ (void)sendPushDataToChannelInBackground:(NSString *)channel
withData:(NSDictionary *)data
block:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* send a push message with arbitrary data to a channel.
See the guide for information about the dictionary structure.
@param channel The channel to send to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param data The data to send.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)sendPushDataToChannelInBackground:(NSString *)channel
withData:(NSDictionary *)data
target:(__nullable id)target
selector:(__nullable SEL)selector;
/**
*Synchronously* send a push message with arbitrary data to a query.
See the guide for information about the dictionary structure.
@param query The query to send to. The query must be a `PFInstallation` query
created with `PFInstallation.+query`.
@param data The data to send.
@param error Pointer to an NSError that will be set if necessary.
@return Returns whether the send succeeded.
*/
+ (BOOL)sendPushDataToQuery:(PFQuery PF_GENERIC(PFInstallation *)*)query
withData:(NSDictionary *)data
error:(NSError **)error;
/**
Asynchronously send a push message with arbitrary data to a query.
See the guide for information about the dictionary structure.
@param query The query to send to. The query must be a `PFInstallation` query
created with `PFInstallation.+query`.
@param data The data to send.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)sendPushDataToQueryInBackground:(PFQuery PF_GENERIC(PFInstallation *)*)query
withData:(NSDictionary *)data;
/**
*Asynchronously* sends a push message with arbitrary data to a query and calls the given block.
See the guide for information about the dictionary structure.
@param query The query to send to. The query must be a `PFInstallation` query
created with `PFInstallation.+query`.
@param data The data to send.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
+ (void)sendPushDataToQueryInBackground:(PFQuery PF_GENERIC(PFInstallation *)*)query
withData:(NSDictionary *)data
block:(nullable PFBooleanResultBlock)block;
///--------------------------------------
/// @name Handling Notifications
///--------------------------------------
/**
A default handler for push notifications while the app is active that
could be used to mimic the behavior of iOS push notifications while the app is backgrounded or not running.
Call this from `application:didReceiveRemoteNotification:`.
If push has a dictionary containing loc-key and loc-args in the alert,
we support up to 10 items in loc-args (`NSRangeException` if limit exceeded).
@warning This method is available only on iOS.
@param userInfo The userInfo dictionary you get in `appplication:didReceiveRemoteNotification:`.
*/
+ (void)handlePush:(nullable NSDictionary *)userInfo NS_AVAILABLE_IOS(3_0) PF_EXTENSION_UNAVAILABLE("");
///--------------------------------------
/// @name Managing Channel Subscriptions
///--------------------------------------
/**
Store the device token locally for push notifications.
Usually called from you main app delegate's `didRegisterForRemoteNotificationsWithDeviceToken:`.
@param deviceToken Either as an `NSData` straight from `application:didRegisterForRemoteNotificationsWithDeviceToken:`
or as an `NSString` if you converted it yourself.
*/
+ (void)storeDeviceToken:(id)deviceToken;
/**
*Synchronously* get all the channels that this device is subscribed to.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns an `NSSet` containing all the channel names this device is subscribed to.
*/
+ (nullable NSSet PF_GENERIC(NSString *)*)getSubscribedChannels:(NSError **)error;
/**
*Asynchronously* get all the channels that this device is subscribed to.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSSet<NSString *> *)*)getSubscribedChannelsInBackground;
/**
*Asynchronously* get all the channels that this device is subscribed to.
@param block The block to execute.
It should have the following argument signature: `^(NSSet *channels, NSError *error)`.
*/
+ (void)getSubscribedChannelsInBackgroundWithBlock:(PFSetResultBlock)block;
/*
*Asynchronously* get all the channels that this device is subscribed to.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSSet *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
*/
+ (void)getSubscribedChannelsInBackgroundWithTarget:(id)target selector:(SEL)selector;
/**
*Synchrnously* subscribes the device to a channel of push notifications.
@param channel The channel to subscribe to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the subscribe succeeded.
*/
+ (BOOL)subscribeToChannel:(NSString *)channel error:(NSError **)error;
/**
*Asynchronously* subscribes the device to a channel of push notifications.
@param channel The channel to subscribe to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)subscribeToChannelInBackground:(NSString *)channel;
/**
*Asynchronously* subscribes the device to a channel of push notifications and calls the given block.
@param channel The channel to subscribe to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`
*/
+ (void)subscribeToChannelInBackground:(NSString *)channel
block:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* subscribes the device to a channel of push notifications and calls the given callback.
@param channel The channel to subscribe to. The channel name must start with
a letter and contain only letters, numbers, dashes, and underscores.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)subscribeToChannelInBackground:(NSString *)channel
target:(nullable id)target
selector:(nullable SEL)selector;
/**
*Synchronously* unsubscribes the device to a channel of push notifications.
@param channel The channel to unsubscribe from.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns whether the unsubscribe succeeded.
*/
+ (BOOL)unsubscribeFromChannel:(NSString *)channel error:(NSError **)error;
/**
*Asynchronously* unsubscribes the device from a channel of push notifications.
@param channel The channel to unsubscribe from.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)unsubscribeFromChannelInBackground:(NSString *)channel;
/**
*Asynchronously* unsubscribes the device from a channel of push notifications and calls the given block.
@param channel The channel to unsubscribe from.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
+ (void)unsubscribeFromChannelInBackground:(NSString *)channel
block:(nullable PFBooleanResultBlock)block;
/*
*Asynchronously* unsubscribes the device from a channel of push notifications and calls the given callback.
@param channel The channel to unsubscribe from.
@param target The object to call selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)unsubscribeFromChannelInBackground:(NSString *)channel
target:(nullable id)target
selector:(nullable SEL)selector;
@end
NS_ASSUME_NONNULL_END

892
Clocker/Parse/Parse.framework/Versions/A/Headers/PFQuery.h

@ -1,892 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
#import <Parse/PFGeoPoint.h>
#import <Parse/PFObject.h>
#import <Parse/PFUser.h>
NS_ASSUME_NONNULL_BEGIN
/**
The `PFQuery` class defines a query that is used to query for `PFObject`s.
*/
@interface PFQuery PF_GENERIC(PFGenericObject : PFObject *) : NSObject<NSCopying>
///--------------------------------------
/// @name Blocks
///--------------------------------------
typedef void (^PFQueryArrayResultBlock)(NSArray PF_GENERIC(PFGenericObject) * __nullable objects, NSError * __nullable error);
///--------------------------------------
/// @name Creating a Query for a Class
///--------------------------------------
/**
Initializes the query with a class name.
@param className The class name.
*/
- (instancetype)initWithClassName:(NSString *)className;
/**
Returns a `PFQuery` for a given class.
@param className The class to query on.
@return A `PFQuery` object.
*/
+ (instancetype)queryWithClassName:(NSString *)className;
/**
Creates a PFQuery with the constraints given by predicate.
The following types of predicates are supported:
- Simple comparisons such as `=`, `!=`, `<`, `>`, `<=`, `>=`, and `BETWEEN` with a key and a constant.
- Containment predicates, such as `x IN {1, 2, 3}`.
- Key-existence predicates, such as `x IN SELF`.
- BEGINSWITH expressions.
- Compound predicates with `AND`, `OR`, and `NOT`.
- SubQueries with `key IN %@`, subquery.
The following types of predicates are NOT supported:
- Aggregate operations, such as `ANY`, `SOME`, `ALL`, or `NONE`.
- Regular expressions, such as `LIKE`, `MATCHES`, `CONTAINS`, or `ENDSWITH`.
- Predicates comparing one key to another.
- Complex predicates with many ORed clauses.
@param className The class to query on.
@param predicate The predicate to create conditions from.
*/
+ (instancetype)queryWithClassName:(NSString *)className predicate:(nullable NSPredicate *)predicate;
/**
The class name to query for.
*/
@property (nonatomic, strong) NSString *parseClassName;
///--------------------------------------
/// @name Adding Basic Constraints
///--------------------------------------
/**
Make the query include PFObjects that have a reference stored at the provided key.
This has an effect similar to a join. You can use dot notation to specify which fields in
the included object are also fetch.
@param key The key to load child `PFObject`s for.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)includeKey:(NSString *)key;
/**
Make the query restrict the fields of the returned `PFObject`s to include only the provided keys.
If this is called multiple times, then all of the keys specified in each of the calls will be included.
@param keys The keys to include in the result.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)selectKeys:(NSArray PF_GENERIC(NSString *)*)keys;
/**
Add a constraint that requires a particular key exists.
@param key The key that should exist.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKeyExists:(NSString *)key;
/**
Add a constraint that requires a key not exist.
@param key The key that should not exist.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKeyDoesNotExist:(NSString *)key;
/**
Add a constraint to the query that requires a particular key's object to be equal to the provided object.
@param key The key to be constrained.
@param object The object that must be equalled.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key equalTo:(id)object;
/**
Add a constraint to the query that requires a particular key's object to be less than the provided object.
@param key The key to be constrained.
@param object The object that provides an upper bound.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key lessThan:(id)object;
/**
Add a constraint to the query that requires a particular key's object
to be less than or equal to the provided object.
@param key The key to be constrained.
@param object The object that must be equalled.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key lessThanOrEqualTo:(id)object;
/**
Add a constraint to the query that requires a particular key's object
to be greater than the provided object.
@param key The key to be constrained.
@param object The object that must be equalled.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key greaterThan:(id)object;
/**
Add a constraint to the query that requires a particular key's
object to be greater than or equal to the provided object.
@param key The key to be constrained.
@param object The object that must be equalled.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key greaterThanOrEqualTo:(id)object;
/**
Add a constraint to the query that requires a particular key's object
to be not equal to the provided object.
@param key The key to be constrained.
@param object The object that must not be equalled.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key notEqualTo:(id)object;
/**
Add a constraint to the query that requires a particular key's object
to be contained in the provided array.
@param key The key to be constrained.
@param array The possible values for the key's object.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key containedIn:(NSArray *)array;
/**
Add a constraint to the query that requires a particular key's object
not be contained in the provided array.
@param key The key to be constrained.
@param array The list of values the key's object should not be.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key notContainedIn:(NSArray *)array;
/**
Add a constraint to the query that requires a particular key's array
contains every element of the provided array.
@param key The key to be constrained.
@param array The array of values to search for.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key containsAllObjectsInArray:(NSArray *)array;
///--------------------------------------
/// @name Adding Location Constraints
///--------------------------------------
/**
Add a constraint to the query that requires a particular key's coordinates (specified via `PFGeoPoint`)
be near a reference point.
Distance is calculated based on angular distance on a sphere. Results will be sorted by distance
from reference point.
@param key The key to be constrained.
@param geopoint The reference point represented as a `PFGeoPoint`.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key nearGeoPoint:(PFGeoPoint *)geopoint;
/**
Add a constraint to the query that requires a particular key's coordinates (specified via `PFGeoPoint`)
be near a reference point and within the maximum distance specified (in miles).
Distance is calculated based on a spherical coordinate system.
Results will be sorted by distance (nearest to farthest) from the reference point.
@param key The key to be constrained.
@param geopoint The reference point represented as a `PFGeoPoint`.
@param maxDistance Maximum distance in miles.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key
nearGeoPoint:(PFGeoPoint *)geopoint
withinMiles:(double)maxDistance;
/**
Add a constraint to the query that requires a particular key's coordinates (specified via `PFGeoPoint`)
be near a reference point and within the maximum distance specified (in kilometers).
Distance is calculated based on a spherical coordinate system.
Results will be sorted by distance (nearest to farthest) from the reference point.
@param key The key to be constrained.
@param geopoint The reference point represented as a `PFGeoPoint`.
@param maxDistance Maximum distance in kilometers.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key
nearGeoPoint:(PFGeoPoint *)geopoint
withinKilometers:(double)maxDistance;
/**
Add a constraint to the query that requires a particular key's coordinates (specified via `PFGeoPoint`) be near
a reference point and within the maximum distance specified (in radians). Distance is calculated based on
angular distance on a sphere. Results will be sorted by distance (nearest to farthest) from the reference point.
@param key The key to be constrained.
@param geopoint The reference point as a `PFGeoPoint`.
@param maxDistance Maximum distance in radians.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key
nearGeoPoint:(PFGeoPoint *)geopoint
withinRadians:(double)maxDistance;
/**
Add a constraint to the query that requires a particular key's coordinates (specified via `PFGeoPoint`) be
contained within a given rectangular geographic bounding box.
@param key The key to be constrained.
@param southwest The lower-left inclusive corner of the box.
@param northeast The upper-right inclusive corner of the box.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key withinGeoBoxFromSouthwest:(PFGeoPoint *)southwest toNortheast:(PFGeoPoint *)northeast;
///--------------------------------------
/// @name Adding String Constraints
///--------------------------------------
/**
Add a regular expression constraint for finding string values that match the provided regular expression.
@warning This may be slow for large datasets.
@param key The key that the string to match is stored in.
@param regex The regular expression pattern to match.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key matchesRegex:(NSString *)regex;
/**
Add a regular expression constraint for finding string values that match the provided regular expression.
@warning This may be slow for large datasets.
@param key The key that the string to match is stored in.
@param regex The regular expression pattern to match.
@param modifiers Any of the following supported PCRE modifiers:
- `i` - Case insensitive search
- `m` - Search across multiple lines of input
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key
matchesRegex:(NSString *)regex
modifiers:(nullable NSString *)modifiers;
/**
Add a constraint for finding string values that contain a provided substring.
@warning This will be slow for large datasets.
@param key The key that the string to match is stored in.
@param substring The substring that the value must contain.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key containsString:(nullable NSString *)substring;
/**
Add a constraint for finding string values that start with a provided prefix.
This will use smart indexing, so it will be fast for large datasets.
@param key The key that the string to match is stored in.
@param prefix The substring that the value must start with.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key hasPrefix:(nullable NSString *)prefix;
/**
Add a constraint for finding string values that end with a provided suffix.
@warning This will be slow for large datasets.
@param key The key that the string to match is stored in.
@param suffix The substring that the value must end with.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key hasSuffix:(nullable NSString *)suffix;
///--------------------------------------
/// @name Adding Subqueries
///--------------------------------------
/**
Returns a `PFQuery` that is the `or` of the passed in queries.
@param queries The list of queries to or together.
@return An instance of `PFQuery` that is the `or` of the passed in queries.
*/
+ (instancetype)orQueryWithSubqueries:(NSArray PF_GENERIC(PFQuery *)*)queries;
/**
Adds a constraint that requires that a key's value matches a value in another key
in objects returned by a sub query.
@param key The key that the value is stored.
@param otherKey The key in objects in the returned by the sub query whose value should match.
@param query The query to run.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key
matchesKey:(NSString *)otherKey
inQuery:(PFQuery *)query;
/**
Adds a constraint that requires that a key's value `NOT` match a value in another key
in objects returned by a sub query.
@param key The key that the value is stored.
@param otherKey The key in objects in the returned by the sub query whose value should match.
@param query The query to run.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key
doesNotMatchKey:(NSString *)otherKey
inQuery:(PFQuery *)query;
/**
Add a constraint that requires that a key's value matches a `PFQuery` constraint.
@warning This only works where the key's values are `PFObject`s or arrays of `PFObject`s.
@param key The key that the value is stored in
@param query The query the value should match
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key matchesQuery:(PFQuery *)query;
/**
Add a constraint that requires that a key's value to not match a `PFQuery` constraint.
@warning This only works where the key's values are `PFObject`s or arrays of `PFObject`s.
@param key The key that the value is stored in
@param query The query the value should not match
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)whereKey:(NSString *)key doesNotMatchQuery:(PFQuery *)query;
///--------------------------------------
/// @name Sorting
///--------------------------------------
/**
Sort the results in *ascending* order with the given key.
@param key The key to order by.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)orderByAscending:(NSString *)key;
/**
Additionally sort in *ascending* order by the given key.
The previous keys provided will precedence over this key.
@param key The key to order by.
*/
- (instancetype)addAscendingOrder:(NSString *)key;
/**
Sort the results in *descending* order with the given key.
@param key The key to order by.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)orderByDescending:(NSString *)key;
/**
Additionally sort in *descending* order by the given key.
The previous keys provided will precedence over this key.
@param key The key to order by.
*/
- (instancetype)addDescendingOrder:(NSString *)key;
/**
Sort the results using a given sort descriptor.
@warning If a `sortDescriptor` has custom `selector` or `comparator` - they aren't going to be used.
@param sortDescriptor The `NSSortDescriptor` to use to sort the results of the query.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)orderBySortDescriptor:(NSSortDescriptor *)sortDescriptor;
/**
Sort the results using a given array of sort descriptors.
@warning If a `sortDescriptor` has custom `selector` or `comparator` - they aren't going to be used.
@param sortDescriptors An array of `NSSortDescriptor` objects to use to sort the results of the query.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)orderBySortDescriptors:(nullable NSArray PF_GENERIC(NSSortDescriptor *)*)sortDescriptors;
///--------------------------------------
/// @name Getting Objects by ID
///--------------------------------------
/**
Returns a `PFObject` with a given class and id.
@param objectClass The class name for the object that is being requested.
@param objectId The id of the object that is being requested.
@return The `PFObject` if found. Returns `nil` if the object isn't found, or if there was an error.
*/
+ (nullable PFGenericObject)getObjectOfClass:(NSString *)objectClass
objectId:(NSString *)objectId PF_SWIFT_UNAVAILABLE;
/**
Returns a `PFObject` with a given class and id and sets an error if necessary.
@param objectClass The class name for the object that is being requested.
@param objectId The id of the object that is being requested.
@param error Pointer to an `NSError` that will be set if necessary.
@return The `PFObject` if found. Returns `nil` if the object isn't found, or if there was an `error`.
*/
+ (nullable PFGenericObject)getObjectOfClass:(NSString *)objectClass
objectId:(NSString *)objectId
error:(NSError **)error;
/**
Returns a `PFObject` with the given id.
@warning This method mutates the query.
It will reset limit to `1`, skip to `0` and remove all conditions, leaving only `objectId`.
@param objectId The id of the object that is being requested.
@return The `PFObject` if found. Returns nil if the object isn't found, or if there was an error.
*/
- (nullable PFGenericObject)getObjectWithId:(NSString *)objectId PF_SWIFT_UNAVAILABLE;
/**
Returns a `PFObject` with the given id and sets an error if necessary.
@warning This method mutates the query.
It will reset limit to `1`, skip to `0` and remove all conditions, leaving only `objectId`.
@param objectId The id of the object that is being requested.
@param error Pointer to an `NSError` that will be set if necessary.
@return The `PFObject` if found. Returns nil if the object isn't found, or if there was an error.
*/
- (nullable PFGenericObject)getObjectWithId:(NSString *)objectId error:(NSError **)error;
/**
Gets a `PFObject` asynchronously and calls the given block with the result.
@warning This method mutates the query.
It will reset limit to `1`, skip to `0` and remove all conditions, leaving only `objectId`.
@param objectId The id of the object that is being requested.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(PFGenericObject) *)getObjectInBackgroundWithId:(NSString *)objectId;
/**
Gets a `PFObject` asynchronously and calls the given block with the result.
@warning This method mutates the query.
It will reset limit to `1`, skip to `0` and remove all conditions, leaving only `objectId`.
@param objectId The id of the object that is being requested.
@param block The block to execute.
The block should have the following argument signature: `^(NSArray *object, NSError *error)`
*/
- (void)getObjectInBackgroundWithId:(NSString *)objectId
block:(nullable void (^)(PFGenericObject __nullable object, NSError *__nullable error))block;
/*
Gets a `PFObject` asynchronously.
This mutates the PFQuery. It will reset limit to `1`, skip to `0` and remove all conditions, leaving only `objectId`.
@param objectId The id of the object being requested.
@param target The target for the callback selector.
@param selector The selector for the callback.
It should have the following signature: `(void)callbackWithResult:(id)result error:(NSError *)error`.
Result will be `nil` if error is set and vice versa.
*/
- (void)getObjectInBackgroundWithId:(NSString *)objectId
target:(nullable id)target
selector:(nullable SEL)selector;
///--------------------------------------
/// @name Getting User Objects
///--------------------------------------
/**
Returns a `PFUser` with a given id.
@param objectId The id of the object that is being requested.
@return The PFUser if found. Returns nil if the object isn't found, or if there was an error.
*/
+ (nullable PFUser *)getUserObjectWithId:(NSString *)objectId PF_SWIFT_UNAVAILABLE;
/**
Returns a PFUser with a given class and id and sets an error if necessary.
@param objectId The id of the object that is being requested.
@param error Pointer to an NSError that will be set if necessary.
@result The PFUser if found. Returns nil if the object isn't found, or if there was an error.
*/
+ (nullable PFUser *)getUserObjectWithId:(NSString *)objectId error:(NSError **)error;
/**
@deprecated Please use [PFUser query] instead.
*/
+ (instancetype)queryForUser PARSE_DEPRECATED("Use [PFUser query] instead.");
///--------------------------------------
/// @name Getting all Matches for a Query
///--------------------------------------
/**
Finds objects *synchronously* based on the constructed query.
@return Returns an array of `PFObject` objects that were found.
*/
- (nullable NSArray PF_GENERIC(PFGenericObject) *)findObjects PF_SWIFT_UNAVAILABLE;
/**
Finds objects *synchronously* based on the constructed query and sets an error if there was one.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns an array of `PFObject` objects that were found.
*/
- (nullable NSArray PF_GENERIC(PFGenericObject) *)findObjects:(NSError **)error;
/**
Finds objects *asynchronously* and sets the `NSArray` of `PFObject` objects as a result of the task.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSArray<PFGenericObject> *)*)findObjectsInBackground;
/**
Finds objects *asynchronously* and calls the given block with the results.
@param block The block to execute.
It should have the following argument signature: `^(NSArray *objects, NSError *error)`
*/
- (void)findObjectsInBackgroundWithBlock:(nullable PFQueryArrayResultBlock)block;
/*
Finds objects *asynchronously* and calls the given callback with the results.
@param target The object to call the selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(id)result error:(NSError *)error`.
Result will be `nil` if error is set and vice versa.
*/
- (void)findObjectsInBackgroundWithTarget:(nullable id)target selector:(nullable SEL)selector;
///--------------------------------------
/// @name Getting the First Match in a Query
///--------------------------------------
/**
Gets an object *synchronously* based on the constructed query.
@warning This method mutates the query. It will reset the limit to `1`.
@return Returns a `PFObject`, or `nil` if none was found.
*/
- (nullable PFGenericObject)getFirstObject PF_SWIFT_UNAVAILABLE;
/**
Gets an object *synchronously* based on the constructed query and sets an error if any occurred.
@warning This method mutates the query. It will reset the limit to `1`.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns a `PFObject`, or `nil` if none was found.
*/
- (nullable PFGenericObject)getFirstObject:(NSError **)error;
/**
Gets an object *asynchronously* and sets it as a result of the task.
@warning This method mutates the query. It will reset the limit to `1`.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(PFGenericObject) *)getFirstObjectInBackground;
/**
Gets an object *asynchronously* and calls the given block with the result.
@warning This method mutates the query. It will reset the limit to `1`.
@param block The block to execute.
It should have the following argument signature: `^(PFObject *object, NSError *error)`.
`result` will be `nil` if `error` is set OR no object was found matching the query.
`error` will be `nil` if `result` is set OR if the query succeeded, but found no results.
*/
- (void)getFirstObjectInBackgroundWithBlock:(nullable void (^)(PFGenericObject __nullable object, NSError *__nullable error))block;
/*
Gets an object *asynchronously* and calls the given callback with the results.
@warning This method mutates the query. It will reset the limit to `1`.
@param target The object to call the selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(PFObject *)result error:(NSError *)error`.
`result` will be `nil` if `error` is set OR no object was found matching the query.
`error` will be `nil` if `result` is set OR if the query succeeded, but found no results.
*/
- (void)getFirstObjectInBackgroundWithTarget:(nullable id)target selector:(nullable SEL)selector;
///--------------------------------------
/// @name Counting the Matches in a Query
///--------------------------------------
/**
Counts objects *synchronously* based on the constructed query.
@return Returns the number of `PFObject` objects that match the query, or `-1` if there is an error.
*/
- (NSInteger)countObjects PF_SWIFT_UNAVAILABLE;
/**
Counts objects *synchronously* based on the constructed query and sets an error if there was one.
@param error Pointer to an `NSError` that will be set if necessary.
@return Returns the number of `PFObject` objects that match the query, or `-1` if there is an error.
*/
- (NSInteger)countObjects:(NSError **)error;
/**
Counts objects *asynchronously* and sets `NSNumber` with count as a result of the task.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSNumber *)*)countObjectsInBackground;
/**
Counts objects *asynchronously* and calls the given block with the counts.
@param block The block to execute.
It should have the following argument signature: `^(int count, NSError *error)`
*/
- (void)countObjectsInBackgroundWithBlock:(nullable PFIntegerResultBlock)block;
/*
Counts objects *asynchronously* and calls the given callback with the count.
@param target The object to call the selector on.
@param selector The selector to call.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
*/
- (void)countObjectsInBackgroundWithTarget:(nullable id)target selector:(nullable SEL)selector;
///--------------------------------------
/// @name Cancelling a Query
///--------------------------------------
/**
Cancels the current network request (if any). Ensures that callbacks won't be called.
*/
- (void)cancel;
///--------------------------------------
/// @name Paginating Results
///--------------------------------------
/**
A limit on the number of objects to return. The default limit is `100`, with a
maximum of 1000 results being returned at a time.
@warning If you are calling `findObjects` with `limit = 1`, you may find it easier to use `getFirst` instead.
*/
@property (nonatomic, assign) NSInteger limit;
/**
The number of objects to skip before returning any.
*/
@property (nonatomic, assign) NSInteger skip;
///--------------------------------------
/// @name Controlling Caching Behavior
///--------------------------------------
/**
The cache policy to use for requests.
Not allowed when Pinning is enabled.
@see fromLocalDatastore
@see fromPin
@see fromPinWithName:
*/
@property (nonatomic, assign) PFCachePolicy cachePolicy;
/**
The age after which a cached value will be ignored
*/
@property (nonatomic, assign) NSTimeInterval maxCacheAge;
/**
Returns whether there is a cached result for this query.
@result `YES` if there is a cached result for this query, otherwise `NO`.
*/
- (BOOL)hasCachedResult;
/**
Clears the cached result for this query. If there is no cached result, this is a noop.
*/
- (void)clearCachedResult;
/**
Clears the cached results for all queries.
*/
+ (void)clearAllCachedResults;
///--------------------------------------
/// @name Query Source
///--------------------------------------
/**
Change the source of this query to all pinned objects.
@warning Requires Local Datastore to be enabled.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
@see cachePolicy
*/
- (instancetype)fromLocalDatastore;
/**
Change the source of this query to the default group of pinned objects.
@warning Requires Local Datastore to be enabled.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
@see PFObjectDefaultPin
@see cachePolicy
*/
- (instancetype)fromPin;
/**
Change the source of this query to a specific group of pinned objects.
@warning Requires Local Datastore to be enabled.
@param name The pinned group.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
@see PFObjectDefaultPin
@see cachePolicy
*/
- (instancetype)fromPinWithName:(nullable NSString *)name;
/**
Ignore ACLs when querying from the Local Datastore.
This is particularly useful when querying for objects with Role based ACLs set on them.
@warning Requires Local Datastore to be enabled.
@return The same instance of `PFQuery` as the receiver. This allows method chaining.
*/
- (instancetype)ignoreACLs;
///--------------------------------------
/// @name Advanced Settings
///--------------------------------------
/**
Whether or not performance tracing should be done on the query.
@warning This should not be set to `YES` in most cases.
*/
@property (nonatomic, assign) BOOL trace;
@end
NS_ASSUME_NONNULL_END

57
Clocker/Parse/Parse.framework/Versions/A/Headers/PFRelation.h

@ -1,57 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Parse/PFObject.h>
#import <Parse/PFQuery.h>
NS_ASSUME_NONNULL_BEGIN
/**
The `PFRelation` class that is used to access all of the children of a many-to-many relationship.
Each instance of `PFRelation` is associated with a particular parent object and key.
*/
@interface PFRelation : NSObject
/**
The name of the class of the target child objects.
*/
@property (nullable, nonatomic, copy) NSString *targetClass;
///--------------------------------------
/// @name Accessing Objects
///--------------------------------------
/**
Returns a `PFQuery` object that can be used to get objects in this relation.
*/
- (PFQuery *)query;
///--------------------------------------
/// @name Modifying Relations
///--------------------------------------
/**
Adds a relation to the passed in object.
@param object A `PFObject` object to add relation to.
*/
- (void)addObject:(PFObject *)object;
/**
Removes a relation to the passed in object.
@param object A `PFObject` object to add relation to.
*/
- (void)removeObject:(PFObject *)object;
@end
NS_ASSUME_NONNULL_END

99
Clocker/Parse/Parse.framework/Versions/A/Headers/PFRole.h

@ -1,99 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Parse/PFObject.h>
#import <Parse/PFSubclassing.h>
NS_ASSUME_NONNULL_BEGIN
/**
The `PFRole` class represents a Role on the Parse server.
`PFRoles` represent groupings of `PFUser` objects for the purposes of granting permissions
(e.g. specifying a `PFACL` for a `PFObject`).
Roles are specified by their sets of child users and child roles,
all of which are granted any permissions that the parent role has.
Roles must have a name (which cannot be changed after creation of the role), and must specify an ACL.
*/
@interface PFRole : PFObject <PFSubclassing>
///--------------------------------------
/// @name Creating a New Role
///--------------------------------------
/**
Constructs a new `PFRole` with the given name.
If no default ACL has been specified, you must provide an ACL for the role.
@param name The name of the Role to create.
*/
- (instancetype)initWithName:(NSString *)name;
/**
Constructs a new `PFRole` with the given name.
@param name The name of the Role to create.
@param acl The ACL for this role. Roles must have an ACL.
*/
- (instancetype)initWithName:(NSString *)name acl:(nullable PFACL *)acl;
/**
Constructs a new `PFRole` with the given name.
If no default ACL has been specified, you must provide an ACL for the role.
@param name The name of the Role to create.
*/
+ (instancetype)roleWithName:(NSString *)name;
/**
Constructs a new `PFRole` with the given name.
@param name The name of the Role to create.
@param acl The ACL for this role. Roles must have an ACL.
*/
+ (instancetype)roleWithName:(NSString *)name acl:(nullable PFACL *)acl;
///--------------------------------------
/// @name Role-specific Properties
///--------------------------------------
/**
Gets or sets the name for a role.
This value must be set before the role has been saved to the server,
and cannot be set once the role has been saved.
@warning A role's name can only contain alphanumeric characters, `_`, `-`, and spaces.
*/
@property (nonatomic, copy) NSString *name;
/**
Gets the `PFRelation` for the `PFUser` objects that are direct children of this role.
These users are granted any privileges that this role has been granted
(e.g. read or write access through ACLs). You can add or remove users from
the role through this relation.
*/
@property (nonatomic, strong, readonly) PFRelation *users;
/**
Gets the `PFRelation` for the `PFRole` objects that are direct children of this role.
These roles' users are granted any privileges that this role has been granted
(e.g. read or write access through ACLs). You can add or remove child roles
from this role through this relation.
*/
@property (nonatomic, strong, readonly) PFRelation *roles;
@end
NS_ASSUME_NONNULL_END

52
Clocker/Parse/Parse.framework/Versions/A/Headers/PFSession.h

@ -1,52 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFObject.h>
#import <Parse/PFSubclassing.h>
NS_ASSUME_NONNULL_BEGIN
@class PFSession;
typedef void(^PFSessionResultBlock)(PFSession *__nullable session, NSError *__nullable error);
/**
`PFSession` is a local representation of a session.
This class is a subclass of a `PFObject`,
and retains the same functionality as any other subclass of `PFObject`.
*/
@interface PFSession : PFObject<PFSubclassing>
/**
The session token string for this session.
*/
@property (nullable, nonatomic, copy, readonly) NSString *sessionToken;
/**
*Asynchronously* fetches a `PFSession` object related to the current user.
@return A task that is `completed` with an instance of `PFSession` class or is `faulted` if the operation fails.
*/
+ (BFTask PF_GENERIC(PFSession *)*)getCurrentSessionInBackground;
/**
*Asynchronously* fetches a `PFSession` object related to the current user.
@param block The block to execute when the operation completes.
It should have the following argument signature: `^(PFSession *session, NSError *error)`.
*/
+ (void)getCurrentSessionInBackgroundWithBlock:(nullable PFSessionResultBlock)block;
@end
NS_ASSUME_NONNULL_END

89
Clocker/Parse/Parse.framework/Versions/A/Headers/PFSubclassing.h

@ -1,89 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
@class PFQuery PF_GENERIC(PFGenericObject : PFObject *);
NS_ASSUME_NONNULL_BEGIN
/**
If a subclass of `PFObject` conforms to `PFSubclassing` and calls `PFObject.+registerSubclass`,
Parse framework will be able to use that class as the native class for a Parse cloud object.
Classes conforming to this protocol should subclass `PFObject` and
include `PFObject+Subclass.h` in their implementation file.
This ensures the methods in the Subclass category of `PFObject` are exposed in its subclasses only.
*/
@protocol PFSubclassing
@required
/**
The name of the class as seen in the REST API.
*/
+ (NSString *)parseClassName;
@optional
/**
Constructs an object of the most specific class known to implement `+parseClassName`.
This method takes care to help `PFObject` subclasses be subclassed themselves.
For example, `PFUser.+object` returns a `PFUser` by default but will return an
object of a registered subclass instead if one is known.
A default implementation is provided by `PFObject` which should always be sufficient.
@return Returns the object that is instantiated.
*/
+ (instancetype)object;
/**
Creates a reference to an existing PFObject for use in creating associations between PFObjects.
Calling `PFObject.dataAvailable` on this object will return `NO`
until `PFObject.-fetchIfNeeded` has been called. No network request will be made.
A default implementation is provided by `PFObject` which should always be sufficient.
@param objectId The object id for the referenced object.
@return A new `PFObject` without data.
*/
+ (instancetype)objectWithoutDataWithObjectId:(nullable NSString *)objectId;
/**
Create a query which returns objects of this type.
A default implementation is provided by `PFObject` which should always be sufficient.
*/
+ (nullable PFQuery *)query;
/**
Returns a query for objects of this type with a given predicate.
A default implementation is provided by `PFObject` which should always be sufficient.
@param predicate The predicate to create conditions from.
@return An instance of `PFQuery`.
@see [PFQuery queryWithClassName:predicate:]
*/
+ (nullable PFQuery *)queryWithPredicate:(nullable NSPredicate *)predicate;
/**
Lets Parse know this class should be used to instantiate all objects with class type `parseClassName`.
@warning This method must be called before `Parse.+setApplicationId:clientKey:`.
*/
+ (void)registerSubclass;
@end
NS_ASSUME_NONNULL_END

519
Clocker/Parse/Parse.framework/Versions/A/Headers/PFUser.h

@ -1,519 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Bolts/BFTask.h>
#import <Parse/PFConstants.h>
#import <Parse/PFObject.h>
#import <Parse/PFSubclassing.h>
NS_ASSUME_NONNULL_BEGIN
typedef void(^PFUserSessionUpgradeResultBlock)(NSError *__nullable error);
typedef void(^PFUserLogoutResultBlock)(NSError *__nullable error);
@class PFQuery PF_GENERIC(PFGenericObject : PFObject *);
@protocol PFUserAuthenticationDelegate;
/**
The `PFUser` class is a local representation of a user persisted to the Parse Data.
This class is a subclass of a `PFObject`, and retains the same functionality of a `PFObject`,
but also extends it with various user specific methods, like authentication, signing up, and validation uniqueness.
Many APIs responsible for linking a `PFUser` with Facebook or Twitter have been deprecated in favor of dedicated
utilities for each social network. See `PFFacebookUtils`, `PFTwitterUtils` and `PFAnonymousUtils` for more information.
*/
@interface PFUser : PFObject <PFSubclassing>
///--------------------------------------
/// @name Accessing the Current User
///--------------------------------------
/**
Gets the currently logged in user from disk and returns an instance of it.
@return Returns a `PFUser` that is the currently logged in user. If there is none, returns `nil`.
*/
+ (nullable instancetype)currentUser;
/**
The session token for the `PFUser`.
This is set by the server upon successful authentication.
*/
@property (nullable, nonatomic, copy, readonly) NSString *sessionToken;
/**
Whether the `PFUser` was just created from a request.
This is only set after a Facebook or Twitter login.
*/
@property (nonatomic, assign, readonly) BOOL isNew;
/**
Whether the user is an authenticated object for the device.
An authenticated `PFUser` is one that is obtained via a `-signUp:` or `+logInWithUsername:password:` method.
An authenticated object is required in order to save (with altered values) or delete it.
*/
@property (nonatomic, assign, readonly, getter=isAuthenticated) BOOL authenticated;
///--------------------------------------
/// @name Creating a New User
///--------------------------------------
/**
Creates a new `PFUser` object.
@return Returns a new `PFUser` object.
*/
+ (instancetype)user;
/**
Enables automatic creation of anonymous users.
After calling this method, `+currentUser` will always have a value.
The user will only be created on the server once the user has been saved,
or once an object with a relation to that user or an ACL that refers to the user has been saved.
@warning `PFObject.-saveEventually` will not work on if an item being saved has a relation
to an automatic user that has never been saved.
*/
+ (void)enableAutomaticUser;
/**
The username for the `PFUser`.
*/
@property (nullable, nonatomic, strong) NSString *username;
/**!
The password for the `PFUser`.
This will not be filled in from the server with the password.
It is only meant to be set.
*/
@property (nullable, nonatomic, strong) NSString *password;
/**
The email for the `PFUser`.
*/
@property (nullable, nonatomic, strong) NSString *email;
/**
Signs up the user *synchronously*.
This will also enforce that the username isn't already taken.
@warning Make sure that password and username are set before calling this method.
@return Returns `YES` if the sign up was successful, otherwise `NO`.
*/
- (BOOL)signUp PF_SWIFT_UNAVAILABLE;
/**
Signs up the user *synchronously*.
This will also enforce that the username isn't already taken.
@warning Make sure that password and username are set before calling this method.
@param error Error object to set on error.
@return Returns whether the sign up was successful.
*/
- (BOOL)signUp:(NSError **)error;
/**
Signs up the user *asynchronously*.
This will also enforce that the username isn't already taken.
@warning Make sure that password and username are set before calling this method.
@return The task, that encapsulates the work being done.
*/
- (BFTask PF_GENERIC(NSNumber *)*)signUpInBackground;
/**
Signs up the user *asynchronously*.
This will also enforce that the username isn't already taken.
@warning Make sure that password and username are set before calling this method.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
- (void)signUpInBackgroundWithBlock:(nullable PFBooleanResultBlock)block;
/**
Signs up the user *asynchronously*.
This will also enforce that the username isn't already taken.
@warning Make sure that password and username are set before calling this method.
@param target Target object for the selector.
@param selector The selector that will be called when the asynchrounous request is complete.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
- (void)signUpInBackgroundWithTarget:(nullable id)target selector:(nullable SEL)selector;
///--------------------------------------
/// @name Logging In
///--------------------------------------
/**
Makes a *synchronous* request to login a user with specified credentials.
Returns an instance of the successfully logged in `PFUser`.
This also caches the user locally so that calls to `+currentUser` will use the latest logged in user.
@param username The username of the user.
@param password The password of the user.
@return Returns an instance of the `PFUser` on success.
If login failed for either wrong password or wrong username, returns `nil`.
*/
+ (nullable instancetype)logInWithUsername:(NSString *)username
password:(NSString *)password PF_SWIFT_UNAVAILABLE;
/**
Makes a *synchronous* request to login a user with specified credentials.
Returns an instance of the successfully logged in `PFUser`.
This also caches the user locally so that calls to `+currentUser` will use the latest logged in user.
@param username The username of the user.
@param password The password of the user.
@param error The error object to set on error.
@return Returns an instance of the `PFUser` on success.
If login failed for either wrong password or wrong username, returns `nil`.
*/
+ (nullable instancetype)logInWithUsername:(NSString *)username
password:(NSString *)password
error:(NSError **)error;
/**
Makes an *asynchronous* request to login a user with specified credentials.
Returns an instance of the successfully logged in `PFUser`.
This also caches the user locally so that calls to `+currentUser` will use the latest logged in user.
@param username The username of the user.
@param password The password of the user.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(__kindof PFUser *)*)logInWithUsernameInBackground:(NSString *)username
password:(NSString *)password;
/**
Makes an *asynchronous* request to login a user with specified credentials.
Returns an instance of the successfully logged in `PFUser`.
This also caches the user locally so that calls to `+currentUser` will use the latest logged in user.
@param username The username of the user.
@param password The password of the user.
@param target Target object for the selector.
@param selector The selector that will be called when the asynchrounous request is complete.
It should have the following signature: `(void)callbackWithUser:(PFUser *)user error:(NSError *)error`.
*/
+ (void)logInWithUsernameInBackground:(NSString *)username
password:(NSString *)password
target:(nullable id)target
selector:(nullable SEL)selector;
/**
Makes an *asynchronous* request to log in a user with specified credentials.
Returns an instance of the successfully logged in `PFUser`.
This also caches the user locally so that calls to `+currentUser` will use the latest logged in user.
@param username The username of the user.
@param password The password of the user.
@param block The block to execute.
It should have the following argument signature: `^(PFUser *user, NSError *error)`.
*/
+ (void)logInWithUsernameInBackground:(NSString *)username
password:(NSString *)password
block:(nullable PFUserResultBlock)block;
///--------------------------------------
/// @name Becoming a User
///--------------------------------------
/**
Makes a *synchronous* request to become a user with the given session token.
Returns an instance of the successfully logged in `PFUser`.
This also caches the user locally so that calls to `+currentUser` will use the latest logged in user.
@param sessionToken The session token for the user.
@return Returns an instance of the `PFUser` on success.
If becoming a user fails due to incorrect token, it returns `nil`.
*/
+ (nullable instancetype)become:(NSString *)sessionToken PF_SWIFT_UNAVAILABLE;
/**
Makes a *synchronous* request to become a user with the given session token.
Returns an instance of the successfully logged in `PFUser`.
This will also cache the user locally so that calls to `+currentUser` will use the latest logged in user.
@param sessionToken The session token for the user.
@param error The error object to set on error.
@return Returns an instance of the `PFUser` on success.
If becoming a user fails due to incorrect token, it returns `nil`.
*/
+ (nullable instancetype)become:(NSString *)sessionToken error:(NSError **)error;
/**
Makes an *asynchronous* request to become a user with the given session token.
Returns an instance of the successfully logged in `PFUser`.
This also caches the user locally so that calls to `+currentUser` will use the latest logged in user.
@param sessionToken The session token for the user.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(__kindof PFUser *)*)becomeInBackground:(NSString *)sessionToken;
/**
Makes an *asynchronous* request to become a user with the given session token.
Returns an instance of the successfully logged in `PFUser`. This also caches the user locally
so that calls to `+currentUser` will use the latest logged in user.
@param sessionToken The session token for the user.
@param block The block to execute.
The block should have the following argument signature: `^(PFUser *user, NSError *error)`.
*/
+ (void)becomeInBackground:(NSString *)sessionToken block:(nullable PFUserResultBlock)block;
/**
Makes an *asynchronous* request to become a user with the given session token.
Returns an instance of the successfully logged in `PFUser`. This also caches the user locally
so that calls to `+currentUser` will use the latest logged in user.
@param sessionToken The session token for the user.
@param target Target object for the selector.
@param selector The selector that will be called when the asynchrounous request is complete.
It should have the following signature: `(void)callbackWithUser:(PFUser *)user error:(NSError *)error`.
*/
+ (void)becomeInBackground:(NSString *)sessionToken
target:(__nullable id)target
selector:(__nullable SEL)selector;
///--------------------------------------
/// @name Revocable Session
///--------------------------------------
/**
Enables revocable sessions and migrates the currentUser session token to use revocable session if needed.
This method is required if you want to use `PFSession` APIs
and your application's 'Require Revocable Session' setting is turned off on `http://parse.com` app settings.
After returned `BFTask` completes - `PFSession` class and APIs will be available for use.
@return An instance of `BFTask` that is completed when revocable
sessions are enabled and currentUser token is migrated.
*/
+ (BFTask *)enableRevocableSessionInBackground;
/**
Enables revocable sessions and upgrades the currentUser session token to use revocable session if needed.
This method is required if you want to use `PFSession` APIs
and legacy sessions are enabled in your application settings on `http://parse.com/`.
After returned `BFTask` completes - `PFSession` class and APIs will be available for use.
@param block Block that will be called when revocable sessions are enabled and currentUser token is migrated.
*/
+ (void)enableRevocableSessionInBackgroundWithBlock:(nullable PFUserSessionUpgradeResultBlock)block;
///--------------------------------------
/// @name Logging Out
///--------------------------------------
/**
*Synchronously* logs out the currently logged in user on disk.
*/
+ (void)logOut;
/**
*Asynchronously* logs out the currently logged in user.
This will also remove the session from disk, log out of linked services
and all future calls to `+currentUser` will return `nil`. This is preferrable to using `-logOut`,
unless your code is already running from a background thread.
@return An instance of `BFTask`, that is resolved with `nil` result when logging out completes.
*/
+ (BFTask *)logOutInBackground;
/**
*Asynchronously* logs out the currently logged in user.
This will also remove the session from disk, log out of linked services
and all future calls to `+currentUser` will return `nil`. This is preferrable to using `-logOut`,
unless your code is already running from a background thread.
@param block A block that will be called when logging out completes or fails.
*/
+ (void)logOutInBackgroundWithBlock:(nullable PFUserLogoutResultBlock)block;
///--------------------------------------
/// @name Requesting a Password Reset
///--------------------------------------
/**
*Synchronously* Send a password reset request for a specified email.
If a user account exists with that email, an email will be sent to that address
with instructions on how to reset their password.
@param email Email of the account to send a reset password request.
@return Returns `YES` if the reset email request is successful. `NO` - if no account was found for the email address.
*/
+ (BOOL)requestPasswordResetForEmail:(NSString *)email PF_SWIFT_UNAVAILABLE;
/**
*Synchronously* send a password reset request for a specified email and sets an error object.
If a user account exists with that email, an email will be sent to that address
with instructions on how to reset their password.
@param email Email of the account to send a reset password request.
@param error Error object to set on error.
@return Returns `YES` if the reset email request is successful. `NO` - if no account was found for the email address.
*/
+ (BOOL)requestPasswordResetForEmail:(NSString *)email error:(NSError **)error;
/**
Send a password reset request asynchronously for a specified email and sets an
error object. If a user account exists with that email, an email will be sent to
that address with instructions on how to reset their password.
@param email Email of the account to send a reset password request.
@return The task, that encapsulates the work being done.
*/
+ (BFTask PF_GENERIC(NSNumber *)*)requestPasswordResetForEmailInBackground:(NSString *)email;
/**
Send a password reset request *asynchronously* for a specified email.
If a user account exists with that email, an email will be sent to that address
with instructions on how to reset their password.
@param email Email of the account to send a reset password request.
@param block The block to execute.
It should have the following argument signature: `^(BOOL succeeded, NSError *error)`.
*/
+ (void)requestPasswordResetForEmailInBackground:(NSString *)email
block:(nullable PFBooleanResultBlock)block;
/**
Send a password reset request *asynchronously* for a specified email and sets an error object.
If a user account exists with that email, an email will be sent to that address
with instructions on how to reset their password.
@param email Email of the account to send a reset password request.
@param target Target object for the selector.
@param selector The selector that will be called when the asynchronous request is complete.
It should have the following signature: `(void)callbackWithResult:(NSNumber *)result error:(NSError *)error`.
`error` will be `nil` on success and set if there was an error.
`[result boolValue]` will tell you whether the call succeeded or not.
*/
+ (void)requestPasswordResetForEmailInBackground:(NSString *)email
target:(__nullable id)target
selector:(__nullable SEL)selector;
///--------------------------------------
/// @name Third-party Authentication
///--------------------------------------
/**
Registers a third party authentication delegate.
@note This method shouldn't be invoked directly unless developing a third party authentication library.
@see PFUserAuthenticationDelegate
@param delegate The third party authenticaiton delegate to be registered.
@param authType The name of the type of third party authentication source.
*/
+ (void)registerAuthenticationDelegate:(id<PFUserAuthenticationDelegate>)delegate forAuthType:(NSString *)authType;
/**
Logs in a user with third party authentication credentials.
@note This method shouldn't be invoked directly unless developing a third party authentication library.
@see PFUserAuthenticationDelegate
@param authType The name of the type of third party authentication source.
@param authData The user credentials of the third party authentication source.
@return A `BFTask` that is resolved to `PFUser` when logging in completes.
*/
+ (BFTask PF_GENERIC(PFUser *)*)logInWithAuthTypeInBackground:(NSString *)authType
authData:(NSDictionary PF_GENERIC(NSString *, NSString *)*)authData;
/**
Links this user to a third party authentication library.
@note This method shouldn't be invoked directly unless developing a third party authentication library.
@see PFUserAuthenticationDelegate
@param authType The name of the type of third party authentication source.
@param authData The user credentials of the third party authentication source.
@return A `BFTask` that is resolved to `@YES` if linking succeeds.
*/
- (BFTask PF_GENERIC(NSNumber *)*)linkWithAuthTypeInBackground:(NSString *)authType
authData:(NSDictionary PF_GENERIC(NSString *, NSString *)*)authData;
/**
Unlinks this user from a third party authentication library.
@note This method shouldn't be invoked directly unless developing a third party authentication library.
@see PFUserAuthenticationDelegate
@param authType The name of the type of third party authentication source.
@return A `BFTask` that is resolved to `@YES` if unlinking succeeds.
*/
- (BFTask PF_GENERIC(NSNumber *)*)unlinkWithAuthTypeInBackground:(NSString *)authType;
/**
Indicates whether this user is linked with a third party authentication library of a specific type.
@note This method shouldn't be invoked directly unless developing a third party authentication library.
@see PFUserAuthenticationDelegate
@param authType The name of the type of third party authentication source.
@return `YES` if the user is linked with a provider, otherwise `NO`.
*/
- (BOOL)isLinkedWithAuthType:(NSString *)authType;
@end
NS_ASSUME_NONNULL_END

36
Clocker/Parse/Parse.framework/Versions/A/Headers/PFUserAuthenticationDelegate.h

@ -1,36 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Parse/PFConstants.h>
NS_ASSUME_NONNULL_BEGIN
/**
Provides a general interface for delegation of third party authentication with `PFUser`s.
*/
@protocol PFUserAuthenticationDelegate <NSObject>
/**
Called when restoring third party authentication credentials that have been serialized,
such as session keys, user id, etc.
@note This method will be executed on a background thread.
@param authData The auth data for the provider. This value may be `nil` when unlinking an account.
@return `YES` - if the `authData` was succesfully synchronized,
or `NO` if user should not longer be associated because of bad `authData`.
*/
- (BOOL)restoreAuthenticationWithAuthData:(nullable NSDictionary PF_GENERIC(NSString *, NSString *)*)authData;
@end
NS_ASSUME_NONNULL_END

200
Clocker/Parse/Parse.framework/Versions/A/Headers/Parse.h

@ -1,200 +0,0 @@
/**
* Copyright (c) 2015-present, Parse, LLC.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
#import <Foundation/Foundation.h>
#import <Parse/PFACL.h>
#import <Parse/PFAnalytics.h>
#import <Parse/PFAnonymousUtils.h>
#import <Parse/PFCloud.h>
#import <Parse/PFConfig.h>
#import <Parse/PFConstants.h>
#import <Parse/PFFile.h>
#import <Parse/PFGeoPoint.h>
#import <Parse/PFObject+Subclass.h>
#import <Parse/PFObject.h>
#import <Parse/PFQuery.h>
#import <Parse/PFRelation.h>
#import <Parse/PFRole.h>
#import <Parse/PFSession.h>
#import <Parse/PFSubclassing.h>
#import <Parse/PFUser.h>
#import <Parse/PFUserAuthenticationDelegate.h>
#if TARGET_OS_IOS
#import <Parse/PFInstallation.h>
#import <Parse/PFNetworkActivityIndicatorManager.h>
#import <Parse/PFPush.h>
#import <Parse/PFProduct.h>
#import <Parse/PFPurchase.h>
#elif PF_TARGET_OS_OSX
#import <Parse/PFInstallation.h>
#import <Parse/PFPush.h>
#elif TARGET_OS_TV
#import <Parse/PFProduct.h>
#import <Parse/PFPurchase.h>
#endif
NS_ASSUME_NONNULL_BEGIN
/**
The `Parse` class contains static functions that handle global configuration for the Parse framework.
*/
@interface Parse : NSObject
///--------------------------------------
/// @name Connecting to Parse
///--------------------------------------
/**
Sets the applicationId and clientKey of your application.
@param applicationId The application id of your Parse application.
@param clientKey The client key of your Parse application.
*/
+ (void)setApplicationId:(NSString *)applicationId clientKey:(NSString *)clientKey;
/**
The current application id that was used to configure Parse framework.
*/
+ (NSString *)getApplicationId;
/**
The current client key that was used to configure Parse framework.
*/
+ (NSString *)getClientKey;
///--------------------------------------
/// @name Enabling Local Datastore
///--------------------------------------
/**
Enable pinning in your application. This must be called before your application can use
pinning. The recommended way is to call this method before `+setApplicationId:clientKey:`.
*/
+ (void)enableLocalDatastore PF_TV_UNAVAILABLE;
/**
Flag that indicates whether Local Datastore is enabled.
@return `YES` if Local Datastore is enabled, otherwise `NO`.
*/
+ (BOOL)isLocalDatastoreEnabled PF_TV_UNAVAILABLE;
///--------------------------------------
/// @name Enabling Extensions Data Sharing
///--------------------------------------
/**
Enables data sharing with an application group identifier.
After enabling - Local Datastore, `PFUser.+currentUser`, `PFInstallation.+currentInstallation` and all eventually commands
are going to be available to every application/extension in a group that have the same Parse applicationId.
@warning This method is required to be called before `+setApplicationId:clientKey:`.
@param groupIdentifier Application Group Identifier to share data with.
*/
+ (void)enableDataSharingWithApplicationGroupIdentifier:(NSString *)groupIdentifier PF_EXTENSION_UNAVAILABLE("Use `enableDataSharingWithApplicationGroupIdentifier:containingApplication:`.") PF_WATCH_UNAVAILABLE PF_TV_UNAVAILABLE;
/**
Enables data sharing with an application group identifier.
After enabling - Local Datastore, `PFUser.+currentUser`, `PFInstallation.+currentInstallation` and all eventually commands
are going to be available to every application/extension in a group that have the same Parse applicationId.
@warning This method is required to be called before `+setApplicationId:clientKey:`.
This method can only be used by application extensions.
@param groupIdentifier Application Group Identifier to share data with.
@param bundleIdentifier Bundle identifier of the containing application.
*/
+ (void)enableDataSharingWithApplicationGroupIdentifier:(NSString *)groupIdentifier
containingApplication:(NSString *)bundleIdentifier PF_WATCH_UNAVAILABLE PF_TV_UNAVAILABLE;
/**
Application Group Identifier for Data Sharing.
@return `NSString` value if data sharing is enabled, otherwise `nil`.
*/
+ (NSString *)applicationGroupIdentifierForDataSharing PF_WATCH_UNAVAILABLE PF_TV_UNAVAILABLE;
/**
Containing application bundle identifier for Data Sharing.
@return `NSString` value if data sharing is enabled, otherwise `nil`.
*/
+ (NSString *)containingApplicationBundleIdentifierForDataSharing PF_WATCH_UNAVAILABLE PF_TV_UNAVAILABLE;
#if PARSE_IOS_ONLY
///--------------------------------------
/// @name Configuring UI Settings
///--------------------------------------
/**
Set whether to show offline messages when using a Parse view or view controller related classes.
@param enabled Whether a `UIAlertView` should be shown when the device is offline
and network access is required from a view or view controller.
@deprecated This method has no effect.
*/
+ (void)offlineMessagesEnabled:(BOOL)enabled PARSE_DEPRECATED("This method is deprecated and has no effect.");
/**
Set whether to show an error message when using a Parse view or view controller related classes
and a Parse error was generated via a query.
@param enabled Whether a `UIAlertView` should be shown when an error occurs.
@deprecated This method has no effect.
*/
+ (void)errorMessagesEnabled:(BOOL)enabled PARSE_DEPRECATED("This method is deprecated and has no effect.");
#endif
///--------------------------------------
/// @name Logging
///--------------------------------------
/**
Sets the level of logging to display.
By default:
- If running inside an app that was downloaded from iOS App Store - it is set to `PFLogLevelNone`
- All other cases - it is set to `PFLogLevelWarning`
@param logLevel Log level to set.
@see PFLogLevel
*/
+ (void)setLogLevel:(PFLogLevel)logLevel;
/**
Log level that will be displayed.
By default:
- If running inside an app that was downloaded from iOS App Store - it is set to `PFLogLevelNone`
- All other cases - it is set to `PFLogLevelWarning`
@return A `PFLogLevel` value.
@see PFLogLevel
*/
+ (PFLogLevel)logLevel;
@end
NS_ASSUME_NONNULL_END

6
Clocker/Parse/Parse.framework/Versions/A/Modules/module.modulemap

@ -1,6 +0,0 @@
framework module Parse {
umbrella header "Parse.h"
export *
module * { export * }
}

BIN
Clocker/Parse/Parse.framework/Versions/A/Parse

Binary file not shown.

42
Clocker/Parse/Parse.framework/Versions/A/Resources/Info.plist

@ -1,42 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>BuildMachineOSBuild</key>
<string>15C50</string>
<key>CFBundleDevelopmentRegion</key>
<string>English</string>
<key>CFBundleExecutable</key>
<string>Parse</string>
<key>CFBundleIdentifier</key>
<string>com.parse.osx</string>
<key>CFBundleInfoDictionaryVersion</key>
<string>6.0</string>
<key>CFBundlePackageType</key>
<string>FMWK</string>
<key>CFBundleShortVersionString</key>
<string>1.11.0</string>
<key>CFBundleSignature</key>
<string>????</string>
<key>CFBundleSupportedPlatforms</key>
<array>
<string>MacOSX</string>
</array>
<key>CFBundleVersion</key>
<string>1.11.0</string>
<key>DTCompiler</key>
<string>com.apple.compilers.llvm.clang.1_0</string>
<key>DTPlatformBuild</key>
<string>7C68</string>
<key>DTPlatformVersion</key>
<string>GM</string>
<key>DTSDKBuild</key>
<string>15C43</string>
<key>DTSDKName</key>
<string>macosx10.11</string>
<key>DTXcode</key>
<string>0720</string>
<key>DTXcodeBuild</key>
<string>7C68</string>
</dict>
</plist>

Some files were not shown because too many files have changed in this diff Show More

Loading…
Cancel
Save