204 lines
7.5 KiB
Objective-C
204 lines
7.5 KiB
Objective-C
//
|
|
// TUIReactPopContextRecentView.m
|
|
// TUIChat
|
|
//
|
|
// Created by wyl on 2022/10/24.
|
|
// Copyright © 2023 Tencent. All rights reserved.
|
|
//
|
|
|
|
#import "TUIReactPopContextRecentView.h"
|
|
#import <TIMCommon/NSString+TUIEmoji.h>
|
|
#import <TIMCommon/TIMCommonModel.h>
|
|
#import <TIMCommon/TIMDefine.h>
|
|
#import <TIMCommon/TUIFitButton.h>
|
|
#import <TIMCommon/TIMCommonMediator.h>
|
|
#import <TIMCommon/TUIEmojiMeditorProtocol.h>
|
|
#import "TUIReactContextEmojiDetailController.h"
|
|
#import "TUIMessageCellData+Reaction.h"
|
|
#define kTIMRecentDefaultEmojiSize CGSizeMake(25, 25)
|
|
|
|
@interface TUIReactPopContextRecentView ()
|
|
@property(nonatomic, strong) NSMutableArray *sectionIndexInGroup;
|
|
@property(nonatomic, strong) NSMutableArray *pageCountInGroup;
|
|
@property(nonatomic, strong) NSMutableArray *groupIndexInSection;
|
|
@property(nonatomic, strong) NSMutableDictionary *itemIndexs;
|
|
@property(nonatomic, assign) NSInteger sectionCount;
|
|
@end
|
|
@implementation TUIReactPopContextRecentView
|
|
|
|
- (void)layoutSubviews {
|
|
[super layoutSubviews];
|
|
[self defaultLayout];
|
|
}
|
|
|
|
- (void)defaultLayout {
|
|
[self setupCorner];
|
|
[self setupDefaultArray];
|
|
}
|
|
|
|
- (void)setupCorner {
|
|
UIRectCorner corner = UIRectCornerAllCorners;
|
|
UIBezierPath *maskPath = [UIBezierPath bezierPathWithRoundedRect:self.bounds byRoundingCorners:corner cornerRadii:CGSizeMake(kScale390(22), kScale390(22))];
|
|
CAShapeLayer *maskLayer = [[CAShapeLayer alloc] init];
|
|
maskLayer.frame = self.bounds;
|
|
maskLayer.path = maskPath.CGPath;
|
|
self.layer.mask = maskLayer;
|
|
}
|
|
|
|
- (void)setupDefaultArray {
|
|
NSMutableArray *faceArray = [NSMutableArray array];
|
|
TUIFaceGroup *defaultFaceGroup = [self findFaceGroupAboutType];
|
|
if (defaultFaceGroup) {
|
|
[faceArray addObject:defaultFaceGroup];
|
|
}
|
|
[self setData:faceArray];
|
|
}
|
|
|
|
- (void)setData:(NSMutableArray *)data {
|
|
_faceGroups = data;
|
|
_sectionIndexInGroup = [NSMutableArray array];
|
|
_groupIndexInSection = [NSMutableArray array];
|
|
_itemIndexs = [NSMutableDictionary dictionary];
|
|
|
|
NSInteger sectionIndex = 0;
|
|
for (NSInteger groupIndex = 0; groupIndex < _faceGroups.count; ++groupIndex) {
|
|
TUIFaceGroup *group = _faceGroups[groupIndex];
|
|
[_sectionIndexInGroup addObject:@(sectionIndex)];
|
|
int itemCount = group.rowCount * group.itemCountPerRow;
|
|
int sectionCount = ceil(group.faces.count * 1.0 / (itemCount - 0));
|
|
for (int sectionIndex = 0; sectionIndex < sectionCount; ++sectionIndex) {
|
|
[_groupIndexInSection addObject:@(groupIndex)];
|
|
}
|
|
sectionIndex += sectionCount;
|
|
}
|
|
_sectionCount = sectionIndex;
|
|
|
|
for (NSInteger curSection = 0; curSection < _sectionCount; ++curSection) {
|
|
NSNumber *groupIndex = _groupIndexInSection[curSection];
|
|
NSNumber *groupSectionIndex = _sectionIndexInGroup[groupIndex.integerValue];
|
|
TUIFaceGroup *face = _faceGroups[groupIndex.integerValue];
|
|
NSInteger itemCount = face.rowCount * face.itemCountPerRow;
|
|
NSInteger groupSection = curSection - groupSectionIndex.integerValue;
|
|
for (NSInteger itemIndex = 0; itemIndex < itemCount; ++itemIndex) {
|
|
// transpose line/row
|
|
NSInteger row = itemIndex % face.rowCount;
|
|
NSInteger column = itemIndex / face.rowCount;
|
|
NSInteger reIndex = face.itemCountPerRow * row + column + groupSection * itemCount;
|
|
[_itemIndexs setObject:@(reIndex) forKey:[NSIndexPath indexPathForRow:itemIndex inSection:curSection]];
|
|
}
|
|
}
|
|
|
|
[self createBtns];
|
|
|
|
if (self.needShowbottomLine) {
|
|
float margin = 20;
|
|
|
|
UIView *line = [[UIView alloc] initWithFrame:CGRectMake(margin, self.frame.size.height - 1, self.frame.size.width - 2 * margin, 0.5)];
|
|
;
|
|
[self addSubview:line];
|
|
line.backgroundColor = TIMCommonDynamicColor(@"separator_color", @"#DBDBDB");
|
|
}
|
|
}
|
|
|
|
- (TUIFaceGroup *)findFaceGroupAboutType {
|
|
// emoji group
|
|
id<TUIEmojiMeditorProtocol> service = [[TIMCommonMediator share] getObject:@protocol(TUIEmojiMeditorProtocol)];
|
|
TUIFaceGroup * group = [service getChatPopMenuRecentQueue];
|
|
group.faces = [NSMutableArray arrayWithArray:[group.faces subarrayWithRange:NSMakeRange(0, 6)]];
|
|
return group;
|
|
}
|
|
|
|
- (void)createBtns {
|
|
if (self.subviews) {
|
|
for (UIView *subView in self.subviews) {
|
|
[subView removeFromSuperview];
|
|
}
|
|
}
|
|
int groupIndex = [_groupIndexInSection[0] intValue];
|
|
TUIFaceGroup *group = _faceGroups[groupIndex];
|
|
int tag = 0;
|
|
float margin = kScale390(8);
|
|
float padding = kScale390(2);
|
|
|
|
UIButton *preBtn = nil;
|
|
for (TUIFaceCellData *cellData in group.faces) {
|
|
UIButton *button = [self buttonWithCellImage:[[TUIImageCache sharedInstance] getFaceFromCache:cellData.path] Tag:tag];
|
|
[self addSubview:button];
|
|
if (tag == 0) {
|
|
button.mm_width(kTIMRecentDefaultEmojiSize.width).mm_height( kTIMRecentDefaultEmojiSize.height).mm_left(margin).mm_top(kScale390(8));
|
|
} else {
|
|
button.mm_width(kTIMRecentDefaultEmojiSize.width).mm_height( kTIMRecentDefaultEmojiSize.height).mm_left(preBtn.mm_x + preBtn.mm_w + padding).mm_top(kScale390(8));
|
|
}
|
|
tag++;
|
|
preBtn = button;
|
|
}
|
|
|
|
self.arrowButton = [self buttonWithCellImage:[UIImage imageNamed:TUIChatImagePath_Minimalist(@"icon_emoji_more")] Tag:999];
|
|
[self addSubview:self.arrowButton];
|
|
|
|
self.arrowButton.mm_width(kScale390(24)).mm_height(kScale390(24)).mm_right(margin).mm_top(kScale390(8));
|
|
if (isRTL()) {
|
|
for (UIView *subview in self.subviews) {
|
|
[subview resetFrameToFitRTL];
|
|
}
|
|
}
|
|
}
|
|
|
|
- (UIButton *)buttonWithCellImage:(UIImage *)img Tag:(NSInteger)tag {
|
|
TUIFitButton *actionButton = [TUIFitButton buttonWithType:UIButtonTypeCustom];
|
|
actionButton.imageSize = CGSizeMake(kTIMRecentDefaultEmojiSize.width,kTIMRecentDefaultEmojiSize.height);
|
|
[actionButton setImage:img forState:UIControlStateNormal];
|
|
actionButton.contentMode = UIViewContentModeScaleAspectFit;
|
|
[actionButton addTarget:self action:@selector(onClick:) forControlEvents:UIControlEventTouchUpInside];
|
|
actionButton.tag = tag;
|
|
return actionButton;
|
|
}
|
|
|
|
- (void)onClick:(UIButton *)btn {
|
|
if (btn.tag == 999) {
|
|
btn.selected = !btn.selected;
|
|
[self showDetailPage];
|
|
} else {
|
|
TUIFaceGroup *group = self.faceGroups[0];
|
|
TUIFaceCellData *face = group.faces[btn.tag];
|
|
NSString *faceName = face.name;
|
|
[self updateReactClick:faceName];
|
|
if (_delegateVC) {
|
|
[_delegateVC blurDismissViewControllerAnimated:YES completion:^(BOOL finished) {
|
|
|
|
}];
|
|
}
|
|
}
|
|
}
|
|
|
|
- (void)showDetailPage {
|
|
TUIReactContextEmojiDetailController *detailController = [[TUIReactContextEmojiDetailController alloc] init];
|
|
detailController.modalPresentationStyle = UIModalPresentationCustom;
|
|
__weak typeof(self) weakSelf = self;
|
|
detailController.reactClickCallback = ^(NSString *_Nonnull faceName) {
|
|
__strong typeof(weakSelf) strongSelf = weakSelf;
|
|
[weakSelf updateReactClick:faceName];
|
|
if (weakSelf.delegateVC) {
|
|
[weakSelf.delegateVC blurDismissViewControllerAnimated:YES completion:^(BOOL finished) {
|
|
|
|
}];
|
|
}
|
|
};
|
|
[self.mm_viewController presentViewController:detailController animated:YES completion:nil];
|
|
}
|
|
- (void)hideDetailPage {
|
|
if (self.delegateVC) {
|
|
[self.delegateVC blurDismissViewControllerAnimated:YES completion:^(BOOL finished) {
|
|
|
|
}];
|
|
}
|
|
}
|
|
|
|
- (void)updateReactClick:(NSString *)faceName {
|
|
if (self.delegateVC.alertViewCellData) {
|
|
[self.delegateVC.alertViewCellData updateReactClick:faceName];
|
|
}
|
|
}
|
|
|
|
@end
|