|  |  |  | //
 | 
					
						
							|  |  |  | //  Copyright (c) 2018 Open Whisper Systems. All rights reserved.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | NS_ASSUME_NONNULL_BEGIN | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @interface DateUtil : NSObject | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (NSDateFormatter *)dateFormatter; | 
					
						
							|  |  |  | + (NSDateFormatter *)timeFormatter; | 
					
						
							|  |  |  | + (NSDateFormatter *)monthAndDayFormatter; | 
					
						
							|  |  |  | + (NSDateFormatter *)shortDayOfWeekFormatter; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (BOOL)dateIsOlderThanToday:(NSDate *)date; | 
					
						
							|  |  |  | + (BOOL)dateIsOlderThanOneWeek:(NSDate *)date; | 
					
						
							|  |  |  | + (BOOL)dateIsToday:(NSDate *)date; | 
					
						
							|  |  |  | + (BOOL)dateIsThisYear:(NSDate *)date; | 
					
						
							|  |  |  | + (BOOL)dateIsYesterday:(NSDate *)date; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (NSString *)formatPastTimestampRelativeToNow:(uint64_t)pastTimestamp | 
					
						
							|  |  |  |     NS_SWIFT_NAME(formatPastTimestampRelativeToNow(_:)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (NSString *)formatTimestampShort:(uint64_t)timestamp; | 
					
						
							|  |  |  | + (NSString *)formatDateShort:(NSDate *)date; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (NSString *)formatTimestampAsTime:(uint64_t)timestamp; | 
					
						
							|  |  |  | + (NSString *)formatDateAsTime:(NSDate *)date; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (NSString *)formatMessageTimestamp:(uint64_t)timestamp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (BOOL)isTimestampFromLastHour:(uint64_t)timestamp; | 
					
						
							|  |  |  | // These two "exemplary" values can be used by views to measure
 | 
					
						
							|  |  |  | // the likely size for recent values formatted using isTimestampFromLastHour:.
 | 
					
						
							|  |  |  | + (NSString *)exemplaryNowTimeFormat; | 
					
						
							|  |  |  | + (NSString *)exemplaryMinutesTimeFormat; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (NSString *)formatDateForDisplay:(NSDate *)date; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (BOOL)isSameDayWithTimestamp:(uint64_t)timestamp1 timestamp:(uint64_t)timestamp2; | 
					
						
							|  |  |  | + (BOOL)isSameDayWithDate:(NSDate *)date1 date:(NSDate *)date2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (BOOL)isSameHourWithTimestamp:(uint64_t)timestamp1 timestamp:(uint64_t)timestamp2; | 
					
						
							|  |  |  | + (BOOL)isSameHourWithDate:(NSDate *)date1 date:(NSDate *)date2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | + (BOOL)shouldShowDateBreakForTimestamp:(uint64_t)timestamp1 timestamp:(uint64_t)timestamp2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | NS_ASSUME_NONNULL_END |