123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- #import "WFCUMediaMessageCell.h"
- #import "WFCUMediaMessageDownloader.h"
- #import "HWCircleView.h"
- @interface WFCUMediaMessageCell ()
- @property (nonatomic, strong)UIView *maskView;
- @property (nonatomic, strong)UIActivityIndicatorView *activityView;
- @property (nonatomic, strong)HWCircleView *progressView;
- @end
- @implementation WFCUMediaMessageCell
- - (void)setModel:(WFCUMessageModel *)model {
- [super setModel:model];
- __weak typeof(self)ws = self;
- [[NSNotificationCenter defaultCenter] addObserverForName:kMediaMessageStartDownloading object:nil queue:[NSOperationQueue mainQueue] usingBlock:^(NSNotification * _Nonnull note) {
- if ([note.object longLongValue] == ws.model.message.messageUid) {
- [ws onStartDownloading:ws];
- }
- }];
- [[NSNotificationCenter defaultCenter] addObserverForName:kMediaMessageDownloadFinished object:nil queue:[NSOperationQueue mainQueue] usingBlock:^(NSNotification * _Nonnull note) {
- if ([note.object longLongValue] == ws.model.message.messageUid) {
- [ws onDownloadFinished:ws];
- }
- }];
-
- [[NSNotificationCenter defaultCenter] addObserverForName:kUploadMediaMessageProgresse object:@(model.message.messageId) queue:[NSOperationQueue mainQueue] usingBlock:^(NSNotification * _Nonnull note) {
- float progress = [note.userInfo[@"progress"] floatValue];
- BOOL finish = [note.userInfo[@"finish"] boolValue];
- [ws updateUploadProgress:progress finish:finish];
- }];
-
- [[NSNotificationCenter defaultCenter] addObserverForName:kSendingMessageStatusUpdated object:@(model.message.messageId) queue:[NSOperationQueue mainQueue] usingBlock:^(NSNotification * _Nonnull note) {
- WFCCMessageStatus newStatus = (WFCCMessageStatus)[[note.userInfo objectForKey:@"status"] integerValue];
- if(newStatus == Message_Status_Sent || newStatus == Message_Status_Send_Failure) {
- [ws updateUploadProgress:1 finish:YES];
- }
- }];
-
-
- if (model.mediaDownloading) {
- [self onStartDownloading:self];
- } else {
- [self onDownloadFinished:self];
- }
- }
- - (void)updateUploadProgress:(float)progress finish:(BOOL)finish {
- if(finish) {
- self.progressView.hidden = YES;
- } else {
- UIView *parentView = [self getProgressParentView];
- self.progressView.hidden = NO;
- self.progressView.progress = progress;
- [parentView bringSubviewToFront:self.progressView];
- }
- }
- - (void)onStartDownloading:(id)sender {
- if (!_maskView) {
- _maskView = [[UIView alloc] init];
- [self.bubbleView addSubview:_maskView];
- [_maskView setBackgroundColor:[UIColor grayColor]];
- [_maskView setAlpha:0.5];
- [_maskView setClipsToBounds:YES];
- }
- _maskView.frame = self.bubbleView.bounds;
- [self.bubbleView bringSubviewToFront:_maskView];
-
- if (!_activityView) {
- _activityView = [[UIActivityIndicatorView alloc] init];
- [_maskView addSubview:_activityView];
- }
- _activityView.center = CGPointMake(self.maskView.bounds.size.width/2, self.maskView.bounds.size.height/2);
- [_activityView startAnimating];
-
- }
- - (void)onDownloadFinished:(id)sender {
- if (_maskView) {
- [_maskView removeFromSuperview];
- _maskView = nil;
- }
- if (_activityView) {
- [_activityView removeFromSuperview];
- [_activityView stopAnimating];
- _activityView = nil;
- }
-
- if ([sender isKindOfClass:[NSNotification class]]) {
- NSNotification *noti = (NSNotification *)sender;
- if ([noti.userInfo[@"result"] boolValue]) {
- [self setModel:self.model];
- }
- }
- }
- - (UIView *)progressView {
- if(!_progressView) {
- _progressView = [[HWCircleView alloc] initWithFrame:[self getProgressParentView].bounds];
- [[self getProgressParentView] addSubview:_progressView];
- }
- return _progressView;
- }
- - (UIView *)getProgressParentView {
- return nil;
- }
- - (void)dealloc {
- [[NSNotificationCenter defaultCenter] removeObserver:self];
- }
- @end
|