| /* |
| Copyright 2016-present the Material Components for iOS authors. All Rights Reserved. |
| |
| Licensed under the Apache License, Version 2.0 (the "License"); |
| you may not use this file except in compliance with the License. |
| You may obtain a copy of the License at |
| |
| http://www.apache.org/licenses/LICENSE-2.0 |
| |
| Unless required by applicable law or agreed to in writing, software |
| distributed under the License is distributed on an "AS IS" BASIS, |
| WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| See the License for the specific language governing permissions and |
| limitations under the License. |
| */ |
| |
| #import "CollectionsALaCarteExample.h" |
| |
| #import "MaterialTypography.h" |
| |
| static const NSInteger kSectionCount = 10; |
| static const NSInteger kSectionItemCount = 5; |
| static NSString *const kReusableIdentifierItem = @"itemCellIdentifier"; |
| |
| #pragma mark - Custom Collection view |
| |
| /** A custom collection view. */ |
| @interface CustomCollectionView : UICollectionView |
| @end |
| |
| @implementation CustomCollectionView |
| |
| - (instancetype)initWithFrame:(CGRect)frame collectionViewLayout:(UICollectionViewLayout *)layout { |
| self = [super initWithFrame:frame collectionViewLayout:layout]; |
| if (self) { |
| // Our custom collection view settings. |
| self.backgroundColor = [UIColor lightGrayColor]; |
| self.contentInset = UIEdgeInsetsMake(40, 20, 40, 20); |
| } |
| return self; |
| } |
| |
| @end |
| |
| #pragma mark - CollectionsALaCarteExample |
| |
| /** |
| This example demonstrates how a subclass can provide its own collection view and still receive the |
| styling and editing capabilities of the MDCCollectionViewController class. |
| */ |
| @implementation CollectionsALaCarteExample { |
| CustomCollectionView *_customCollectionView; |
| NSMutableArray *_content; |
| } |
| |
| + (NSArray *)catalogBreadcrumbs { |
| return @[ @"Collections", @"Collections À la carte" ]; |
| } |
| |
| - (void)viewDidLoad { |
| [super viewDidLoad]; |
| |
| // Here we are setting a custom collection view. |
| _customCollectionView = [[CustomCollectionView alloc] initWithFrame:self.collectionView.frame |
| collectionViewLayout:self.collectionViewLayout]; |
| self.collectionView = _customCollectionView; |
| |
| // Register cell class. |
| [self.collectionView registerClass:[MDCCollectionViewTextCell class] |
| forCellWithReuseIdentifier:kReusableIdentifierItem]; |
| |
| // Populate content. |
| _content = [NSMutableArray array]; |
| for (NSInteger i = 0; i < kSectionCount; i++) { |
| NSMutableArray *items = [NSMutableArray array]; |
| for (NSInteger j = 0; j < kSectionItemCount; j++) { |
| NSString *itemString = [NSString stringWithFormat:@"Section-%zd Item-%zd", i, j]; |
| [items addObject:itemString]; |
| } |
| [_content addObject:items]; |
| } |
| |
| // Customize collection view settings. |
| self.styler.cellStyle = MDCCollectionViewCellStyleCard; |
| } |
| |
| #pragma mark - <UICollectionViewDataSource> |
| |
| - (NSInteger)numberOfSectionsInCollectionView:(UICollectionView *)collectionView { |
| return [_content count]; |
| } |
| |
| - (NSInteger)collectionView:(UICollectionView *)collectionView |
| numberOfItemsInSection:(NSInteger)section { |
| return [_content[section] count]; |
| } |
| |
| - (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView |
| cellForItemAtIndexPath:(NSIndexPath *)indexPath { |
| MDCCollectionViewTextCell *cell = |
| [collectionView dequeueReusableCellWithReuseIdentifier:kReusableIdentifierItem |
| forIndexPath:indexPath]; |
| cell.textLabel.text = _content[indexPath.section][indexPath.item]; |
| return cell; |
| } |
| |
| #pragma mark - <MDCCollectionViewEditingDelegate> |
| |
| - (BOOL)collectionViewAllowsSwipeToDismissItem:(UICollectionView *)collectionView { |
| return YES; |
| } |
| |
| - (BOOL)collectionView:(UICollectionView *)collectionView |
| canSwipeToDismissItemAtIndexPath:(NSIndexPath *)indexPath { |
| // In this example we are allowing all items to be dismissed. |
| return YES; |
| } |
| |
| - (void)collectionView:(UICollectionView *)collectionView |
| willDeleteItemsAtIndexPaths:(NSArray<NSIndexPath *> *)indexPaths { |
| // Remove these swiped index paths from our data. |
| for (NSIndexPath *indexPath in indexPaths) { |
| [_content[indexPath.section] removeObjectAtIndex:indexPath.item]; |
| } |
| } |
| |
| @end |