- December 17, 2024
- Mins Read
An iOS UICollectionViewLayout subclass to show a list of contacts with configurable expandable items.
Run the demo app and play with it! Demo App
To run the example project, clone the repo, and run pod install
from the Example directory first.
Requires iOS SDK version > 7.0
Requires ARC
CocoaPods is a 3rd-party dependency manager for Swift and Objective-C projects. For more information, refer to the CocoaPods Getting Started Guide. Otherwise, you can install CocoaPods with the following command:
$ gem install cocoapods
To integrate MEVHorizontalContacts into your Xcode project using CocoaPods, specify it in your Podfile
:
source ‘https://github.com/CocoaPods/Specs.git’
pod ‘MEVHorizontalContacts’
Then, run the following command:
$ pod install
To integrate MEVHorizontalContacts into your Xcode project manually, just include the filest from /Pod/Classes/ folder in your App’s Xcode project.
Then, import the following file your classes:
#import “MEVHorizontalContacts.h”
#import “MEVHorizontalContacts.h”
@interface ViewController () <MEVHorizontalContactsDataSource, MEVHorizontalContactsDelegate>
@property (nonatomic, strong) MEVHorizontalContacts *horizontalContacts;
@end
_horizontalContacts = [MEVHorizontalContacts new];
_horizontalContacts.backgroundColor = [UIColor whiteColor];
_horizontalContacts.dataSource = self;
_horizontalContacts.delegate = self;
[self addSubview:_horizontalContacts];
[self addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@”H:|[horizontalContacts]|” options:NSLayoutFormatAlignAllCenterX metrics:nil views:@{@”horizontalContacts” : _horizontalContacts}]];
[self addConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@”V:|[horizontalContacts]|” options:NSLayoutFormatAlignAllCenterY metrics:nil views:@{@”horizontalContacts” : _horizontalContacts}]];
#pragma mark – MEVHorizontalContactsDataSource Methods
– (NSInteger)numberOfContacts;
– (NSInteger)numberOfItemsAtContactIndex:(NSInteger)index;
– (MEVHorizontalContactsCell *)contactAtIndex:(NSInteger)index;
– (MEVHorizontalContactsCell *)item:(NSInteger)item atContactIndex:(NSInteger)index;
– (UIEdgeInsets)horizontalContactsInsets;
– (NSInteger)horizontalContactsSpacing;
#pragma mark – MEVHorizontalContactsDelegate Methods
– (void)contactSelectedAtIndex:(NSInteger)index;
– (void)item:(NSInteger)item selectedAtContactIndex:(NSInteger)index;
– (MEVHorizontalContactsCell *)contactAtIndex:(NSInteger)index {
MEVHorizontalContactsCell *cell = [_horizontalContacts dequeueReusableContactCellForIndex:index];
[cell.imageView setImage:[UIImage imageNamed:[self getImageNameAtIndex:index]]];
[cell.imageView.layer setBorderColor:[UIColor colorWithRed:34/255.0f green:167/255.0f blue:240/255.0f alpha:1].CGColor];
[cell.imageView.layer setBorderWidth:1.0f];
[cell.label setText:[self getUserNameAtIndex:index]];
[cell.label setFont:[UIFont boldSystemFontOfSize:12.0f]];
return cell;
}
– (MEVHorizontalContactsCell *)item:(NSInteger)item atContactIndex:(NSInteger)index {
UIImage *image;
NSString *labelText;
switch (item) {
case 0:
labelText = @”Call”;
image = [UIImage imageNamed:@”actionCall”];
break;
case 1:
labelText = @”Email”;
image = [UIImage imageNamed:@”actionEmail”];
break;
case 2:
labelText = @”Message”;
image = [UIImage imageNamed:@”actionMessage”];
break;
default:
labelText = @”Call”;
image = [UIImage imageNamed:@”actionCall”];
break;
}
MEVHorizontalContactsCell *cell = [_horizontalContacts dequeueReusableItemCellForIndex:index];
[cell.imageView setImage:image];
[cell.imageView setTintColor:[UIColor colorWithRed:34/255.0f green:167/255.0f blue:240/255.0f alpha:1]];
[cell.imageView.layer setBorderColor:[UIColor colorWithRed:34/255.0f green:167/255.0f blue:240/255.0f alpha:1].CGColor];
[cell.imageView.layer setBorderWidth:1.0f];
[cell.label setText:labelText];
[cell.label setFont:[UIFont boldSystemFontOfSize:10.0f]];
return cell;
}
– (MEVHorizontalContactsCell *)contactAtIndex:(NSInteger)index {
MEVHorizontalContactsCell *cell = [_horizontalContacts dequeueReusableContactCellForIndex:index];
[cell.imageView setImage:[UIImage imageNamed:[self getImageNameAtIndex:index]]];
[cell.label setText:[self getUserNameAtIndex:index]];
return cell;
}
– (MEVHorizontalContactsCell *)item:(NSInteger)item atContactIndex:(NSInteger)index {
UIImage *image;
NSString *labelText;
switch (item) {
case 0:
labelText = @”Call”;
image = [UIImage imageNamed:@”actionCall”];
break;
case 1:
labelText = @”Email”;
image = [UIImage imageNamed:@”actionEmail”];
break;
case 2:
labelText = @”Message”;
image = [UIImage imageNamed:@”actionMessage”];
break;
default:
labelText = @”Call”;
image = [UIImage imageNamed:@”actionCall”];
break;
}
MEVHorizontalContactsCell *cell = [_horizontalContacts dequeueReusableItemCellForIndex:index];
[cell.imageView setImage:image];
[cell.imageView setBackgroundColor:[UIColor colorWithRed:34/255.0f green:167/255.0f blue:240/255.0f alpha:1]];
[cell.imageView setTintColor:[UIColor whiteColor]];
[cell.label setText:labelText];
[cell.label setTextColor:[UIColor colorWithRed:34/255.0f green:167/255.0f blue:240/255.0f alpha:1]];
return cell;
}
A vertical stackview which takes subviews with different widths and adds them to it's rows with paddings, spacings etc.
AudioManager is a Swift package that provides a modular and easy-to-use interface for implementing audio feedback in your applications. It ...