Full Code of marcosgriselli/ViewAnimator for AI

master 653a71588ecf cached
75 files
172.8 KB
48.7k tokens
1 requests
Download .txt
Repository: marcosgriselli/ViewAnimator
Branch: master
Commit: 653a71588ecf
Files: 75
Total size: 172.8 KB

Directory structure:
gitextract_e466d0tl/

├── .gitattributes
├── .github/
│   ├── CODE_OF_CONDUCT.md
│   └── ISSUE_TEMPLATE.md
├── .gitignore
├── Example/
│   ├── iOS/
│   │   ├── AppDelegate.swift
│   │   ├── Assets.xcassets/
│   │   │   ├── 0.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── 1.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── 2.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── 3.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── 4.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── AppIcon.appiconset/
│   │   │   │   └── Contents.json
│   │   │   ├── Contents.json
│   │   │   ├── background.imageset/
│   │   │   │   └── Contents.json
│   │   │   └── icon.imageset/
│   │   │       └── Contents.json
│   │   ├── Base.lproj/
│   │   │   ├── LaunchScreen.storyboard
│   │   │   └── Main.storyboard
│   │   ├── Info.plist
│   │   ├── ViewControllers/
│   │   │   ├── CollectionViewController.swift
│   │   │   ├── TableViewController.swift
│   │   │   └── ViewController.swift
│   │   └── Views/
│   │       ├── Cells/
│   │       │   ├── CollectionViewCell.swift
│   │       │   └── TableViewCell.swift
│   │       └── Designable.swift
│   └── tvOS/
│       ├── AppDelegate.swift
│       ├── Assets.xcassets/
│       │   ├── App Icon & Top Shelf Image.brandassets/
│       │   │   ├── App Icon - App Store.imagestack/
│       │   │   │   ├── Contents.json
│       │   │   │   ├── tv-icon-back.imagestacklayer/
│       │   │   │   │   ├── Content.imageset/
│       │   │   │   │   │   └── Contents.json
│       │   │   │   │   └── Contents.json
│       │   │   │   └── tv-icon-front.imagestacklayer/
│       │   │   │       ├── Content.imageset/
│       │   │   │       │   └── Contents.json
│       │   │   │       └── Contents.json
│       │   │   ├── App Icon.imagestack/
│       │   │   │   ├── Contents.json
│       │   │   │   ├── tv-icon-back.imagestacklayer/
│       │   │   │   │   ├── Content.imageset/
│       │   │   │   │   │   └── Contents.json
│       │   │   │   │   └── Contents.json
│       │   │   │   └── tv-icon-front.imagestacklayer/
│       │   │   │       ├── Content.imageset/
│       │   │   │       │   └── Contents.json
│       │   │   │       └── Contents.json
│       │   │   ├── Contents.json
│       │   │   ├── Top Shelf Image Wide.imageset/
│       │   │   │   └── Contents.json
│       │   │   └── Top Shelf Image.imageset/
│       │   │       └── Contents.json
│       │   ├── Contents.json
│       │   ├── Launch Image.launchimage/
│       │   │   └── Contents.json
│       │   ├── detail_1.imageset/
│       │   │   └── Contents.json
│       │   ├── detail_2.imageset/
│       │   │   └── Contents.json
│       │   ├── detail_3.imageset/
│       │   │   └── Contents.json
│       │   ├── detail_4.imageset/
│       │   │   └── Contents.json
│       │   ├── detail_5.imageset/
│       │   │   └── Contents.json
│       │   └── detail_6.imageset/
│       │       └── Contents.json
│       ├── Base.lproj/
│       │   └── Main.storyboard
│       ├── Cells/
│       │   └── CollectionViewCell.swift
│       ├── CollectionViewController.swift
│       └── Info.plist
├── Gemfile
├── LICENSE
├── Package.swift
├── README.md
├── Sources/
│   ├── .gitkeep
│   ├── Extensions/
│   │   ├── UICollectionView + ViewAnimator.swift
│   │   └── UITableView + ViewAnimator.swift
│   ├── Models/
│   │   ├── AnimationType.swift
│   │   └── Directions.swift
│   ├── Protocols/
│   │   └── Animation.swift
│   ├── ViewAnimator.swift
│   └── ViewAnimatorConfig.swift
├── ViewAnimator.podspec
├── ViewAnimator.xcodeproj/
│   ├── ViewAnimator_Info.plist
│   ├── project.pbxproj
│   ├── project.xcworkspace/
│   │   ├── contents.xcworkspacedata
│   │   └── xcshareddata/
│   │       ├── IDEWorkspaceChecks.plist
│   │       └── WorkspaceSettings.xcsettings
│   └── xcshareddata/
│       └── xcschemes/
│           ├── ViewAnimator-Package.xcscheme
│           ├── ViewAnimator-iOS.xcscheme
│           ├── ViewAnimator-tvOS.xcscheme
│           └── ViewAnimator.xcscheme
├── ViewAnimatorTests/
│   ├── Info.plist
│   └── Tests.swift
└── fastlane/
    ├── Appfile
    └── Fastfile

================================================
FILE CONTENTS
================================================

================================================
FILE: .gitattributes
================================================
*.sh linguist-language=Swift
*.m linguist-language=Swift
*.h linguist-language=Swift
*.rb linguist-language=Swift


================================================
FILE: .github/CODE_OF_CONDUCT.md
================================================
# Contributor Covenant Code of Conduct

## Our Pledge

In the interest of fostering an open and welcoming environment, we as contributors and maintainers pledge to making participation in our project and our community a harassment-free experience for everyone, regardless of age, body size, disability, ethnicity, gender identity and expression, level of experience, nationality, personal appearance, race, religion, or sexual identity and orientation.

## Our Standards

Examples of behavior that contributes to creating a positive environment include:

* Using welcoming and inclusive language
* Being respectful of differing viewpoints and experiences
* Gracefully accepting constructive criticism
* Focusing on what is best for the community
* Showing empathy towards other community members

Examples of unacceptable behavior by participants include:

* The use of sexualized language or imagery and unwelcome sexual attention or advances
* Trolling, insulting/derogatory comments, and personal or political attacks
* Public or private harassment
* Publishing others' private information, such as a physical or electronic address, without explicit permission
* Other conduct which could reasonably be considered inappropriate in a professional setting

## Our Responsibilities

Project maintainers are responsible for clarifying the standards of acceptable behavior and are expected to take appropriate and fair corrective action in response to any instances of unacceptable behavior.

Project maintainers have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, or to ban temporarily or permanently any contributor for other behaviors that they deem inappropriate, threatening, offensive, or harmful.

## Scope

This Code of Conduct applies both within project spaces and in public spaces when an individual is representing the project or its community. Examples of representing a project or community include using an official project e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event. Representation of a project may be further defined and clarified by project maintainers.

## Enforcement

Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by contacting the project team at marcosgriselli@gmail.com. The project team will review and investigate all complaints, and will respond in a way that it deems appropriate to the circumstances. The project team is obligated to maintain confidentiality with regard to the reporter of an incident. Further details of specific enforcement policies may be posted separately.

Project maintainers who do not follow or enforce the Code of Conduct in good faith may face temporary or permanent repercussions as determined by other members of the project's leadership.

## Attribution

This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, available at [http://contributor-covenant.org/version/1/4][version]

[homepage]: http://contributor-covenant.org
[version]: http://contributor-covenant.org/version/1/4/


================================================
FILE: .github/ISSUE_TEMPLATE.md
================================================
## Expected Behavior


## Actual Behavior


## Steps to Reproduce the Problem

  1.
  1.
  1.

## Specifications

  - Version:
  - Platform:
  - Subsystem:


================================================
FILE: .gitignore
================================================
# OS X
.DS_Store

# Xcode
build/
*.pbxuser
!default.pbxuser
*.mode1v3
!default.mode1v3
*.mode2v3
!default.mode2v3
*.perspectivev3
!default.perspectivev3
xcuserdata/
*.xccheckout
profile
*.moved-aside
DerivedData
*.hmap
*.ipa

# Bundler
.bundle

# Carthage
#
# Add this line if you want to avoid checking in source code from Carthage dependencies.
# Carthage/Checkouts
#
Carthage/Build

# Swift Package Manager
.build/

# fastlane
# 
# It is recommended to not store the screenshots in the git repo. Instead, use fastlane to re-generate the
# screenshots whenever they are needed.
# For more information about the recommended setup visit:
# https://github.com/fastlane/fastlane/blob/master/fastlane/docs/Gitignore.md

fastlane/report.xml
fastlane/Preview.html
fastlane/screenshots
fastlane/test_output
fastlane/README.md


================================================
FILE: Example/iOS/AppDelegate.swift
================================================
//
//  AppDelegate.swift
//  ViewAnimator-iOS
//
//  Created by Marcos Griselli on 29/08/2020.
//

import UIKit

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?


    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        // Override point for customization after application launch.
        return true
    }

    func applicationWillResignActive(_ application: UIApplication) {
        // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
        // Use this method to pause ongoing tasks, disable timers, and invalidate graphics rendering callbacks. Games should use this method to pause the game.
    }

    func applicationDidEnterBackground(_ application: UIApplication) {
        // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
        // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
    }

    func applicationWillEnterForeground(_ application: UIApplication) {
        // Called as part of the transition from the background to the active state; here you can undo many of the changes made on entering the background.
    }

    func applicationDidBecomeActive(_ application: UIApplication) {
        // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
    }

    func applicationWillTerminate(_ application: UIApplication) {
        // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
    }


}



================================================
FILE: Example/iOS/Assets.xcassets/0.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "5.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "5@2x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "filename" : "5@3x.png",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/iOS/Assets.xcassets/1.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "1.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "1@2x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "filename" : "1@3x.png",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/iOS/Assets.xcassets/2.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "2.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "2@2x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "filename" : "2@3x.png",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/iOS/Assets.xcassets/3.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "3.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "3@2x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "filename" : "3@3x.png",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/iOS/Assets.xcassets/4.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "4.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "4@2x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "filename" : "4@3x.png",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/iOS/Assets.xcassets/AppIcon.appiconset/Contents.json
================================================
{
  "info" : {
    "version" : 1,
    "author" : "xcode"
  },
  "images" : [
    {
      "filename" : "Icon-40.png",
      "size" : "40x40",
      "idiom" : "ipad",
      "scale" : "1x"
    },
    {
      "filename" : "Icon-40@2x.png",
      "size" : "40x40",
      "idiom" : "ipad",
      "scale" : "2x"
    },
    {
      "filename" : "Icon-60@2x.png",
      "size" : "60x60",
      "idiom" : "iphone",
      "scale" : "2x"
    },
    {
      "filename" : "Icon-72.png",
      "size" : "72x72",
      "idiom" : "ipad",
      "scale" : "1x"
    },
    {
      "filename" : "Icon-72@2x.png",
      "size" : "72x72",
      "idiom" : "ipad",
      "scale" : "2x"
    },
    {
      "filename" : "Icon-76.png",
      "size" : "76x76",
      "idiom" : "ipad",
      "scale" : "1x"
    },
    {
      "filename" : "Icon-76@2x.png",
      "size" : "76x76",
      "idiom" : "ipad",
      "scale" : "2x"
    },
    {
      "filename" : "Icon-Small-50.png",
      "size" : "50x50",
      "idiom" : "ipad",
      "scale" : "1x"
    },
    {
      "filename" : "Icon-Small-50@2x.png",
      "size" : "50x50",
      "idiom" : "ipad",
      "scale" : "2x"
    },
    {
      "filename" : "Icon-Small.png",
      "size" : "29x29",
      "idiom" : "iphone",
      "scale" : "1x"
    },
    {
      "filename" : "Icon-Small@2x.png",
      "size" : "29x29",
      "idiom" : "iphone",
      "scale" : "2x"
    },
    {
      "filename" : "Icon.png",
      "size" : "57x57",
      "idiom" : "iphone",
      "scale" : "1x"
    },
    {
      "filename" : "Icon@2x.png",
      "size" : "57x57",
      "idiom" : "iphone",
      "scale" : "2x"
    },
    {
      "filename" : "Icon-Small@3x.png",
      "size" : "29x29",
      "idiom" : "iphone",
      "scale" : "3x"
    },
    {
      "filename" : "Icon-40@3x.png",
      "size" : "40x40",
      "idiom" : "iphone",
      "scale" : "3x"
    },
    {
      "filename" : "Icon-60@3x.png",
      "size" : "60x60",
      "idiom" : "iphone",
      "scale" : "3x"
    },
    {
      "filename" : "Icon-40@2x.png",
      "size" : "40x40",
      "idiom" : "iphone",
      "scale" : "2x"
    },
    {
      "filename" : "Icon-Small.png",
      "size" : "29x29",
      "idiom" : "ipad",
      "scale" : "1x"
    },
    {
      "filename" : "Icon-Small@2x.png",
      "size" : "29x29",
      "idiom" : "ipad",
      "scale" : "2x"
    },
    {
      "filename" : "Icon-83.5@2x.png",
      "size" : "83.5x83.5",
      "idiom" : "ipad",
      "scale" : "2x"
    },
    {
      "filename" : "NotificationIcon@2x.png",
      "size" : "20x20",
      "idiom" : "iphone",
      "scale" : "2x"
    },
    {
      "filename" : "NotificationIcon@3x.png",
      "size" : "20x20",
      "idiom" : "iphone",
      "scale" : "3x"
    },
    {
      "filename" : "NotificationIcon~ipad.png",
      "size" : "20x20",
      "idiom" : "ipad",
      "scale" : "1x"
    },
    {
      "filename" : "NotificationIcon~ipad@2x.png",
      "size" : "20x20",
      "idiom" : "ipad",
      "scale" : "2x"
    },
    {
      "filename" : "ios-marketing.png",
      "size" : "1024x1024",
      "idiom" : "ios-marketing",
      "scale" : "1x"
    }
  ]
}

================================================
FILE: Example/iOS/Assets.xcassets/Contents.json
================================================
{
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/iOS/Assets.xcassets/background.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "background.pdf"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/iOS/Assets.xcassets/icon.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "icon.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "icon@2x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "filename" : "icon@3x.png",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/iOS/Base.lproj/LaunchScreen.storyboard
================================================
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="13122.16" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" launchScreen="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES" initialViewController="01J-lp-oVM">
    <dependencies>
        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="13104.12"/>
        <capability name="Safe area layout guides" minToolsVersion="9.0"/>
        <capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
    </dependencies>
    <scenes>
        <!--View Controller-->
        <scene sceneID="EHf-IW-A2E">
            <objects>
                <viewController id="01J-lp-oVM" sceneMemberID="viewController">
                    <view key="view" contentMode="scaleToFill" id="Ze5-6b-2t3">
                        <rect key="frame" x="0.0" y="0.0" width="375" height="667"/>
                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
                        <color key="backgroundColor" red="1" green="1" blue="1" alpha="1" colorSpace="custom" customColorSpace="sRGB"/>
                        <viewLayoutGuide key="safeArea" id="6Tk-OE-BBY"/>
                    </view>
                </viewController>
                <placeholder placeholderIdentifier="IBFirstResponder" id="iYj-Kq-Ea1" userLabel="First Responder" sceneMemberID="firstResponder"/>
            </objects>
            <point key="canvasLocation" x="53" y="375"/>
        </scene>
    </scenes>
</document>


================================================
FILE: Example/iOS/Base.lproj/Main.storyboard
================================================
<?xml version="1.0" encoding="UTF-8"?>
<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="15505" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" colorMatched="YES" initialViewController="bTT-jA-UgM">
    <device id="retina5_9" orientation="portrait" appearance="light"/>
    <dependencies>
        <deployment identifier="iOS"/>
        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="15510"/>
        <capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
    </dependencies>
    <scenes>
        <!--Tab Bar Controller-->
        <scene sceneID="RvZ-0K-ceI">
            <objects>
                <tabBarController id="bTT-jA-UgM" sceneMemberID="viewController">
                    <extendedEdge key="edgesForExtendedLayout" top="YES"/>
                    <tabBar key="tabBar" contentMode="scaleToFill" insetsLayoutMarginsFromSafeArea="NO" id="YGT-5p-WJl">
                        <rect key="frame" x="0.0" y="0.0" width="375" height="49"/>
                        <autoresizingMask key="autoresizingMask"/>
                        <color key="backgroundColor" white="0.0" alpha="0.0" colorSpace="calibratedWhite"/>
                    </tabBar>
                    <connections>
                        <segue destination="vXZ-lx-hvc" kind="relationship" relationship="viewControllers" id="dEP-m2-NkK"/>
                        <segue destination="y9f-iQ-3Do" kind="relationship" relationship="viewControllers" id="2NJ-V0-bGw"/>
                        <segue destination="d6M-ta-yMh" kind="relationship" relationship="viewControllers" id="vzR-dg-agj"/>
                    </connections>
                </tabBarController>
                <placeholder placeholderIdentifier="IBFirstResponder" id="2Fg-gg-Ro8" userLabel="First Responder" sceneMemberID="firstResponder"/>
            </objects>
            <point key="canvasLocation" x="-393" y="33"/>
        </scene>
        <!--Full View-->
        <scene sceneID="ufC-wZ-h7g">
            <objects>
                <viewController storyboardIdentifier="ViewController" id="vXZ-lx-hvc" customClass="ViewController" customModule="ViewAnimator_Example" customModuleProvider="target" sceneMemberID="viewController">
                    <layoutGuides>
                        <viewControllerLayoutGuide type="top" id="jyV-Pf-zRb"/>
                        <viewControllerLayoutGuide type="bottom" id="2fi-mo-0CV"/>
                    </layoutGuides>
                    <view key="view" contentMode="scaleToFill" id="kh9-bI-dsS">
                        <rect key="frame" x="0.0" y="0.0" width="375" height="812"/>
                        <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
                        <subviews>
                            <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="SUNDAY, OCTOBER 8" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="hW6-Of-57y">
                                <rect key="frame" x="14" y="70" width="132" height="16"/>
                                <fontDescription key="fontDescription" type="system" pointSize="13"/>
                                <nil key="textColor"/>
                                <nil key="highlightedColor"/>
                            </label>
                            <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Memories" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="qoX-Tp-oK7">
                                <rect key="frame" x="14" y="86" width="169" height="41"/>
                                <fontDescription key="fontDescription" type="system" weight="black" pointSize="34"/>
                                <nil key="textColor"/>
                                <nil key="highlightedColor"/>
                            </label>
                            <collectionView clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="scaleToFill" dataMode="prototypes" translatesAutoresizingMaskIntoConstraints="NO" id="62B-9S-MCt">
                                <rect key="frame" x="0.0" y="142" width="375" height="130"/>
                                <color key="backgroundColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
                                <constraints>
                                    <constraint firstAttribute="height" constant="130" id="Aqy-PL-2ZZ"/>
                                </constraints>
                                <collectionViewFlowLayout key="collectionViewLayout" scrollDirection="horizontal" minimumLineSpacing="10" minimumInteritemSpacing="10" id="AyM-oE-5jK">
                                    <size key="itemSize" width="100" height="100"/>
                                    <size key="headerReferenceSize" width="0.0" height="0.0"/>
                                    <size key="footerReferenceSize" width="0.0" height="0.0"/>
                                    <inset key="sectionInset" minX="14" minY="0.0" maxX="14" maxY="0.0"/>
                                </collectionViewFlowLayout>
                                <cells>
                                    <collectionViewCell opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" restorationIdentifier="cell" reuseIdentifier="cell" id="aGU-Gs-wjU" customClass="CollectionViewCell" customModule="ViewAnimator_Example" customModuleProvider="target">
                                        <rect key="frame" x="14" y="15" width="100" height="100"/>
                                        <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
                                        <view key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" insetsLayoutMarginsFromSafeArea="NO">
                                            <rect key="frame" x="0.0" y="0.0" width="100" height="100"/>
                                            <autoresizingMask key="autoresizingMask"/>
                                        </view>
                                    </collectionViewCell>
                                </cells>
                                <userDefinedRuntimeAttributes>
                                    <userDefinedRuntimeAttribute type="number" keyPath="cornerRadius">
                                        <real key="value" value="5"/>
                                    </userDefinedRuntimeAttribute>
                                    <userDefinedRuntimeAttribute type="number" keyPath="shadowRadius">
                                        <real key="value" value="4"/>
                                    </userDefinedRuntimeAttribute>
                                    <userDefinedRuntimeAttribute type="number" keyPath="shadowOpacity">
                                        <real key="value" value="0.10000000000000001"/>
                                    </userDefinedRuntimeAttribute>
                                    <userDefinedRuntimeAttribute type="size" keyPath="shadowOffset">
                                        <size key="value" width="1" height="2"/>
                                    </userDefinedRuntimeAttribute>
                                    <userDefinedRuntimeAttribute type="color" keyPath="shadowColor">
                                        <color key="value" white="0.0" alpha="1" colorSpace="calibratedWhite"/>
                                    </userDefinedRuntimeAttribute>
                                </userDefinedRuntimeAttributes>
                            </collectionView>
                            <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="People" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="YIm-4U-abp">
                                <rect key="frame" x="14.000000000000007" y="287" width="117.66666666666669" height="41"/>
                                <fontDescription key="fontDescription" type="system" weight="black" pointSize="34"/>
                                <nil key="textColor"/>
                                <nil key="highlightedColor"/>
                            </label>
                            <tableView clipsSubviews="YES" contentMode="scaleToFill" alwaysBounceVertical="YES" dataMode="prototypes" style="plain" separatorStyle="default" rowHeight="60" estimatedRowHeight="-1" sectionHeaderHeight="28" sectionFooterHeight="28" contentViewInsetsToSafeArea="NO" translatesAutoresizingMaskIntoConstraints="NO" id="dvM-fY-6Tr">
                                <rect key="frame" x="0.0" y="343" width="375" height="386"/>
                                <color key="backgroundColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
                                <inset key="separatorInset" minX="69" minY="0.0" maxX="0.0" maxY="0.0"/>
                                <prototypes>
                                    <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" insetsLayoutMarginsFromSafeArea="NO" selectionStyle="none" accessoryType="disclosureIndicator" hidesAccessoryWhenEditing="NO" indentationLevel="1" indentationWidth="0.0" reuseIdentifier="tableCell" rowHeight="60" id="vMW-1T-s5f" customClass="TableViewCell" customModule="ViewAnimator_Example" customModuleProvider="target">
                                        <rect key="frame" x="0.0" y="28" width="375" height="60"/>
                                        <autoresizingMask key="autoresizingMask"/>
                                        <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" insetsLayoutMarginsFromSafeArea="NO" tableViewCell="vMW-1T-s5f" id="0mw-bg-mOo">
                                            <rect key="frame" x="0.0" y="0.0" width="349" height="60"/>
                                            <autoresizingMask key="autoresizingMask"/>
                                            <subviews>
                                                <imageView clipsSubviews="YES" userInteractionEnabled="NO" contentMode="scaleToFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" translatesAutoresizingMaskIntoConstraints="NO" id="zNY-Kw-AI8">
                                                    <rect key="frame" x="14" y="7.6666666666666679" width="45" height="45"/>
                                                    <constraints>
                                                        <constraint firstAttribute="width" constant="45" id="Qih-Zu-zLY"/>
                                                        <constraint firstAttribute="width" secondItem="zNY-Kw-AI8" secondAttribute="height" multiplier="1:1" id="oO6-Wt-RfM"/>
                                                    </constraints>
                                                    <userDefinedRuntimeAttributes>
                                                        <userDefinedRuntimeAttribute type="number" keyPath="cornerRadius">
                                                            <real key="value" value="22.5"/>
                                                        </userDefinedRuntimeAttribute>
                                                    </userDefinedRuntimeAttributes>
                                                </imageView>
                                                <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="User name" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="oy2-kP-1fR">
                                                    <rect key="frame" x="74" y="19.666666666666668" width="83" height="21.000000000000004"/>
                                                    <fontDescription key="fontDescription" type="system" pointSize="17"/>
                                                    <nil key="textColor"/>
                                                    <nil key="highlightedColor"/>
                                                </label>
                                            </subviews>
                                            <constraints>
                                                <constraint firstItem="zNY-Kw-AI8" firstAttribute="leading" secondItem="0mw-bg-mOo" secondAttribute="leading" constant="14" id="16F-fc-xWG"/>
                                                <constraint firstAttribute="trailing" relation="greaterThanOrEqual" secondItem="oy2-kP-1fR" secondAttribute="trailing" constant="20" symbolic="YES" id="PVF-is-W6n"/>
                                                <constraint firstItem="zNY-Kw-AI8" firstAttribute="centerY" secondItem="0mw-bg-mOo" secondAttribute="centerY" id="WrC-d7-nAx"/>
                                                <constraint firstItem="oy2-kP-1fR" firstAttribute="centerY" secondItem="zNY-Kw-AI8" secondAttribute="centerY" id="rF3-lO-V7E"/>
                                                <constraint firstItem="oy2-kP-1fR" firstAttribute="leading" secondItem="zNY-Kw-AI8" secondAttribute="trailing" constant="15" id="tw1-YN-OWL"/>
                                            </constraints>
                                        </tableViewCellContentView>
                                        <connections>
                                            <outlet property="label" destination="oy2-kP-1fR" id="wKP-oh-ofN"/>
                                            <outlet property="userImageView" destination="zNY-Kw-AI8" id="Xed-qz-vfT"/>
                                        </connections>
                                    </tableViewCell>
                                </prototypes>
                            </tableView>
                            <button opaque="NO" contentMode="scaleToFill" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="4zt-0R-iYI">
                                <rect key="frame" x="292" y="53" width="67" height="50"/>
                                <constraints>
                                    <constraint firstAttribute="height" constant="50" id="tPW-WK-mft"/>
                                </constraints>
                                <fontDescription key="fontDescription" type="system" weight="semibold" pointSize="17"/>
                                <state key="normal" title="Animate"/>
                                <userDefinedRuntimeAttributes>
                                    <userDefinedRuntimeAttribute type="number" keyPath="cornerRadius">
                                        <real key="value" value="8"/>
                                    </userDefinedRuntimeAttribute>
                                </userDefinedRuntimeAttributes>
                                <connections>
                                    <action selector="animate" destination="vXZ-lx-hvc" eventType="touchUpInside" id="9Kj-ef-mWu"/>
                                </connections>
                            </button>
                        </subviews>
                        <color key="backgroundColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
                        <constraints>
                            <constraint firstItem="4zt-0R-iYI" firstAttribute="leading" relation="greaterThanOrEqual" secondItem="hW6-Of-57y" secondAttribute="trailing" constant="100" id="2v9-S8-lCq"/>
                            <constraint firstItem="62B-9S-MCt" firstAttribute="top" secondItem="qoX-Tp-oK7" secondAttribute="bottom" constant="15" id="2za-2H-90u"/>
                            <constraint firstItem="qoX-Tp-oK7" firstAttribute="leading" secondItem="hW6-Of-57y" secondAttribute="leading" id="Cas-HV-sWw"/>
                            <constraint firstItem="dvM-fY-6Tr" firstAttribute="trailing" secondItem="62B-9S-MCt" secondAttribute="trailing" id="D6z-4g-Xnd"/>
                            <constraint firstItem="hW6-Of-57y" firstAttribute="top" secondItem="jyV-Pf-zRb" secondAttribute="bottom" constant="26" id="EQo-Ri-rK9"/>
                            <constraint firstAttribute="trailing" relation="greaterThanOrEqual" secondItem="hW6-Of-57y" secondAttribute="trailing" constant="20" symbolic="YES" id="HtZ-Ie-t6o"/>
                            <constraint firstItem="YIm-4U-abp" firstAttribute="leading" secondItem="qoX-Tp-oK7" secondAttribute="leading" id="Hzy-bV-1J0"/>
                            <constraint firstItem="YIm-4U-abp" firstAttribute="top" secondItem="62B-9S-MCt" secondAttribute="bottom" constant="15" id="Ibp-cp-rRJ"/>
                            <constraint firstAttribute="trailing" relation="greaterThanOrEqual" secondItem="qoX-Tp-oK7" secondAttribute="trailing" constant="20" symbolic="YES" id="Ipn-VV-yvl"/>
                            <constraint firstItem="dvM-fY-6Tr" firstAttribute="leading" secondItem="62B-9S-MCt" secondAttribute="leading" id="PFL-bz-yFn"/>
                            <constraint firstItem="qoX-Tp-oK7" firstAttribute="top" secondItem="hW6-Of-57y" secondAttribute="bottom" id="QS3-H8-RrC"/>
                            <constraint firstItem="dvM-fY-6Tr" firstAttribute="top" secondItem="YIm-4U-abp" secondAttribute="bottom" constant="15" id="Ykw-XQ-KXI"/>
                            <constraint firstAttribute="trailing" secondItem="62B-9S-MCt" secondAttribute="trailing" id="YlK-IJ-GeW"/>
                            <constraint firstAttribute="trailing" relation="greaterThanOrEqual" secondItem="YIm-4U-abp" secondAttribute="trailing" constant="20" symbolic="YES" id="dtX-Jy-ED8"/>
                            <constraint firstItem="2fi-mo-0CV" firstAttribute="top" secondItem="dvM-fY-6Tr" secondAttribute="bottom" id="le0-YU-IKA"/>
                            <constraint firstItem="62B-9S-MCt" firstAttribute="leading" secondItem="kh9-bI-dsS" secondAttribute="leading" id="or1-h0-zUw"/>
                            <constraint firstAttribute="trailing" secondItem="4zt-0R-iYI" secondAttribute="trailing" constant="16" id="sr4-Yx-J36"/>
                            <constraint firstItem="4zt-0R-iYI" firstAttribute="centerY" secondItem="hW6-Of-57y" secondAttribute="centerY" id="tXx-to-3Ep"/>
                            <constraint firstItem="hW6-Of-57y" firstAttribute="leading" secondItem="kh9-bI-dsS" secondAttribute="leading" constant="14" id="y66-Op-r1o"/>
                        </constraints>
                    </view>
                    <tabBarItem key="tabBarItem" title="Full View" id="ZcQ-1e-LsA"/>
                    <navigationItem key="navigationItem" id="sgB-eb-vFc"/>
                    <connections>
                        <outlet property="collectionView" destination="62B-9S-MCt" id="QeH-N5-j4O"/>
                        <outlet property="tableView" destination="dvM-fY-6Tr" id="ttI-JA-eet"/>
                    </connections>
                </viewController>
                <placeholder placeholderIdentifier="IBFirstResponder" id="x5A-6p-PRh" sceneMemberID="firstResponder"/>
            </objects>
            <point key="canvasLocation" x="-1110" y="1046"/>
        </scene>
        <!--TableView-->
        <scene sceneID="Y3y-J1-p5S">
            <objects>
                <tableViewController id="9nI-WI-49a" customClass="TableViewController" customModule="ViewAnimator_Example" customModuleProvider="target" sceneMemberID="viewController">
                    <tableView key="view" clipsSubviews="YES" contentMode="scaleToFill" alwaysBounceVertical="YES" showsHorizontalScrollIndicator="NO" dataMode="prototypes" style="plain" separatorStyle="default" rowHeight="-1" estimatedRowHeight="-1" sectionHeaderHeight="28" sectionFooterHeight="28" id="6RT-2l-ZD4">
                        <rect key="frame" x="0.0" y="0.0" width="375" height="812"/>
                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
                        <color key="backgroundColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
                        <view key="tableFooterView" contentMode="scaleToFill" id="1sR-dN-F8r">
                            <rect key="frame" x="0.0" y="99.666667938232422" width="375" height="44"/>
                            <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
                            <color key="backgroundColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
                        </view>
                        <prototypes>
                            <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" preservesSuperviewLayoutMargins="YES" selectionStyle="default" indentationWidth="10" reuseIdentifier="defaultCell" id="nAu-sW-RHj">
                                <rect key="frame" x="0.0" y="28" width="375" height="43.666667938232422"/>
                                <autoresizingMask key="autoresizingMask"/>
                                <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" preservesSuperviewLayoutMargins="YES" insetsLayoutMarginsFromSafeArea="NO" tableViewCell="nAu-sW-RHj" id="2ZG-wa-Xsa">
                                    <rect key="frame" x="0.0" y="0.0" width="375" height="43.666667938232422"/>
                                    <autoresizingMask key="autoresizingMask"/>
                                </tableViewCellContentView>
                            </tableViewCell>
                        </prototypes>
                        <connections>
                            <outlet property="dataSource" destination="9nI-WI-49a" id="XxK-Bj-y18"/>
                            <outlet property="delegate" destination="9nI-WI-49a" id="tM2-X3-jej"/>
                        </connections>
                    </tableView>
                    <navigationItem key="navigationItem" title="TableView" id="2LI-Cw-BWg">
                        <rightBarButtonItems>
                            <barButtonItem title="Reset" id="g0O-5I-B00">
                                <connections>
                                    <action selector="resetTapped:" destination="9nI-WI-49a" id="9G8-TB-1MU"/>
                                </connections>
                            </barButtonItem>
                            <barButtonItem title="Animate" id="VwE-Ky-wxY">
                                <connections>
                                    <action selector="animateTapped:" destination="9nI-WI-49a" id="XMJ-sY-rda"/>
                                </connections>
                            </barButtonItem>
                        </rightBarButtonItems>
                    </navigationItem>
                </tableViewController>
                <placeholder placeholderIdentifier="IBFirstResponder" id="C6k-fB-RW8" userLabel="First Responder" sceneMemberID="firstResponder"/>
            </objects>
            <point key="canvasLocation" x="-394" y="2080"/>
        </scene>
        <!--CollectionView-->
        <scene sceneID="IWO-55-e04">
            <objects>
                <viewController storyboardIdentifier="CollectionViewController" id="r2d-tc-8fj" customClass="CollectionViewController" customModule="ViewAnimator_Example" customModuleProvider="target" sceneMemberID="viewController">
                    <layoutGuides>
                        <viewControllerLayoutGuide type="top" id="Jm5-65-rMu"/>
                        <viewControllerLayoutGuide type="bottom" id="DDr-wK-DCH"/>
                    </layoutGuides>
                    <view key="view" contentMode="scaleToFill" id="fmr-pm-yEy">
                        <rect key="frame" x="0.0" y="0.0" width="375" height="812"/>
                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
                        <subviews>
                            <collectionView clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="scaleToFill" dataMode="prototypes" translatesAutoresizingMaskIntoConstraints="NO" id="hSy-5M-nOm">
                                <rect key="frame" x="0.0" y="88" width="375" height="592"/>
                                <color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="genericGamma22GrayColorSpace"/>
                                <collectionViewFlowLayout key="collectionViewLayout" minimumLineSpacing="10" minimumInteritemSpacing="10" id="NAm-dQ-LV0">
                                    <size key="itemSize" width="105" height="150"/>
                                    <size key="headerReferenceSize" width="0.0" height="0.0"/>
                                    <size key="footerReferenceSize" width="0.0" height="0.0"/>
                                    <inset key="sectionInset" minX="10" minY="10" maxX="10" maxY="10"/>
                                </collectionViewFlowLayout>
                                <cells>
                                    <collectionViewCell opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" reuseIdentifier="cell" id="Mz3-rw-Hfm">
                                        <rect key="frame" x="10" y="10" width="105" height="150"/>
                                        <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
                                        <view key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" insetsLayoutMarginsFromSafeArea="NO">
                                            <rect key="frame" x="0.0" y="0.0" width="105" height="150"/>
                                            <autoresizingMask key="autoresizingMask"/>
                                        </view>
                                    </collectionViewCell>
                                </cells>
                            </collectionView>
                            <activityIndicatorView opaque="NO" contentMode="scaleToFill" horizontalHuggingPriority="750" verticalHuggingPriority="750" hidesWhenStopped="YES" animating="YES" style="gray" translatesAutoresizingMaskIntoConstraints="NO" id="tnU-O2-2YK">
                                <rect key="frame" x="177.66666666666666" y="396" width="20" height="20"/>
                            </activityIndicatorView>
                        </subviews>
                        <color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="genericGamma22GrayColorSpace"/>
                        <constraints>
                            <constraint firstItem="tnU-O2-2YK" firstAttribute="centerX" secondItem="fmr-pm-yEy" secondAttribute="centerX" id="4FA-9X-Ojd"/>
                            <constraint firstItem="tnU-O2-2YK" firstAttribute="centerY" secondItem="fmr-pm-yEy" secondAttribute="centerY" id="Qc8-c2-5cW"/>
                            <constraint firstItem="hSy-5M-nOm" firstAttribute="leading" secondItem="fmr-pm-yEy" secondAttribute="leading" id="TLh-9e-7yT"/>
                            <constraint firstAttribute="trailing" secondItem="hSy-5M-nOm" secondAttribute="trailing" id="Xfz-OH-aNl"/>
                            <constraint firstItem="DDr-wK-DCH" firstAttribute="top" secondItem="hSy-5M-nOm" secondAttribute="bottom" id="fzy-O1-Vb2"/>
                            <constraint firstItem="hSy-5M-nOm" firstAttribute="top" secondItem="Jm5-65-rMu" secondAttribute="bottom" id="mlM-OQ-J0S"/>
                        </constraints>
                    </view>
                    <toolbarItems/>
                    <navigationItem key="navigationItem" title="CollectionView" id="IQe-c4-g6Z">
                        <rightBarButtonItems>
                            <barButtonItem title="Reset" id="c10-I5-VZI">
                                <connections>
                                    <action selector="resetTapped:" destination="r2d-tc-8fj" id="Xej-Tf-kfr"/>
                                </connections>
                            </barButtonItem>
                            <barButtonItem title="Animate" id="OW1-9v-33r">
                                <connections>
                                    <action selector="animateTapped:" destination="r2d-tc-8fj" id="fU0-W5-P3h"/>
                                </connections>
                            </barButtonItem>
                        </rightBarButtonItems>
                    </navigationItem>
                    <simulatedToolbarMetrics key="simulatedBottomBarMetrics"/>
                    <connections>
                        <outlet property="activityIndicator" destination="tnU-O2-2YK" id="V47-q5-4qN"/>
                        <outlet property="collectionView" destination="hSy-5M-nOm" id="wcZ-kZ-iwo"/>
                    </connections>
                </viewController>
                <placeholder placeholderIdentifier="IBFirstResponder" id="vuC-4N-sDe" userLabel="First Responder" sceneMemberID="firstResponder"/>
            </objects>
            <point key="canvasLocation" x="463" y="2080"/>
        </scene>
        <!--TableView-->
        <scene sceneID="cV2-LB-XaS">
            <objects>
                <navigationController automaticallyAdjustsScrollViewInsets="NO" id="y9f-iQ-3Do" sceneMemberID="viewController">
                    <tabBarItem key="tabBarItem" title="TableView" id="rT5-9R-QMO"/>
                    <toolbarItems/>
                    <navigationBar key="navigationBar" contentMode="scaleToFill" insetsLayoutMarginsFromSafeArea="NO" largeTitles="YES" id="H6s-Lx-MHE">
                        <rect key="frame" x="0.0" y="44" width="375" height="96"/>
                        <autoresizingMask key="autoresizingMask"/>
                    </navigationBar>
                    <nil name="viewControllers"/>
                    <connections>
                        <segue destination="9nI-WI-49a" kind="relationship" relationship="rootViewController" id="VnR-xX-Tzp"/>
                    </connections>
                </navigationController>
                <placeholder placeholderIdentifier="IBFirstResponder" id="ieI-lO-VGE" userLabel="First Responder" sceneMemberID="firstResponder"/>
            </objects>
            <point key="canvasLocation" x="-394" y="1046"/>
        </scene>
        <!--CollectionView-->
        <scene sceneID="oUW-63-zxC">
            <objects>
                <navigationController automaticallyAdjustsScrollViewInsets="NO" id="d6M-ta-yMh" sceneMemberID="viewController">
                    <tabBarItem key="tabBarItem" title="CollectionView" id="lgO-xL-d8H"/>
                    <toolbarItems/>
                    <navigationBar key="navigationBar" contentMode="scaleToFill" insetsLayoutMarginsFromSafeArea="NO" largeTitles="YES" id="HRN-Xq-Z6D">
                        <rect key="frame" x="0.0" y="44" width="375" height="96"/>
                        <autoresizingMask key="autoresizingMask"/>
                    </navigationBar>
                    <nil name="viewControllers"/>
                    <connections>
                        <segue destination="r2d-tc-8fj" kind="relationship" relationship="rootViewController" id="jY9-1o-SUw"/>
                    </connections>
                </navigationController>
                <placeholder placeholderIdentifier="IBFirstResponder" id="bxO-Cw-Hx3" userLabel="First Responder" sceneMemberID="firstResponder"/>
            </objects>
            <point key="canvasLocation" x="463" y="1046"/>
        </scene>
    </scenes>
</document>


================================================
FILE: Example/iOS/Info.plist
================================================
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
	<key>CFBundleDevelopmentRegion</key>
	<string>$(DEVELOPMENT_LANGUAGE)</string>
	<key>CFBundleExecutable</key>
	<string>$(EXECUTABLE_NAME)</string>
	<key>CFBundleIdentifier</key>
	<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
	<key>CFBundleInfoDictionaryVersion</key>
	<string>6.0</string>
	<key>CFBundleName</key>
	<string>$(PRODUCT_NAME)</string>
	<key>CFBundlePackageType</key>
	<string>APPL</string>
	<key>CFBundleShortVersionString</key>
	<string>1.0</string>
	<key>CFBundleVersion</key>
	<string>1</string>
	<key>LSRequiresIPhoneOS</key>
	<true/>
	<key>UILaunchStoryboardName</key>
	<string>LaunchScreen</string>
	<key>UIMainStoryboardFile</key>
	<string>Main</string>
	<key>UIRequiredDeviceCapabilities</key>
	<array>
		<string>armv7</string>
	</array>
	<key>UISupportedInterfaceOrientations</key>
	<array>
		<string>UIInterfaceOrientationPortrait</string>
		<string>UIInterfaceOrientationLandscapeLeft</string>
		<string>UIInterfaceOrientationLandscapeRight</string>
	</array>
	<key>UISupportedInterfaceOrientations~ipad</key>
	<array>
		<string>UIInterfaceOrientationPortrait</string>
		<string>UIInterfaceOrientationPortraitUpsideDown</string>
		<string>UIInterfaceOrientationLandscapeLeft</string>
		<string>UIInterfaceOrientationLandscapeRight</string>
	</array>
</dict>
</plist>


================================================
FILE: Example/iOS/ViewControllers/CollectionViewController.swift
================================================
//
//  CollectionViewController.swift
//  ViewAnimator_Example
//
//  Created by Marcos Griselli on 04/02/2018.
//  Copyright © 2018 CocoaPods. All rights reserved.
//

import UIKit
import ViewAnimator

private let reuseIdentifier = "Cell"

class CollectionViewController: UIViewController {
    
    var initiallyAnimates = false
    private var items = [Any?]()
    @IBOutlet weak var collectionView: UICollectionView!
    @IBOutlet weak var activityIndicator: UIActivityIndicatorView!
    private let animations = [AnimationType.vector((CGVector(dx: 0, dy: 30)))]
    
    override func viewDidLoad() {
        super.viewDidLoad()
        collectionView.dataSource = self
        collectionView.delegate = self
        collectionView.register(UICollectionViewCell.self, forCellWithReuseIdentifier: reuseIdentifier)
        
        if initiallyAnimates {
            activityIndicator.stopAnimating()
            DispatchQueue.main.asyncAfter(deadline: .now() + 0.33) {
                self.items = Array(repeating: nil, count: 5)
                self.collectionView?.reloadData()
                self.collectionView?.performBatchUpdates({
                    UIView.animate(views: self.collectionView!.orderedVisibleCells,
                                   animations: self.animations, completion: {
                        
                        })
                }, completion: nil)
            }
        }
    }
    
    @IBAction func animateTapped(_ sender: UIBarButtonItem) {
        sender.isEnabled = false
        activityIndicator.stopAnimating()
        items = Array(repeating: nil, count: 5)
        collectionView?.reloadData()
        collectionView?.performBatchUpdates({
            UIView.animate(views: self.collectionView!.orderedVisibleCells,
                animations: animations, options: [.curveEaseInOut], completion: {
                sender.isEnabled = true
                })
        }, completion: nil)
    }
    
    @IBAction func resetTapped(_ sender: UIBarButtonItem) {
        items.removeAll()
        UIView.animate(views: collectionView!.orderedVisibleCells,
                       animations: animations, reversed: true,
                       initialAlpha: 1.0,
                       finalAlpha: 0.0,
                       options: [.curveEaseIn],
                       completion: {
                        self.collectionView?.reloadData()
                        self.activityIndicator.startAnimating()
        })
    }
}

// MARK: UICollectionViewDataSource
extension CollectionViewController: UICollectionViewDataSource {
    
    func numberOfSections(in collectionView: UICollectionView) -> Int {
        return 2
    }
    
    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        return items.count
    }
    
    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: reuseIdentifier, for: indexPath)
        let color: UIColor = indexPath.section % 2 == 0 ? .red : .blue
        cell.contentView.backgroundColor = color
        return cell
    }
}

extension CollectionViewController: UICollectionViewDelegate {
    func collectionView(_ collectionView: UICollectionView, didSelectItemAt indexPath: IndexPath) {
        guard let viewController = storyboard?.instantiateViewController(withIdentifier: "CollectionViewController") as? CollectionViewController else {
            return
        }
        viewController.initiallyAnimates = true
        navigationController?.show(viewController, sender: nil)
    }
}


================================================
FILE: Example/iOS/ViewControllers/TableViewController.swift
================================================
//
//  TableViewController.swift
//  ViewAnimator_Example
//
//  Created by Marcos Griselli on 1/14/18.
//  Copyright © 2018 CocoaPods. All rights reserved.
//

import UIKit
import ViewAnimator

class TableViewController: UITableViewController {

    private var items = [Any?]()
    private let activityIndicator = UIActivityIndicatorView(style: .gray)
    private let animations = [AnimationType.vector(CGVector(dx: 0, dy: 30))]

    override func viewDidLoad() {
        super.viewDidLoad()
        setupActivityIndicator()
    }

    private func setupActivityIndicator() {
        activityIndicator.center = CGPoint(x: view.center.x, y: 100.0)
        activityIndicator.hidesWhenStopped = true
        view.addSubview(activityIndicator)
        activityIndicator.startAnimating()
    }

    // MARK: - Table view data source

    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return items.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "defaultCell", for: indexPath)
        cell.textLabel?.text = "Cell: \(indexPath.row + 1)"
        return cell
    }

    @IBAction func animateTapped(_ sender: UIBarButtonItem) {
        sender.isEnabled = false
        activityIndicator.stopAnimating()
        items = Array(repeating: nil, count: 20)
        tableView.reloadData()
        UIView.animate(views: tableView.visibleCells, animations: animations, completion: {
            sender.isEnabled = true
        })
    }

    @IBAction func resetTapped(_ sender: UIBarButtonItem) {
        items.removeAll()
        UIView.animate(views: tableView.visibleCells, animations: animations, reversed: true,
                       initialAlpha: 1.0, finalAlpha: 0.0, completion: {
            self.tableView.reloadData()
            self.activityIndicator.startAnimating()
        })
    }
}


================================================
FILE: Example/iOS/ViewControllers/ViewController.swift
================================================
//
//  ViewController.swift
//  ViewAnimator
//
//  Created by marcosgriselli@gmail.com on 10/05/2017.
//  Copyright (c) 2017 marcosgriselli@gmail.com. All rights reserved.
//

import UIKit
import ViewAnimator

class ViewController: UIViewController {
    
    @IBOutlet weak var collectionView: UICollectionView!
    @IBOutlet weak var tableView: UITableView!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        collectionView.register(CollectionViewCell.self, forCellWithReuseIdentifier: "cell")
        collectionView.dataSource = self
        
        tableView.tableFooterView = UIView()
        tableView.dataSource = self
    }

    @IBAction func animate() {
        // Combined animations example
        let fromAnimation = AnimationType.vector(CGVector(dx: 30, dy: 0))
        let zoomAnimation = AnimationType.zoom(scale: 0.2)
        let rotateAnimation = AnimationType.rotate(angle: CGFloat.pi/6)
        UIView.animate(views: collectionView.visibleCells,
                       animations: [zoomAnimation, rotateAnimation],
                       duration: 0.5)
        
        UIView.animate(views: tableView.visibleCells,
                       animations: [fromAnimation, zoomAnimation], delay: 0.5)
    }
}

extension ViewController: UITableViewDataSource {
    func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }
    
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 5
    }
    
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "tableCell", for: indexPath) as! TableViewCell
        cell.userImageView.image = UIImage(named: "\(indexPath.row)")
        return cell
    }
}

extension ViewController: UICollectionViewDataSource {
    func numberOfSections(in collectionView: UICollectionView) -> Int {
        return 1
    }
    
    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        return 5
    }
    
    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell", for: indexPath) as! CollectionViewCell
        cell.backgroundColor = UIColor.red
        cell.layer.cornerRadius = 5.0
        cell.imageView.image = UIImage(named: "\(indexPath.item)")
        return cell
    }
}


================================================
FILE: Example/iOS/Views/Cells/CollectionViewCell.swift
================================================
//
//  CollectionViewCell.swift
//  ViewAnimator_Example
//
//  Created by Marcos Griselli on 10/9/17.
//  Copyright © 2017 CocoaPods. All rights reserved.
//

import UIKit

class CollectionViewCell: UICollectionViewCell {

    lazy var imageView: UIImageView = {
       let imageView = UIImageView()
        imageView.clipsToBounds = true
        return imageView
    }()
    
    override func layoutSubviews() {
        super.layoutSubviews()
        if imageView.superview == nil {
            imageView.frame = bounds
            imageView.layer.cornerRadius = layer.cornerRadius
            addSubview(imageView)
        }
    }
}


================================================
FILE: Example/iOS/Views/Cells/TableViewCell.swift
================================================
//
//  TableViewCell.swift
//  ViewAnimator_Example
//
//  Created by Marcos Griselli on 10/9/17.
//  Copyright © 2017 CocoaPods. All rights reserved.
//

import UIKit

class TableViewCell: UITableViewCell {
    
    @IBOutlet var userImageView: UIImageView!
    @IBOutlet var label: UILabel!
}


================================================
FILE: Example/iOS/Views/Designable.swift
================================================
//
//  Designable.swift
//  ViewAnimator_Example
//
//  Created by Marcos Griselli on 10/9/17.
//  Copyright © 2017 CocoaPods. All rights reserved.
//

import UIKit

@IBDesignable
class DesignableView: UIView {
}

@IBDesignable
class DesignableButton: UIButton {
}

@IBDesignable
class DesignableLabel: UILabel {
}

extension UIView {
    
    @IBInspectable
    var cornerRadius: CGFloat {
        get {
            return layer.cornerRadius
        }
        set {
            layer.cornerRadius = newValue
        }
    }
    
    @IBInspectable
    var borderWidth: CGFloat {
        get {
            return layer.borderWidth
        }
        set {
            layer.borderWidth = newValue
        }
    }
    
    @IBInspectable
    var borderColor: UIColor? {
        get {
            if let color = layer.borderColor {
                return UIColor(cgColor: color)
            }
            return nil
        }
        set {
            if let color = newValue {
                layer.borderColor = color.cgColor
            } else {
                layer.borderColor = nil
            }
        }
    }
    
    @IBInspectable
    var shadowRadius: CGFloat {
        get {
            return layer.shadowRadius
        }
        set {
            layer.shadowRadius = newValue
        }
    }
    
    @IBInspectable
    var shadowOpacity: Float {
        get {
            return layer.shadowOpacity
        }
        set {
            layer.shadowOpacity = newValue
        }
    }
    
    @IBInspectable
    var shadowOffset: CGSize {
        get {
            return layer.shadowOffset
        }
        set {
            layer.shadowOffset = newValue
        }
    }
    
    @IBInspectable
    var shadowColor: UIColor? {
        get {
            if let color = layer.shadowColor {
                return UIColor(cgColor: color)
            }
            return nil
        }
        set {
            if let color = newValue {
                layer.shadowColor = color.cgColor
            } else {
                layer.shadowColor = nil
            }
        }
    }
}



================================================
FILE: Example/tvOS/AppDelegate.swift
================================================
//
//  AppDelegate.swift
//  ViewAnimatorTVOS
//
//  Created by Marcos Griselli on 28/04/2018.
//  Copyright © 2018 CocoaPods. All rights reserved.
//

import UIKit

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?


    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        // Override point for customization after application launch.
        return true
    }

    func applicationWillResignActive(_ application: UIApplication) {
        // Sent when the application is about to move from active to inactive state. This can occur for certain types of temporary interruptions (such as an incoming phone call or SMS message) or when the user quits the application and it begins the transition to the background state.
        // Use this method to pause ongoing tasks, disable timers, and throttle down OpenGL ES frame rates. Games should use this method to pause the game.
    }

    func applicationDidEnterBackground(_ application: UIApplication) {
        // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
        // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
    }

    func applicationWillEnterForeground(_ application: UIApplication) {
        // Called as part of the transition from the background to the active state; here you can undo many of the changes made on entering the background.
    }

    func applicationDidBecomeActive(_ application: UIApplication) {
        // Restart any tasks that were paused (or not yet started) while the application was inactive. If the application was previously in the background, optionally refresh the user interface.
    }

    func applicationWillTerminate(_ application: UIApplication) {
        // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
    }


}



================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "layers" : [
    {
      "filename" : "tv-icon-front.imagestacklayer"
    },
    {
      "filename" : "tv-icon-back.imagestacklayer"
    }
  ],
  "properties" : {
    "canvasSize" : {
      "height" : 768,
      "width" : 1280
    }
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/tv-icon-back.imagestacklayer/Content.imageset/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "images" : [
    {
      "idiom" : "tv",
      "filename" : "tv-icon-back.png",
      "scale" : "1x"
    },
    {
      "idiom" : "tv",
      "scale" : "2x"
    }
  ]
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/tv-icon-back.imagestacklayer/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "properties" : {
    "frame-size" : {
      "height" : 768,
      "width" : 1280
    },
    "frame-center" : {
      "y" : 384,
      "x" : 640
    }
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/tv-icon-front.imagestacklayer/Content.imageset/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "images" : [
    {
      "idiom" : "tv",
      "filename" : "tv-icon-front.png",
      "scale" : "1x"
    },
    {
      "idiom" : "tv",
      "scale" : "2x"
    }
  ]
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/tv-icon-front.imagestacklayer/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "properties" : {
    "frame-size" : {
      "height" : 768,
      "width" : 1280
    },
    "frame-center" : {
      "y" : 384,
      "x" : 640
    }
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "layers" : [
    {
      "filename" : "tv-icon-front.imagestacklayer"
    },
    {
      "filename" : "tv-icon-back.imagestacklayer"
    }
  ],
  "properties" : {
    "canvasSize" : {
      "height" : 240,
      "width" : 400
    }
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/tv-icon-back.imagestacklayer/Content.imageset/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "images" : [
    {
      "idiom" : "tv",
      "filename" : "tv-icon-back.png",
      "scale" : "1x"
    },
    {
      "idiom" : "tv",
      "filename" : "tv-icon-back@2x.png",
      "scale" : "2x"
    }
  ]
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/tv-icon-back.imagestacklayer/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "properties" : {
    "frame-size" : {
      "height" : 240,
      "width" : 400
    },
    "frame-center" : {
      "y" : 120,
      "x" : 200
    }
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/tv-icon-front.imagestacklayer/Content.imageset/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "images" : [
    {
      "idiom" : "tv",
      "filename" : "tv-icon-front.png",
      "scale" : "1x"
    },
    {
      "idiom" : "tv",
      "filename" : "tv-icon-front@2x.png",
      "scale" : "2x"
    }
  ]
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/tv-icon-front.imagestacklayer/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "properties" : {
    "frame-size" : {
      "height" : 240,
      "width" : 400
    },
    "frame-center" : {
      "y" : 120,
      "x" : 200
    }
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "assets" : [
    {
      "filename" : "App Icon - App Store.imagestack",
      "size" : "1280x768",
      "idiom" : "tv",
      "role" : "primary-app-icon"
    },
    {
      "filename" : "App Icon.imagestack",
      "size" : "400x240",
      "idiom" : "tv",
      "role" : "primary-app-icon"
    },
    {
      "filename" : "Top Shelf Image.imageset",
      "size" : "1920x720",
      "idiom" : "tv",
      "role" : "top-shelf-image"
    },
    {
      "filename" : "Top Shelf Image Wide.imageset",
      "size" : "2320x720",
      "idiom" : "tv",
      "role" : "top-shelf-image-wide"
    }
  ]
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/Top Shelf Image Wide.imageset/Contents.json
================================================
{
  "info" : {
    "version" : 1,
    "author" : "xcode"
  },
  "images" : [
    {
      "idiom" : "tv",
      "scale" : "1x"
    },
    {
      "idiom" : "tv",
      "scale" : "2x"
    }
  ]
}

================================================
FILE: Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/Top Shelf Image.imageset/Contents.json
================================================
{
  "info" : {
    "version" : 1,
    "author" : "xcode"
  },
  "images" : [
    {
      "idiom" : "tv",
      "scale" : "1x"
    },
    {
      "idiom" : "tv",
      "scale" : "2x"
    }
  ]
}

================================================
FILE: Example/tvOS/Assets.xcassets/Contents.json
================================================
{
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/Launch Image.launchimage/Contents.json
================================================
{
  "info" : {
    "author" : "xcode",
    "version" : 1
  },
  "images" : [
    {
      "extent" : "full-screen",
      "filename" : "tvOSLaunchImage.png",
      "minimum-system-version" : "9.0",
      "idiom" : "tv",
      "scale" : "1x",
      "orientation" : "landscape"
    },
    {
      "extent" : "full-screen",
      "filename" : "tvOSLaunchImage@2x.png",
      "minimum-system-version" : "11.0",
      "idiom" : "tv",
      "scale" : "2x",
      "orientation" : "landscape"
    }
  ]
}

================================================
FILE: Example/tvOS/Assets.xcassets/detail_1.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "detail_1@2x.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "detail_1@3x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/detail_2.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "detail_2@2x.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "detail_2@3x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/detail_3.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "detail_3@2x.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "detail_3@3x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/detail_4.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "detail_4@2x.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "detail_4@3x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/detail_5.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "detail_5@2x.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "detail_5@3x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/tvOS/Assets.xcassets/detail_6.imageset/Contents.json
================================================
{
  "images" : [
    {
      "idiom" : "universal",
      "filename" : "detail_6@2x.png",
      "scale" : "1x"
    },
    {
      "idiom" : "universal",
      "filename" : "detail_6@3x.png",
      "scale" : "2x"
    },
    {
      "idiom" : "universal",
      "scale" : "3x"
    }
  ],
  "info" : {
    "version" : 1,
    "author" : "xcode"
  }
}

================================================
FILE: Example/tvOS/Base.lproj/Main.storyboard
================================================
<?xml version="1.0" encoding="UTF-8"?>
<document type="com.apple.InterfaceBuilder.AppleTV.Storyboard" version="3.0" toolsVersion="14109" targetRuntime="AppleTV" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" useSafeAreas="YES" colorMatched="YES" initialViewController="BYZ-38-t0r">
    <device id="appleTV" orientation="landscape">
        <adaptation id="light"/>
    </device>
    <dependencies>
        <deployment identifier="tvOS"/>
        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="14088"/>
        <capability name="Constraints to layout margins" minToolsVersion="6.0"/>
        <capability name="Safe area layout guides" minToolsVersion="9.0"/>
        <capability name="documents saved in the Xcode 8 format" minToolsVersion="8.0"/>
    </dependencies>
    <scenes>
        <!--View Controller-->
        <scene sceneID="tne-QT-ifu">
            <objects>
                <viewController id="BYZ-38-t0r" customClass="ViewController" customModule="ViewAnimatorTVOS" customModuleProvider="target" sceneMemberID="viewController">
                    <layoutGuides>
                        <viewControllerLayoutGuide type="top" id="y3c-jy-aDJ"/>
                        <viewControllerLayoutGuide type="bottom" id="wfy-db-euE"/>
                    </layoutGuides>
                    <view key="view" contentMode="scaleToFill" id="8bC-Xf-vdC">
                        <rect key="frame" x="0.0" y="0.0" width="1920" height="1080"/>
                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
                        <subviews>
                            <activityIndicatorView opaque="NO" contentMode="scaleToFill" horizontalHuggingPriority="750" verticalHuggingPriority="750" hidesWhenStopped="YES" animating="YES" style="whiteLarge" translatesAutoresizingMaskIntoConstraints="NO" id="w3O-QV-i5a">
                                <rect key="frame" x="928" y="508" width="64" height="64"/>
                            </activityIndicatorView>
                            <collectionView clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="scaleToFill" dataMode="prototypes" translatesAutoresizingMaskIntoConstraints="NO" id="A8I-2m-uwu">
                                <rect key="frame" x="90" y="140" width="1740" height="880"/>
                                <collectionViewFlowLayout key="collectionViewLayout" minimumLineSpacing="35" minimumInteritemSpacing="20" id="DqQ-mU-qpl">
                                    <size key="itemSize" width="317" height="469"/>
                                    <size key="headerReferenceSize" width="0.0" height="0.0"/>
                                    <size key="footerReferenceSize" width="0.0" height="0.0"/>
                                    <inset key="sectionInset" minX="0.0" minY="0.0" maxX="0.0" maxY="0.0"/>
                                </collectionViewFlowLayout>
                                <cells>
                                    <collectionViewCell opaque="NO" multipleTouchEnabled="YES" contentMode="center" reuseIdentifier="cell" id="rtR-FU-f8w" customClass="CollectionViewCell" customModule="ViewAnimatorTVOS" customModuleProvider="target">
                                        <rect key="frame" x="0.0" y="0.0" width="317" height="469"/>
                                        <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
                                        <view key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" insetsLayoutMarginsFromSafeArea="NO">
                                            <rect key="frame" x="0.0" y="0.0" width="317" height="469"/>
                                            <autoresizingMask key="autoresizingMask"/>
                                            <subviews>
                                                <imageView userInteractionEnabled="NO" contentMode="scaleToFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" translatesAutoresizingMaskIntoConstraints="NO" id="aTv-Ym-PfV">
                                                    <rect key="frame" x="0.0" y="0.0" width="317" height="469"/>
                                                </imageView>
                                            </subviews>
                                        </view>
                                        <constraints>
                                            <constraint firstItem="aTv-Ym-PfV" firstAttribute="leading" secondItem="rtR-FU-f8w" secondAttribute="leading" id="FHc-Nn-o3t"/>
                                            <constraint firstAttribute="trailing" secondItem="aTv-Ym-PfV" secondAttribute="trailing" id="Tpu-pE-uam"/>
                                            <constraint firstAttribute="bottom" secondItem="aTv-Ym-PfV" secondAttribute="bottom" id="lgQ-6y-x1d"/>
                                            <constraint firstItem="aTv-Ym-PfV" firstAttribute="top" secondItem="rtR-FU-f8w" secondAttribute="top" id="sua-EK-fZd"/>
                                        </constraints>
                                        <connections>
                                            <outlet property="imageView" destination="aTv-Ym-PfV" id="7Zg-FW-0Ke"/>
                                        </connections>
                                    </collectionViewCell>
                                </cells>
                            </collectionView>
                            <stackView opaque="NO" contentMode="scaleToFill" distribution="fillEqually" spacing="30" translatesAutoresizingMaskIntoConstraints="NO" id="FAG-Z7-0DC">
                                <rect key="frame" x="1356" y="20" width="474" height="86"/>
                                <subviews>
                                    <button opaque="NO" contentMode="scaleToFill" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="Rao-BY-zni">
                                        <rect key="frame" x="0.0" y="0.0" width="222" height="86"/>
                                        <inset key="contentEdgeInsets" minX="40" minY="20" maxX="40" maxY="20"/>
                                        <state key="normal" title="Animate"/>
                                        <connections>
                                            <action selector="animateTapped:" destination="BYZ-38-t0r" eventType="primaryActionTriggered" id="7ve-hy-QyX"/>
                                            <action selector="animateTapped:" destination="j2R-Dg-AjY" eventType="primaryActionTriggered" id="Mab-RH-eJp"/>
                                        </connections>
                                    </button>
                                    <button opaque="NO" contentMode="scaleToFill" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="POQ-8y-bL6">
                                        <rect key="frame" x="252" y="0.0" width="222" height="86"/>
                                        <inset key="contentEdgeInsets" minX="40" minY="20" maxX="40" maxY="20"/>
                                        <state key="normal" title="Reset"/>
                                        <connections>
                                            <action selector="resetTapped:" destination="j2R-Dg-AjY" eventType="primaryActionTriggered" id="AZ3-UW-Whf"/>
                                            <action selector="resetTapped:" destination="BYZ-38-t0r" eventType="primaryActionTriggered" id="fcC-cd-5Rf"/>
                                        </connections>
                                    </button>
                                </subviews>
                            </stackView>
                        </subviews>
                        <color key="backgroundColor" red="0.0" green="0.0" blue="0.0" alpha="0.0" colorSpace="custom" customColorSpace="sRGB"/>
                        <constraints>
                            <constraint firstItem="A8I-2m-uwu" firstAttribute="top" secondItem="wu6-TO-1qx" secondAttribute="top" constant="80" id="38R-gM-W4O"/>
                            <constraint firstItem="w3O-QV-i5a" firstAttribute="centerY" secondItem="wu6-TO-1qx" secondAttribute="centerY" id="4F1-4y-dpP"/>
                            <constraint firstItem="w3O-QV-i5a" firstAttribute="centerX" secondItem="wu6-TO-1qx" secondAttribute="centerX" id="6za-sj-bgQ"/>
                            <constraint firstItem="FAG-Z7-0DC" firstAttribute="trailing" secondItem="wu6-TO-1qx" secondAttribute="trailing" id="Anj-PG-GmF"/>
                            <constraint firstItem="FAG-Z7-0DC" firstAttribute="top" secondItem="8bC-Xf-vdC" secondAttribute="topMargin" constant="-40" id="Dhi-PR-nxr"/>
                            <constraint firstItem="A8I-2m-uwu" firstAttribute="leading" secondItem="wu6-TO-1qx" secondAttribute="leading" id="PfP-VP-hes"/>
                            <constraint firstItem="wu6-TO-1qx" firstAttribute="bottom" secondItem="A8I-2m-uwu" secondAttribute="bottom" id="lPI-UC-pLa"/>
                            <constraint firstItem="wu6-TO-1qx" firstAttribute="trailing" secondItem="A8I-2m-uwu" secondAttribute="trailing" id="q9R-Mq-hCG"/>
                        </constraints>
                        <viewLayoutGuide key="safeArea" id="wu6-TO-1qx"/>
                    </view>
                    <connections>
                        <outlet property="activityIndicator" destination="w3O-QV-i5a" id="AlH-1e-gQB"/>
                        <outlet property="collectionView" destination="A8I-2m-uwu" id="dHa-nT-MJh"/>
                    </connections>
                </viewController>
                <placeholder placeholderIdentifier="IBFirstResponder" id="dkx-z0-nzr" sceneMemberID="firstResponder"/>
                <exit id="j2R-Dg-AjY" userLabel="Exit" sceneMemberID="exit"/>
            </objects>
        </scene>
    </scenes>
</document>


================================================
FILE: Example/tvOS/Cells/CollectionViewCell.swift
================================================
//
//  CollectionViewCell.swift
//  ViewAnimatorTVOS
//
//  Created by Marcos Griselli on 28/04/2018.
//  Copyright © 2018 CocoaPods. All rights reserved.
//

import UIKit

class CollectionViewCell: UICollectionViewCell {
    @IBOutlet weak var imageView: UIImageView!
}


================================================
FILE: Example/tvOS/CollectionViewController.swift
================================================
//
//  ViewController.swift
//  ViewAnimatorTVOS
//
//  Created by Marcos Griselli on 28/04/2018.
//  Copyright © 2018 CocoaPods. All rights reserved.
//

import UIKit
import ViewAnimator

class ViewController: UIViewController {

    // MARK: - IBOutlets
    @IBOutlet weak var collectionView: UICollectionView!
    @IBOutlet weak var activityIndicator: UIActivityIndicatorView!

    // MARK: - Properties
    private var items = [Any?]()
    private let animations = [AnimationType.from(direction: .bottom, offset: 30.0)]

    // MARK: - View Lifecycle
    override func viewDidLoad() {
        super.viewDidLoad()
        collectionView.dataSource = self
    }
    
    @IBAction func animateTapped(_ sender: UIButton) {
        sender.isEnabled = false
        activityIndicator.stopAnimating()
        items = Array(repeating: nil, count: 20)
        collectionView?.reloadData()
        collectionView?.performBatchUpdates({
            UIView.animate(views: self.collectionView!.orderedVisibleCells,
                           animations: animations, completion: {
                            sender.isEnabled = true
            })
        }, completion: nil)
    }
    
    @IBAction func resetTapped(_ sender: UIButton) {
        items.removeAll()
        UIView.animate(views: collectionView!.orderedVisibleCells,
                       animations: animations, reversed: true,
                       initialAlpha: 1.0,
                       finalAlpha: 0.0,
                       completion: {
                        self.collectionView?.reloadData()
                        self.activityIndicator.startAnimating()
        })
    }
}

// MARK: - UICollectionViewDataSource
extension ViewController: UICollectionViewDataSource {

    func numberOfSections(in collectionView: UICollectionView) -> Int {
        return 1
    }
    
    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        return items.count
    }
    
    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell",
                                                      for: indexPath) as! CollectionViewCell
        let imageIndex = indexPath.item % 6
        cell.imageView.image = UIImage(named: "detail_\(imageIndex + 1)")
        return cell
    }
}


================================================
FILE: Example/tvOS/Info.plist
================================================
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
	<key>CFBundleDevelopmentRegion</key>
	<string>$(DEVELOPMENT_LANGUAGE)</string>
	<key>CFBundleExecutable</key>
	<string>$(EXECUTABLE_NAME)</string>
	<key>CFBundleIdentifier</key>
	<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
	<key>CFBundleInfoDictionaryVersion</key>
	<string>6.0</string>
	<key>CFBundleName</key>
	<string>$(PRODUCT_NAME)</string>
	<key>CFBundlePackageType</key>
	<string>APPL</string>
	<key>CFBundleShortVersionString</key>
	<string>1.0</string>
	<key>CFBundleVersion</key>
	<string>1</string>
	<key>LSRequiresIPhoneOS</key>
	<true/>
	<key>UIMainStoryboardFile</key>
	<string>Main</string>
	<key>UIRequiredDeviceCapabilities</key>
	<array>
		<string>arm64</string>
	</array>
	<key>UIUserInterfaceStyle</key>
	<string>Automatic</string>
</dict>
</plist>


================================================
FILE: Gemfile
================================================
source "https://rubygems.org"

gem 'fastlane'
gem 'cocoapods'


================================================
FILE: LICENSE
================================================
Copyright (c) 2018 marcosgriselli@gmail.com <marcosgriselli@gmail.com>

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.


================================================
FILE: Package.swift
================================================
// swift-tools-version:5.0
import PackageDescription

let package = Package(
    name: "ViewAnimator",
    platforms: [.iOS(.v9), .tvOS(.v9)],
    products: [
        .library(name: "ViewAnimator", targets: ["ViewAnimator"]),
    ],
    targets: [
        .target(
            name: "ViewAnimator",
            dependencies: [],
            path: "Sources"
        ),
        .testTarget(
            name: "ViewAnimatorTests",
            dependencies: ["ViewAnimator"],
            path: "ViewAnimatorTests"),
    ],
    swiftLanguageVersions: [.v5]
)


================================================
FILE: README.md
================================================
<p align="center">
<img src="./Resources/banner_new.svg"/>
</p>

<p align="center">
    <img src="https://img.shields.io/badge/Swift-4.2-orange.svg" />
        <img src="https://img.shields.io/badge/Platforms-iOS%20%7C%20tvOS-blue.svg?style=flat" />
        <img src="https://img.shields.io/cocoapods/dt/ViewAnimator.svg?style=flat"/>
    <a href="https://cocoapods.org/pods/ViewAnimator">
        <img src="https://img.shields.io/cocoapods/v/ViewAnimator.svg" alt="CocoaPods" />
    </a>
    <a href="https://github.com/Carthage/Carthage">
        <img src="https://img.shields.io/badge/carthage-compatible-4BC51D.svg?style=flat" alt="Carthage" />
    </a>
    <a href="https://codebeat.co/projects/github-com-marcosgriselli-viewanimator-master">
      <img src="https://codebeat.co/badges/633fb33d-66b6-4034-93c0-0f52c5d0e15c" alt="Codebeat" />
    </a>
    <a href="https://opensource.org/licenses/MIT">
      <img src="https://img.shields.io/cocoapods/l/ViewAnimator.svg?style=flat" alt="License" />
    </a>
</p>

**ViewAnimator** is a library for building complex iOS UIView animations in an easy way. It provides one line animations for any view included the ones which contain other views like UITableView and UICollectionView with its cells or UIStackView with its arrangedSubviews.

### Entire View&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;UITableView&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;UICollectionView
<img src="https://cdn.jsdelivr.net/gh/marcosgriselli/ViewAnimator@cf065e96ac34c924710dd84c718ecd3be179ae37/Resources/entireView.svg"/>&nbsp;&nbsp;&nbsp;&nbsp;
<img src="https://cdn.jsdelivr.net/gh/marcosgriselli/ViewAnimator@cf065e96ac34c924710dd84c718ecd3be179ae37/Resources/horizontal.svg"/>&nbsp;&nbsp;&nbsp;&nbsp;
<img src="https://cdn.jsdelivr.net/gh/marcosgriselli/ViewAnimator@cf065e96ac34c924710dd84c718ecd3be179ae37/Resources/vertical.svg"/>&nbsp;&nbsp;&nbsp;&nbsp;
<img src="https://cdn.jsdelivr.net/gh/marcosgriselli/ViewAnimator@cf065e96ac34c924710dd84c718ecd3be179ae37/Resources/collection.svg"/>&nbsp;&nbsp;&nbsp;&nbsp;
<img src="https://cdn.jsdelivr.net/gh/marcosgriselli/ViewAnimator@cf065e96ac34c924710dd84c718ecd3be179ae37/Resources/collectionX.svg"/>

SVG animations inspired by [Luke Zhao's](http://lkzhao.com) project [Hero](https://github.com/lkzhao/Hero/blob/master/README.md)

### Complex Layouts
<image src="https://cdn.dribbble.com/users/702789/screenshots/3816087/preview-messaki.gif" width="400"/>

UI created by [Messaki](https://dribbble.com/messaki), make sure to check out his profile.

*Logo and banner created by [@cintia_ve](https://twitter.com/cintia_ve)*

## Installation

### CocoaPods

ViewAnimator is available through [CocoaPods](http://cocoapods.org). To install
it, simply add the following line to your Podfile:

```ruby
pod "ViewAnimator"
```

### Manual

Drop the swift files inside of [ViewAnimator/Classes](https://github.com/marcosgriselli/ViewAnimator/tree/master/ViewAnimator/Classes) into your project.

### Carthage 

```
github "marcosgriselli/ViewAnimator"
```

## Usage

`ViewAnimator` provides a set of `UIView` extensions to easily add custom animations to your views. From version `2.0.0` there are two ways to use this extension. 

### Self animating views

Views can animate theirselves calling `.animate(animations: [Animation])` that's the most basic usage. Here's the full method that contains many default arguments: 

```swift
func animate(animations: [Animation],
             reversed: Bool = false,
             initialAlpha: CGFloat = 0.0,
             finalAlpha: CGFloat = 1.0,
             delay: Double = 0,
             duration: TimeInterval = ViewAnimatorConfig.duration,
             usingSpringWithDamping dampingRatio: CGFloat = ViewAnimatorConfig.springDampingRatio,
             initialSpringVelocity velocity: CGFloat = ViewAnimatorConfig.initialSpringVelocity,
             completion: (() -> Void)? = nil)
``` 

### Animating multiple views 

ViewAnimator follows the UIKit animations API style with a static method  `UIView.animate(views: [UIView], animations: [Animation])`. This makes the library really easy to use and extensible to any kind of view. As the previous example, the method contains a lot of default arguments: 

```swift
static func animate(views: [UIView],
                    animations: [Animation],
                    reversed: Bool = false,
                    initialAlpha: CGFloat = 0.0,
                    finalAlpha: CGFloat = 1.0,
                    delay: Double = 0,
                    animationInterval: TimeInterval = 0.05,
                    duration: TimeInterval = ViewAnimatorConfig.duration,
                    usingSpringWithDamping dampingRatio: CGFloat = ViewAnimatorConfig.springDampingRatio,
                    initialSpringVelocity velocity: CGFloat = ViewAnimatorConfig.initialSpringVelocity,
                    completion: (() -> Void)? = nil)
```

### AnimationType

#### Direction
`Direction` provides the axis where the animation should take place and its movement direction.

```swift
let animation = AnimationType.from(direction: .top, offset: 30.0)
view.animate(animations: [animation])
```

#### Zoom
Zoom in and Zoom out animation support.

```swift
let animation = AnimationType.zoom(scale: 0.5)
view.animate(animations: [animation])
```

### Combined Animations

You can combine conformances of `Animation` to apply multiple transforms on your animation block. 

```swift 
let fromAnimation = AnimationType.from(direction: .right, offset: 30.0)
let zoomAnimation = AnimationType.zoom(scale: 0.2)
let rotateAnimation = AnimationType.rotate(angle: CGFloat.pi/6)
UIView.animate(views: collectionView.visibleCells,
               animations: [zoomAnimation, rotateAnimation],
               duration: 0.5)
UIView.animate(views: tableView.visibleCells,
               animations: [fromAnimation, zoomAnimation], 
               delay: 0.5)

```

## Animation

`Animation` protocol provides you the posibility of expanding the animations supported by `ViewAnimator` with exception of the `animateRandom` function.

```swift 
public protocol Animation {
    var initialTransform: CGAffineTransform { get }
}
```

## UITableView/UICollection extensions

ViewAnimator comes with a set of handy extensions to make your animations in `UITableView` and `UICollectionView` a lot simpler. They both have access to cells in a section to animate easily. 

They both expose a method `visibleCells(in section: Int)` that returns an array of `UITableViewCell` or `UICollectionViewCell`.

```swift
let cells = tableView.visibleCells(in: 1)
UIView.animate(views: cells, animations: [rotateAnimation, fadeAnimation])
``` 

## Mentions

- [iOS Dev Weekly 323](http://iosdevweekly.com/issues/323#start)
- [Natasha The Robot's Newsleter 147](https://swiftnews.curated.co/issues/147#start)
- [Top 10 Swift Articles October](https://medium.mybridge.co/swift-top-10-articles-for-the-past-month-v-oct-2017-4e0f1bd031e8)
- [30 Amazing iOS Swift Libraries (v2018)](https://medium.mybridge.co/30-amazing-ios-swift-libraries-for-the-past-year-v-2018-7cf15027eee9)


## Project Details

### Requirements
* Swift 4.0
* Xcode 7.0+
* iOS 8.0+

### Contributing
Feel free to collaborate with ideas 💭, issues ⁉️ and/or pull requests 🔃.

If you use ViewAnimator in your app I'd love to hear about it and feature your animation here!

### Contributors

[![](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/images/0)](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/links/0)[![](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/images/1)](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/links/1)[![](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/images/2)](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/links/2)[![](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/images/3)](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/links/3)[![](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/images/4)](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/links/4)[![](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/images/5)](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/links/5)[![](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/images/6)](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/links/6)[![](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/images/7)](https://sourcerer.io/fame/marcosgriselli/marcosgriselli/ViewAnimator/links/7)

### Author

Marcos Griselli | <a href="url"><img src="https://cdn.jsdelivr.net/gh/marcosgriselli/ViewAnimator@cf065e96ac34c924710dd84c718ecd3be179ae37/Resources/twitterLogo.svg" height="17"></a> [@marcosgriselli](https://twitter.com/marcosgriselli)


[![Twitter Follow](https://img.shields.io/twitter/follow/marcosgriselli.svg?style=social)](https://twitter.com/marcosgriselli)

[![Twitter Follow](https://img.shields.io/github/followers/marcosgriselli.svg?style=social&label=Follow)](https://github.com/marcosgriselli)

### License

ViewAnimator is available under the MIT license. See the [LICENSE](https://github.com/marcosgriselli/ViewAnimator/blob/master/LICENSE) file for more info.


================================================
FILE: Sources/.gitkeep
================================================


================================================
FILE: Sources/Extensions/UICollectionView + ViewAnimator.swift
================================================
//
//  UICollectionView + ViewAnimator.swift
//  ViewAnimator
//
//  Created by Marcos Griselli on 15/04/2018.
//

import Foundation
import UIKit

public extension UICollectionView {

    /// VisibleCells in the order they are displayed on screen.
    var orderedVisibleCells: [UICollectionViewCell] {
        return indexPathsForVisibleItems.sorted().compactMap { cellForItem(at: $0) }
    }

    /// Gets the currently visibleCells of a section.
    ///
    /// - Parameter section: The section to filter the cells.
    /// - Returns: Array of visible UICollectionViewCells in the argument section.
    func visibleCells(in section: Int) -> [UICollectionViewCell] {
        return visibleCells.filter { indexPath(for: $0)?.section == section }
    }
}


================================================
FILE: Sources/Extensions/UITableView + ViewAnimator.swift
================================================
//
//  UITableView + ViewAnimator.swift
//  ViewAnimator
//
//  Created by Marcos Griselli on 15/04/2018.
//

import Foundation
import UIKit

public extension UITableView {

    /// Gets the currently visibleCells of a section.
    ///
    /// - Parameter section: The section to filter the cells.
    /// - Returns: Array of visible UITableViewCell in the argument section.
    func visibleCells(in section: Int) -> [UITableViewCell] {
        return visibleCells.filter { indexPath(for: $0)?.section == section }
    }
}


================================================
FILE: Sources/Models/AnimationType.swift
================================================
//
//  AnimationType.swift
//  Pods-ViewAnimator_Example
//
//  Created by Marcos Griselli on 10/5/17.
//

import UIKit

/// AnimationType available to perform/
///
/// - vector: Animation from x and y values
/// - zoom: Zoom animation.
/// - rotate: Rotation animation.
public enum AnimationType: Animation {

    case from(direction: Direction, offset: CGFloat)
    case vector(CGVector)
    case zoom(scale: CGFloat)
    case rotate(angle: CGFloat)
    case identity
    
    /// Creates the corresponding CGAffineTransform for AnimationType.from.
    public var initialTransform: CGAffineTransform {
        switch self {
        case .from(let direction, let offset):
                    let sign = direction.sign
                    if direction.isVertical { return CGAffineTransform(translationX: 0, y: offset * sign) }
                    return CGAffineTransform(translationX: offset * sign, y: 0)
        case .vector(let vector):
            return CGAffineTransform(translationX: vector.dx, y: vector.dy)
        case .zoom(let scale):
             return CGAffineTransform(scaleX: scale, y: scale)
        case .rotate(let angle):
            return CGAffineTransform(rotationAngle: angle)
        case .identity:
            return .identity
        }
    }
    
    /// Generates a random Animation.
    ///
    /// - Returns: Newly generated random Animation.
    public static func random() -> Animation {
        let index = Int.random(in: 0..<3)
        if index == 1 {
            return AnimationType.vector(CGVector(dx: .random(in: -10...10), dy: .random(in: -30...30)))
        } else if index == 2 {
            let scale = Double.random(in: 0...ViewAnimatorConfig.maxZoomScale)
            return AnimationType.zoom(scale: CGFloat(scale))
        }
        let angle = CGFloat.random(in: -ViewAnimatorConfig.maxRotationAngle...ViewAnimatorConfig.maxRotationAngle)
        return AnimationType.rotate(angle: angle)
    }
}



================================================
FILE: Sources/Models/Directions.swift
================================================
//
//  Direction.swift
//  Pods-ViewAnimator_Example
//
//  Created by Marcos Griselli on 10/5/17.
//
import UIKit

/// Direction of the animation used in AnimationType.from.
public enum Direction: Int, CaseIterable {

    case top
    case left
    case right
    case bottom
    
    /// Checks if the animation should go on the X or Y axis.
    var isVertical: Bool {
        switch self {
        case .top, .bottom:
            return true
        default:
            return false
        }
    }

    /// Positive or negative value to determine the direction.
    var sign: CGFloat {
        switch self {
        case .top, .left:
            return -1
        case .right, .bottom:
            return 1
        }
    }

    /// Random direction.
    static func random() -> Direction {
        return allCases.randomElement()!
    }
}


================================================
FILE: Sources/Protocols/Animation.swift
================================================
//
//  Animation.swift
//  Pods-ViewAnimator_Example
//
//  Created by Marcos Griselli on 10/16/17.
//

import UIKit

/// Animation protocol defines the initial transform for a view for it to
/// animate to its identity position.
public protocol Animation {

    /// Defines the starting point for the animations. 
    var initialTransform: CGAffineTransform { get }
}


================================================
FILE: Sources/ViewAnimator.swift
================================================
//
//  ViewAnimator.swift
//  Pods-ViewAnimator_Example
//
//  Created by Marcos Griselli on 10/5/17.
//

import Foundation
import UIKit

// MARK: - UIView extension with animations.
public extension UIView {
    
    // MARK: - Single View
    
    /// Animation based on the UIView.animateWithDuration API
    /// - Parameters:
    ///   - animations: Array of Animations to perform on the animation block.
    ///   - reversed: Initial state of the animation. Reversed will start from its original position.
    ///   - initialAlpha: Initial alpha of the view prior to the animation.
    ///   - finalAlpha: View's alpha after the animation.
    ///   - delay: Time Delay before the animation.
    ///   - duration: TimeInterval the animation takes to complete.
    ///   - options: UIView.AnimationsOptions to pass to the animation block.
    ///   - completion: block to run  after the animation finishes.
    func animate(animations: [Animation],
                 reversed: Bool = false,
                 initialAlpha: CGFloat = 0.0,
                 finalAlpha: CGFloat = 1.0,
                 delay: Double = 0,
                 duration: TimeInterval = ViewAnimatorConfig.duration,
                 options: UIView.AnimationOptions = [],
                 completion: (() -> Void)? = nil) {
        
        let transformFrom = transform
        var transformTo = transform
        animations.forEach { transformTo = transformTo.concatenating($0.initialTransform) }
        if !reversed {
            transform = transformTo
        }

        alpha = initialAlpha
        
        UIView.animate(withDuration: duration,
                       delay: delay,
                       options: options,
                       animations: { [weak self] in
            self?.transform = reversed ? transformTo : transformFrom
            self?.alpha = finalAlpha
        }) { _ in
            completion?()
        }
    }
    
    /// Animation based on UIView.animateWithDuration using springs
    ///
    /// - Parameters:
    ///   - animations: Array of Animations to perform on the animation block.
    ///   - reversed: Initial state of the animation. Reversed will start from its original position.
    ///   - initialAlpha: Initial alpha of the view prior to the animation.
    ///   - finalAlpha: View's alpha after the animation.
    ///   - delay: Time Delay before the animation.
    ///   - duration: TimeInterval the animation takes to complete.
    ///   - dampingRatio: The damping ratio for the spring animation.
    ///   - velocity: The initial spring velocity.
    ///   - options: UIView.AnimationsOptions to pass to the animation block. Timing functions will have no impact on spring based animations.
    ///   - completion: CompletionBlock after the animation finishes.
    func animate(animations: [Animation],
                 reversed: Bool = false,
                 initialAlpha: CGFloat = 0.0,
                 finalAlpha: CGFloat = 1.0,
                 delay: Double = 0,
                 duration: TimeInterval = ViewAnimatorConfig.duration,
                 usingSpringWithDamping dampingRatio: CGFloat,
                 initialSpringVelocity velocity: CGFloat,
                 options: UIView.AnimationOptions = [],
                 completion: (() -> Void)? = nil) {
        
        let transformFrom = transform
        var transformTo = transform
        animations.forEach { transformTo = transformTo.concatenating($0.initialTransform) }
        if !reversed {
            transform = transformTo
        }

        alpha = initialAlpha
        
        UIView.animate(withDuration: duration,
                       delay: delay,
                       usingSpringWithDamping: dampingRatio,
                       initialSpringVelocity: velocity,
                       options: options,
                       animations: { [weak self] in
            self?.transform = reversed ? transformTo : transformFrom
            self?.alpha = finalAlpha
        }) { _ in
            completion?()
        }
    }
    /**
     An extension on UIView that provides a convenient method for animating keyframes with multiple animations.

     - Parameters:
       - animations: An array of `Animation` objects representing the transformations to be applied in each keyframe.
       - initialAlpha: The initial alpha value of the view before the animation starts. Default is 1.0.
       - finalAlpha: The final alpha value of the view after the animation completes. Default is 1.0.
       - delay: The delay before the animation starts, in seconds. Default is 0.
       - duration: The total duration of the animation. Default is the value specified in `ViewAnimatorConfig.duration`.
       - options: Additional options for the keyframe animation. Default is an empty set.
       - completion: A closure to be executed after the animation finishes. Default is `nil`.

     The `animateKeyFrames` method animates a series of keyframes, each defined by an `Animation` object.
      The view's properties, such as transform and alpha, are animated over the specified duration and delay.

     Example usage:

     ```swift
     let angle: CGFloat = .pi / 8
     let animatins: [Animation] = [
         AnimationType.rotate(angle: -angle),
         AnimationType.rotate(angle: angle),
         AnimationType.rotate(angle: -angle),
         AnimationType.rotate(angle: angle),
         AnimationType.rotate(angle: 0)
     ]

     view.animateKeyFrames(animations: animations, initialAlpha: 0.5, finalAlpha: 1.0, delay: 0.2, duration: 2.0) {
         // Completion handler
         print("Animation completed!")
     }
     */
    func animateKeyFrames(animations: [Animation],
                          initialAlpha: CGFloat = 0.0,
                          finalAlpha: CGFloat = 1.0,
                          delay: Double = 0,
                          duration: TimeInterval = ViewAnimatorConfig.duration,
                          options: UIView.KeyframeAnimationOptions = [],
                          completion: (() -> Void)? = nil) {
        let numberOfFrames: Int = animations.count
        let singleFrameDuration: Double = Double(1/Double(numberOfFrames))
        
        alpha = initialAlpha
        
        UIView.animateKeyframes(withDuration: duration, delay: delay, options: options) { [weak self] in
            // iterates over each keyframe specified in the animations array.
            for index in 0..<numberOfFrames {
                let animation = animations[index]
                // calculates the relative start time for the current keyframe
                // This ensures that each keyframe starts at the appropriate time in the overall animation sequence
                let frameDurationStartTime = index == 0 ? 0.0 : Double(singleFrameDuration) * Double(index)
                
                // calculates the alpha value for the current keyframe
                let frameAlphaValue = initialAlpha + ((finalAlpha - initialAlpha) * CGFloat(frameDurationStartTime))
                
                UIView.addKeyframe(withRelativeStartTime: frameDurationStartTime, relativeDuration: singleFrameDuration) {
                    self?.transform = animation.initialTransform
                    // if initialAlpha equalts finalAlpha alpha will not animate
                    self?.alpha = frameAlphaValue
                }
            }
            
            UIView.addKeyframe(withRelativeStartTime: 0, relativeDuration: 0) {
                self?.transform = .identity
                self?.alpha = finalAlpha

            }
        } completion: { _ in
            completion?()
        }
    }
    // MARK: - UIView Array
    
    /// Animates multiples views with cascading effect using the UIView.animateWithDuration API
    ///
    /// - Parameters:
    ///   - animations: Array of Animations to perform on the animation block.
    ///   - reversed: Initial state of the animation. Reversed will start from its original position.
    ///   - initialAlpha: Initial alpha of the view prior to the animation.
    ///   - finalAlpha: View's alpha after the animation.
    ///   - delay: Time Delay before the animation.
    ///   - animationInterval: Interval between the animations of each view.
    ///   - duration: TimeInterval the animation takes to complete.
    ///   - dampingRatio: The damping ratio for the spring animation.
    ///   - velocity: The initial spring velocity.
    ///   - options: UIView.AnimationsOptions to pass to the animation block. Timing functions will have no impact on spring based animations.
    ///   - completion: CompletionBlock after the animation finishes.
    static func animate(views: [UIView],
                        animations: [Animation],
                        reversed: Bool = false,
                        initialAlpha: CGFloat = 0.0,
                        finalAlpha: CGFloat = 1.0,
                        delay: Double = 0,
                        animationInterval: TimeInterval = 0.05,
                        duration: TimeInterval = ViewAnimatorConfig.duration,
                        options: UIView.AnimationOptions = [],
                        completion: (() -> Void)? = nil) {

        performAnimation(views: views, animations: animations, reversed: reversed, initialAlpha: initialAlpha, delay: delay, animationBlock: { view, index, dispatchGroup in
            view.animate(animations: animations,
                         reversed: reversed,
                         initialAlpha: initialAlpha,
                         finalAlpha: finalAlpha,
                         delay: Double(index) * animationInterval,
                         duration: duration,
                         options: options,
                         completion: { dispatchGroup.leave() })
        }, completion: completion)
    }
    
    /// Animates multiples views with cascading effect using the UIView.animateWithDuration with springs
    ///
    /// - Parameters:
    ///   - animations: Array of Animations to perform on the animation block.
    ///   - reversed: Initial state of the animation. Reversed will start from its original position.
    ///   - initialAlpha: Initial alpha of the view prior to the animation.
    ///   - finalAlpha: View's alpha after the animation.
    ///   - delay: Time Delay before the animation.
    ///   - animationInterval: Interval between the animations of each view.
    ///   - duration: TimeInterval the animation takes to complete.
    ///   - dampingRatio: The damping ratio for the spring animation.
    ///   - velocity: The initial spring velocity.
    ///   - options: UIView.AnimationsOptions to pass to the animation block. Timing functions will have no impact on spring based animations.
    ///   - completion: CompletionBlock after the animation finishes.
    static func animate(views: [UIView],
                        animations: [Animation],
                        reversed: Bool = false,
                        initialAlpha: CGFloat = 0.0,
                        finalAlpha: CGFloat = 1.0,
                        delay: Double = 0,
                        animationInterval: TimeInterval = 0.05,
                        duration: TimeInterval = ViewAnimatorConfig.duration,
                        usingSpringWithDamping dampingRatio: CGFloat,
                        initialSpringVelocity velocity: CGFloat,
                        options: UIView.AnimationOptions = [],
                        completion: (() -> Void)? = nil) {

        performAnimation(views: views, animations: animations, reversed: reversed, initialAlpha: initialAlpha, delay: delay, animationBlock: { view, index, dispatchGroup in
            view.animate(animations: animations,
                         reversed: reversed,
                         initialAlpha: initialAlpha,
                         finalAlpha: finalAlpha,
                         delay: Double(index) * animationInterval,
                         duration: duration,
                         usingSpringWithDamping: dampingRatio,
                         initialSpringVelocity: velocity,
                         options: options,
                         completion: { dispatchGroup.leave() })
        }, completion: completion)
    }
    
    static private func performAnimation(
        views: [UIView],
        animations: [Animation],
        reversed: Bool = false,
        initialAlpha: CGFloat = 0.0,
        delay: Double = 0,
        animationBlock: @escaping ((UIView, Int, DispatchGroup) -> Void),
        completion: (() -> Void)? = nil) {
        guard views.count > 0 else {
            completion?()
            return
        }
        
        views.forEach { $0.alpha = initialAlpha }
        let dispatchGroup = DispatchGroup()
        for _ in 1...views.count { dispatchGroup.enter() }
        DispatchQueue.main.asyncAfter(deadline: .now() + delay) {
            for (index, view) in views.enumerated() {
                animationBlock(view, index, dispatchGroup)
            }
        }
        
        dispatchGroup.notify(queue: .main) {
            completion?()
        }
    }
}


================================================
FILE: Sources/ViewAnimatorConfig.swift
================================================
//
//  ViewAnimatorConfig.swift
//  Pods-ViewAnimator_Example
//
//  Created by Marcos Griselli on 10/9/17.
//

import UIKit

/// Configuration class for the default values used in animations.
/// All it's values are used when creating 'random' animations as well.
public class ViewAnimatorConfig {
    
    /// Amount of movement in points.
    /// Depends on the Direction given to the AnimationType.
    public static var offset: CGFloat = 30.0
    
    /// Duration of the animation.
    public static var duration: Double = 0.3
    
    /// Interval for animations handling multiple views that need
    /// to be animated one after the other and not at the same time.
    public static var interval: Double = 0.075
    
    /// Maximum zoom to be applied in animations using random AnimationType.zoom.
    public static var maxZoomScale: Double = 2.0
    
    /// Maximum rotation (left or right) to be applied in animations using random AnimationType.rotate
    public static var maxRotationAngle: CGFloat = CGFloat.pi/4

    /// The damping ratio for the spring animation as it approaches its quiescent state.
    public static var springDampingRatio: CGFloat = 1
    
    /// The initial spring velocity. For smooth start to the animation, match this value to the view’s velocity as it was prior to attachment.
    public static var initialSpringVelocity: CGFloat = 0
}


================================================
FILE: ViewAnimator.podspec
================================================
Pod::Spec.new do |s|
  s.name             = 'ViewAnimator'
  s.version          = '3.1.0'
  s.summary          = 'ViewAnimator brings your UI to life with just one line of code.'

  s.description      = <<-DESC
    ViewAnimator helps create beautiful animations of an entire UI with only one line of code.
    It also supports UITableView/UICollectionView and UIStackView animation of cells and arrangedSubviews
    with delightful interactions.
                       DESC

  s.homepage         = 'https://github.com/marcosgriselli/ViewAnimator'
  s.license          = { :type => 'MIT', :file => 'LICENSE' }
  s.author           = { 'marcosgriselli@gmail.com' => 'marcosgriselli@gmail.com' }
  s.source           = { :git => 'https://github.com/marcosgriselli/ViewAnimator.git', :tag => s.version.to_s }
  s.social_media_url = 'https://twitter.com/marcosgriselli'

  s.swift_version = "5.1"
  s.swift_versions = ['4.0', '4.2', '5.0']

  s.ios.deployment_target = '8.0'
  s.tvos.deployment_target = '9.0'
  s.source_files = 'Sources/**/*'

end


================================================
FILE: ViewAnimator.xcodeproj/ViewAnimator_Info.plist
================================================
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
	<key>CFBundleDevelopmentRegion</key>
	<string>en</string>
	<key>CFBundleExecutable</key>
	<string>$(EXECUTABLE_NAME)</string>
	<key>CFBundleIdentifier</key>
	<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
	<key>CFBundleInfoDictionaryVersion</key>
	<string>6.0</string>
	<key>CFBundleName</key>
	<string>$(PRODUCT_NAME)</string>
	<key>CFBundlePackageType</key>
	<string>FMWK</string>
	<key>CFBundleShortVersionString</key>
	<string>1.0</string>
	<key>CFBundleSignature</key>
	<string>????</string>
	<key>CFBundleVersion</key>
	<string>1</string>
	<key>NSPrincipalClass</key>
	<string></string>
</dict>
</plist>


================================================
FILE: ViewAnimator.xcodeproj/project.pbxproj
================================================
// !$*UTF8*$!
{
	archiveVersion = 1;
	classes = {
	};
	objectVersion = 46;
	objects = {

/* Begin PBXBuildFile section */
		FB54AC2324FAA50B003A00A4 /* Tests.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC1324FAA38F003A00A4 /* Tests.swift */; };
		FBAF26BB24FAA5B700B990CF /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = FBAF26BA24FAA5B700B990CF /* AppDelegate.swift */; };
		FBAF26C524FAA5B900B990CF /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = FBAF26C324FAA5B900B990CF /* LaunchScreen.storyboard */; };
		FBC9B9B824FAA7AA0048483A /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = FB54ABFC24FAA372003A00A4 /* Main.storyboard */; };
		FBC9B9B924FAA7AE0048483A /* ViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54ABFF24FAA372003A00A4 /* ViewController.swift */; };
		FBC9B9BA24FAA7B00048483A /* TableViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC0024FAA372003A00A4 /* TableViewController.swift */; };
		FBC9B9BB24FAA7B30048483A /* CollectionViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC0124FAA372003A00A4 /* CollectionViewController.swift */; };
		FBC9B9BC24FAA7B90048483A /* TableViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC0624FAA372003A00A4 /* TableViewCell.swift */; };
		FBC9B9BD24FAA7B90048483A /* CollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC0724FAA372003A00A4 /* CollectionViewCell.swift */; };
		FBC9B9BE24FAA7B90048483A /* Designable.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC0824FAA372003A00A4 /* Designable.swift */; };
		FBC9B9BF24FAA7C30048483A /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = FB54AC0224FAA372003A00A4 /* Assets.xcassets */; };
		FBC9B9C024FAA84F0048483A /* ViewAnimator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "ViewAnimator::ViewAnimator::Product" /* ViewAnimator.framework */; };
		FBC9B9C124FAA84F0048483A /* ViewAnimator.framework in Embed Frameworks */ = {isa = PBXBuildFile; fileRef = "ViewAnimator::ViewAnimator::Product" /* ViewAnimator.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; };
		FBC9B9D824FAAA160048483A /* ViewAnimator.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = "ViewAnimator::ViewAnimator::Product" /* ViewAnimator.framework */; };
		FBC9B9D924FAAA160048483A /* ViewAnimator.framework in Embed Frameworks */ = {isa = PBXBuildFile; fileRef = "ViewAnimator::ViewAnimator::Product" /* ViewAnimator.framework */; settings = {ATTRIBUTES = (CodeSignOnCopy, RemoveHeadersOnCopy, ); }; };
		FBC9B9DD24FAAA350048483A /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC1024FAA372003A00A4 /* AppDelegate.swift */; };
		FBC9B9DE24FAAA350048483A /* CollectionViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC1224FAA372003A00A4 /* CollectionViewController.swift */; };
		FBC9B9DF24FAAA410048483A /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = FB54AC0E24FAA372003A00A4 /* Main.storyboard */; };
		FBC9B9E024FAAA460048483A /* CollectionViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = FB54AC0C24FAA372003A00A4 /* CollectionViewCell.swift */; };
		FBC9B9E124FAAA480048483A /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = FB54AC0D24FAA372003A00A4 /* Assets.xcassets */; };
		FBCE039C267CF75100C9B663 /* Directions.swift in Sources */ = {isa = PBXBuildFile; fileRef = FBCE039B267CF75100C9B663 /* Directions.swift */; };
		OBJ_36 /* UICollectionView + ViewAnimator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_9 /* UICollectionView + ViewAnimator.swift */; };
		OBJ_37 /* UITableView + ViewAnimator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_10 /* UITableView + ViewAnimator.swift */; };
		OBJ_38 /* AnimationType.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_12 /* AnimationType.swift */; };
		OBJ_40 /* Animation.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_15 /* Animation.swift */; };
		OBJ_41 /* ViewAnimator.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_16 /* ViewAnimator.swift */; };
		OBJ_42 /* ViewAnimatorConfig.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_17 /* ViewAnimatorConfig.swift */; };
		OBJ_49 /* Package.swift in Sources */ = {isa = PBXBuildFile; fileRef = OBJ_6 /* Package.swift */; };
/* End PBXBuildFile section */

/* Begin PBXContainerItemProxy section */
		FBC9B9C224FAA84F0048483A /* PBXContainerItemProxy */ = {
			isa = PBXContainerItemProxy;
			containerPortal = OBJ_1 /* Project object */;
			proxyType = 1;
			remoteGlobalIDString = "ViewAnimator::ViewAnimator";
			remoteInfo = ViewAnimator;
		};
		FBC9B9DA24FAAA160048483A /* PBXContainerItemProxy */ = {
			isa = PBXContainerItemProxy;
			containerPortal = OBJ_1 /* Project object */;
			proxyType = 1;
			remoteGlobalIDString = "ViewAnimator::ViewAnimator";
			remoteInfo = ViewAnimator;
		};
/* End PBXContainerItemProxy section */

/* Begin PBXCopyFilesBuildPhase section */
		FBC9B9C424FAA84F0048483A /* Embed Frameworks */ = {
			isa = PBXCopyFilesBuildPhase;
			buildActionMask = 2147483647;
			dstPath = "";
			dstSubfolderSpec = 10;
			files = (
				FBC9B9C124FAA84F0048483A /* ViewAnimator.framework in Embed Frameworks */,
			);
			name = "Embed Frameworks";
			runOnlyForDeploymentPostprocessing = 0;
		};
		FBC9B9DC24FAAA160048483A /* Embed Frameworks */ = {
			isa = PBXCopyFilesBuildPhase;
			buildActionMask = 2147483647;
			dstPath = "";
			dstSubfolderSpec = 10;
			files = (
				FBC9B9D924FAAA160048483A /* ViewAnimator.framework in Embed Frameworks */,
			);
			name = "Embed Frameworks";
			runOnlyForDeploymentPostprocessing = 0;
		};
/* End PBXCopyFilesBuildPhase section */

/* Begin PBXFileReference section */
		FB54ABFD24FAA372003A00A4 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = "<group>"; };
		FB54ABFF24FAA372003A00A4 /* ViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewController.swift; sourceTree = "<group>"; };
		FB54AC0024FAA372003A00A4 /* TableViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TableViewController.swift; sourceTree = "<group>"; };
		FB54AC0124FAA372003A00A4 /* CollectionViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CollectionViewController.swift; sourceTree = "<group>"; };
		FB54AC0224FAA372003A00A4 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
		FB54AC0624FAA372003A00A4 /* TableViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = TableViewCell.swift; sourceTree = "<group>"; };
		FB54AC0724FAA372003A00A4 /* CollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CollectionViewCell.swift; sourceTree = "<group>"; };
		FB54AC0824FAA372003A00A4 /* Designable.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Designable.swift; sourceTree = "<group>"; };
		FB54AC0C24FAA372003A00A4 /* CollectionViewCell.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CollectionViewCell.swift; sourceTree = "<group>"; };
		FB54AC0D24FAA372003A00A4 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
		FB54AC0F24FAA372003A00A4 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = "<group>"; };
		FB54AC1024FAA372003A00A4 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
		FB54AC1124FAA372003A00A4 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
		FB54AC1224FAA372003A00A4 /* CollectionViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = CollectionViewController.swift; sourceTree = "<group>"; };
		FB54AC1324FAA38F003A00A4 /* Tests.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Tests.swift; sourceTree = "<group>"; };
		FB54AC1B24FAA505003A00A4 /* ViewAnimatorTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = ViewAnimatorTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
		FB54AC1F24FAA505003A00A4 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
		FBAF26B824FAA5B700B990CF /* ViewAnimator-iOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "ViewAnimator-iOS.app"; sourceTree = BUILT_PRODUCTS_DIR; };
		FBAF26BA24FAA5B700B990CF /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
		FBAF26C424FAA5B900B990CF /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
		FBAF26C624FAA5B900B990CF /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
		FBC9B9C924FAA9C90048483A /* ViewAnimator-tvOS.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = "ViewAnimator-tvOS.app"; sourceTree = BUILT_PRODUCTS_DIR; };
		FBCE039B267CF75100C9B663 /* Directions.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Directions.swift; sourceTree = "<group>"; };
		OBJ_10 /* UITableView + ViewAnimator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UITableView + ViewAnimator.swift"; sourceTree = "<group>"; };
		OBJ_12 /* AnimationType.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AnimationType.swift; sourceTree = "<group>"; };
		OBJ_15 /* Animation.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Animation.swift; sourceTree = "<group>"; };
		OBJ_16 /* ViewAnimator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewAnimator.swift; sourceTree = "<group>"; };
		OBJ_17 /* ViewAnimatorConfig.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewAnimatorConfig.swift; sourceTree = "<group>"; };
		OBJ_6 /* Package.swift */ = {isa = PBXFileReference; explicitFileType = sourcecode.swift; path = Package.swift; sourceTree = "<group>"; };
		OBJ_9 /* UICollectionView + ViewAnimator.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "UICollectionView + ViewAnimator.swift"; sourceTree = "<group>"; };
		"ViewAnimator::ViewAnimator::Product" /* ViewAnimator.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; path = ViewAnimator.framework; sourceTree = BUILT_PRODUCTS_DIR; };
/* End PBXFileReference section */

/* Begin PBXFrameworksBuildPhase section */
		FB54AC1824FAA505003A00A4 /* Frameworks */ = {
			isa = PBXFrameworksBuildPhase;
			buildActionMask = 2147483647;
			files = (
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		FBAF26B524FAA5B700B990CF /* Frameworks */ = {
			isa = PBXFrameworksBuildPhase;
			buildActionMask = 2147483647;
			files = (
				FBC9B9C024FAA84F0048483A /* ViewAnimator.framework in Frameworks */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		FBC9B9C624FAA9C90048483A /* Frameworks */ = {
			isa = PBXFrameworksBuildPhase;
			buildActionMask = 2147483647;
			files = (
				FBC9B9D824FAAA160048483A /* ViewAnimator.framework in Frameworks */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		OBJ_43 /* Frameworks */ = {
			isa = PBXFrameworksBuildPhase;
			buildActionMask = 0;
			files = (
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
/* End PBXFrameworksBuildPhase section */

/* Begin PBXGroup section */
		FB54ABFE24FAA372003A00A4 /* ViewControllers */ = {
			isa = PBXGroup;
			children = (
				FB54ABFF24FAA372003A00A4 /* ViewController.swift */,
				FB54AC0024FAA372003A00A4 /* TableViewController.swift */,
				FB54AC0124FAA372003A00A4 /* CollectionViewController.swift */,
			);
			path = ViewControllers;
			sourceTree = "<group>";
		};
		FB54AC0424FAA372003A00A4 /* Views */ = {
			isa = PBXGroup;
			children = (
				FB54AC0524FAA372003A00A4 /* Cells */,
				FB54AC0824FAA372003A00A4 /* Designable.swift */,
			);
			path = Views;
			sourceTree = "<group>";
		};
		FB54AC0524FAA372003A00A4 /* Cells */ = {
			isa = PBXGroup;
			children = (
				FB54AC0624FAA372003A00A4 /* TableViewCell.swift */,
				FB54AC0724FAA372003A00A4 /* CollectionViewCell.swift */,
			);
			path = Cells;
			sourceTree = "<group>";
		};
		FB54AC0A24FAA372003A00A4 /* tvOS */ = {
			isa = PBXGroup;
			children = (
				FB54AC1024FAA372003A00A4 /* AppDelegate.swift */,
				FB54AC1224FAA372003A00A4 /* CollectionViewController.swift */,
				FB54AC0E24FAA372003A00A4 /* Main.storyboard */,
				FB54AC0B24FAA372003A00A4 /* Cells */,
				FB54AC0D24FAA372003A00A4 /* Assets.xcassets */,
				FB54AC1124FAA372003A00A4 /* Info.plist */,
			);
			path = tvOS;
			sourceTree = "<group>";
		};
		FB54AC0B24FAA372003A00A4 /* Cells */ = {
			isa = PBXGroup;
			children = (
				FB54AC0C24FAA372003A00A4 /* CollectionViewCell.swift */,
			);
			path = Cells;
			sourceTree = "<group>";
		};
		FB54AC1624FAA45C003A00A4 /* Example */ = {
			isa = PBXGroup;
			children = (
				FBAF26B924FAA5B700B990CF /* iOS */,
				FB54AC0A24FAA372003A00A4 /* tvOS */,
			);
			path = Example;
			sourceTree = "<group>";
		};
		FB54AC1C24FAA505003A00A4 /* ViewAnimatorTests */ = {
			isa = PBXGroup;
			children = (
				FB54AC1324FAA38F003A00A4 /* Tests.swift */,
				FB54AC1F24FAA505003A00A4 /* Info.plist */,
			);
			path = ViewAnimatorTests;
			sourceTree = "<group>";
		};
		FBAF26B924FAA5B700B990CF /* iOS */ = {
			isa = PBXGroup;
			children = (
				FBAF26BA24FAA5B700B990CF /* AppDelegate.swift */,
				FB54ABFC24FAA372003A00A4 /* Main.storyboard */,
				FB54ABFE24FAA372003A00A4 /* ViewControllers */,
				FB54AC0424FAA372003A00A4 /* Views */,
				FB54AC0224FAA372003A00A4 /* Assets.xcassets */,
				FBAF26C324FAA5B900B990CF /* LaunchScreen.storyboard */,
				FBAF26C624FAA5B900B990CF /* Info.plist */,
			);
			path = iOS;
			sourceTree = "<group>";
		};
		OBJ_11 /* Models */ = {
			isa = PBXGroup;
			children = (
				OBJ_12 /* AnimationType.swift */,
				FBCE039B267CF75100C9B663 /* Directions.swift */,
			);
			path = Models;
			sourceTree = "<group>";
		};
		OBJ_14 /* Protocols */ = {
			isa = PBXGroup;
			children = (
				OBJ_15 /* Animation.swift */,
			);
			path = Protocols;
			sourceTree = "<group>";
		};
		OBJ_19 /* Products */ = {
			isa = PBXGroup;
			children = (
				"ViewAnimator::ViewAnimator::Product" /* ViewAnimator.framework */,
				FB54AC1B24FAA505003A00A4 /* ViewAnimatorTests.xctest */,
				FBAF26B824FAA5B700B990CF /* ViewAnimator-iOS.app */,
				FBC9B9C924FAA9C90048483A /* ViewAnimator-tvOS.app */,
			);
			name = Products;
			sourceTree = BUILT_PRODUCTS_DIR;
		};
		OBJ_5 = {
			isa = PBXGroup;
			children = (
				OBJ_6 /* Package.swift */,
				FB54AC1624FAA45C003A00A4 /* Example */,
				OBJ_7 /* Sources */,
				FB54AC1C24FAA505003A00A4 /* ViewAnimatorTests */,
				OBJ_19 /* Products */,
			);
			sourceTree = "<group>";
		};
		OBJ_7 /* Sources */ = {
			isa = PBXGroup;
			children = (
				OBJ_8 /* Extensions */,
				OBJ_11 /* Models */,
				OBJ_14 /* Protocols */,
				OBJ_16 /* ViewAnimator.swift */,
				OBJ_17 /* ViewAnimatorConfig.swift */,
			);
			path = Sources;
			sourceTree = SOURCE_ROOT;
		};
		OBJ_8 /* Extensions */ = {
			isa = PBXGroup;
			children = (
				OBJ_9 /* UICollectionView + ViewAnimator.swift */,
				OBJ_10 /* UITableView + ViewAnimator.swift */,
			);
			path = Extensions;
			sourceTree = "<group>";
		};
/* End PBXGroup section */

/* Begin PBXNativeTarget section */
		FB54AC1A24FAA505003A00A4 /* ViewAnimatorTests */ = {
			isa = PBXNativeTarget;
			buildConfigurationList = FB54AC2024FAA505003A00A4 /* Build configuration list for PBXNativeTarget "ViewAnimatorTests" */;
			buildPhases = (
				FB54AC1724FAA505003A00A4 /* Sources */,
				FB54AC1824FAA505003A00A4 /* Frameworks */,
				FB54AC1924FAA505003A00A4 /* Resources */,
			);
			buildRules = (
			);
			dependencies = (
			);
			name = ViewAnimatorTests;
			productName = ViewAnimatorTests;
			productReference = FB54AC1B24FAA505003A00A4 /* ViewAnimatorTests.xctest */;
			productType = "com.apple.product-type.bundle.unit-test";
		};
		FBAF26B724FAA5B700B990CF /* ViewAnimator-iOS */ = {
			isa = PBXNativeTarget;
			buildConfigurationList = FBAF26C924FAA5B900B990CF /* Build configuration list for PBXNativeTarget "ViewAnimator-iOS" */;
			buildPhases = (
				FBAF26B424FAA5B700B990CF /* Sources */,
				FBAF26B524FAA5B700B990CF /* Frameworks */,
				FBAF26B624FAA5B700B990CF /* Resources */,
				FBC9B9C424FAA84F0048483A /* Embed Frameworks */,
			);
			buildRules = (
			);
			dependencies = (
				FBC9B9C324FAA84F0048483A /* PBXTargetDependency */,
			);
			name = "ViewAnimator-iOS";
			productName = "ViewAnimator-iOS";
			productReference = FBAF26B824FAA5B700B990CF /* ViewAnimator-iOS.app */;
			productType = "com.apple.product-type.application";
		};
		FBC9B9C824FAA9C90048483A /* ViewAnimator-tvOS */ = {
			isa = PBXNativeTarget;
			buildConfigurationList = FBC9B9D524FAA9CA0048483A /* Build configuration list for PBXNativeTarget "ViewAnimator-tvOS" */;
			buildPhases = (
				FBC9B9C524FAA9C90048483A /* Sources */,
				FBC9B9C624FAA9C90048483A /* Frameworks */,
				FBC9B9C724FAA9C90048483A /* Resources */,
				FBC9B9DC24FAAA160048483A /* Embed Frameworks */,
			);
			buildRules = (
			);
			dependencies = (
				FBC9B9DB24FAAA160048483A /* PBXTargetDependency */,
			);
			name = "ViewAnimator-tvOS";
			productName = "ViewAnimator-tvOS";
			productReference = FBC9B9C924FAA9C90048483A /* ViewAnimator-tvOS.app */;
			productType = "com.apple.product-type.application";
		};
		"ViewAnimator::SwiftPMPackageDescription" /* ViewAnimatorPackageDescription */ = {
			isa = PBXNativeTarget;
			buildConfigurationList = OBJ_45 /* Build configuration list for PBXNativeTarget "ViewAnimatorPackageDescription" */;
			buildPhases = (
				OBJ_48 /* Sources */,
			);
			buildRules = (
			);
			dependencies = (
			);
			name = ViewAnimatorPackageDescription;
			productName = ViewAnimatorPackageDescription;
			productType = "com.apple.product-type.framework";
		};
		"ViewAnimator::ViewAnimator" /* ViewAnimator */ = {
			isa = PBXNativeTarget;
			buildConfigurationList = OBJ_32 /* Build configuration list for PBXNativeTarget "ViewAnimator" */;
			buildPhases = (
				OBJ_35 /* Sources */,
				OBJ_43 /* Frameworks */,
			);
			buildRules = (
			);
			dependencies = (
			);
			name = ViewAnimator;
			productName = ViewAnimator;
			productReference = "ViewAnimator::ViewAnimator::Product" /* ViewAnimator.framework */;
			productType = "com.apple.product-type.framework";
		};
/* End PBXNativeTarget section */

/* Begin PBXProject section */
		OBJ_1 /* Project object */ = {
			isa = PBXProject;
			attributes = {
				LastSwiftMigration = 9999;
				LastSwiftUpdateCheck = 1030;
				LastUpgradeCheck = 9999;
				TargetAttributes = {
					FB54AC1A24FAA505003A00A4 = {
						CreatedOnToolsVersion = 10.3;
						DevelopmentTeam = 8PC4X7QUY9;
						ProvisioningStyle = Automatic;
					};
					FBAF26B724FAA5B700B990CF = {
						CreatedOnToolsVersion = 10.3;
						ProvisioningStyle = Automatic;
					};
					FBC9B9C824FAA9C90048483A = {
						CreatedOnToolsVersion = 10.3;
						ProvisioningStyle = Automatic;
					};
				};
			};
			buildConfigurationList = OBJ_2 /* Build configuration list for PBXProject "ViewAnimator" */;
			compatibilityVersion = "Xcode 3.2";
			developmentRegion = English;
			hasScannedForEncodings = 0;
			knownRegions = (
				English,
				en,
				Base,
			);
			mainGroup = OBJ_5;
			productRefGroup = OBJ_19 /* Products */;
			projectDirPath = "";
			projectRoot = "";
			targets = (
				"ViewAnimator::ViewAnimator" /* ViewAnimator */,
				"ViewAnimator::SwiftPMPackageDescription" /* ViewAnimatorPackageDescription */,
				FB54AC1A24FAA505003A00A4 /* ViewAnimatorTests */,
				FBAF26B724FAA5B700B990CF /* ViewAnimator-iOS */,
				FBC9B9C824FAA9C90048483A /* ViewAnimator-tvOS */,
			);
		};
/* End PBXProject section */

/* Begin PBXResourcesBuildPhase section */
		FB54AC1924FAA505003A00A4 /* Resources */ = {
			isa = PBXResourcesBuildPhase;
			buildActionMask = 2147483647;
			files = (
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		FBAF26B624FAA5B700B990CF /* Resources */ = {
			isa = PBXResourcesBuildPhase;
			buildActionMask = 2147483647;
			files = (
				FBC9B9B824FAA7AA0048483A /* Main.storyboard in Resources */,
				FBC9B9BF24FAA7C30048483A /* Assets.xcassets in Resources */,
				FBAF26C524FAA5B900B990CF /* LaunchScreen.storyboard in Resources */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		FBC9B9C724FAA9C90048483A /* Resources */ = {
			isa = PBXResourcesBuildPhase;
			buildActionMask = 2147483647;
			files = (
				FBC9B9DF24FAAA410048483A /* Main.storyboard in Resources */,
				FBC9B9E124FAAA480048483A /* Assets.xcassets in Resources */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
/* End PBXResourcesBuildPhase section */

/* Begin PBXSourcesBuildPhase section */
		FB54AC1724FAA505003A00A4 /* Sources */ = {
			isa = PBXSourcesBuildPhase;
			buildActionMask = 2147483647;
			files = (
				FB54AC2324FAA50B003A00A4 /* Tests.swift in Sources */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		FBAF26B424FAA5B700B990CF /* Sources */ = {
			isa = PBXSourcesBuildPhase;
			buildActionMask = 2147483647;
			files = (
				FBC9B9BC24FAA7B90048483A /* TableViewCell.swift in Sources */,
				FBC9B9BE24FAA7B90048483A /* Designable.swift in Sources */,
				FBC9B9BB24FAA7B30048483A /* CollectionViewController.swift in Sources */,
				FBC9B9BD24FAA7B90048483A /* CollectionViewCell.swift in Sources */,
				FBC9B9B924FAA7AE0048483A /* ViewController.swift in Sources */,
				FBC9B9BA24FAA7B00048483A /* TableViewController.swift in Sources */,
				FBAF26BB24FAA5B700B990CF /* AppDelegate.swift in Sources */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		FBC9B9C524FAA9C90048483A /* Sources */ = {
			isa = PBXSourcesBuildPhase;
			buildActionMask = 2147483647;
			files = (
				FBC9B9E024FAAA460048483A /* CollectionViewCell.swift in Sources */,
				FBC9B9DE24FAAA350048483A /* CollectionViewController.swift in Sources */,
				FBC9B9DD24FAAA350048483A /* AppDelegate.swift in Sources */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		OBJ_35 /* Sources */ = {
			isa = PBXSourcesBuildPhase;
			buildActionMask = 0;
			files = (
				OBJ_36 /* UICollectionView + ViewAnimator.swift in Sources */,
				FBCE039C267CF75100C9B663 /* Directions.swift in Sources */,
				OBJ_37 /* UITableView + ViewAnimator.swift in Sources */,
				OBJ_38 /* AnimationType.swift in Sources */,
				OBJ_40 /* Animation.swift in Sources */,
				OBJ_41 /* ViewAnimator.swift in Sources */,
				OBJ_42 /* ViewAnimatorConfig.swift in Sources */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
		OBJ_48 /* Sources */ = {
			isa = PBXSourcesBuildPhase;
			buildActionMask = 0;
			files = (
				OBJ_49 /* Package.swift in Sources */,
			);
			runOnlyForDeploymentPostprocessing = 0;
		};
/* End PBXSourcesBuildPhase section */

/* Begin PBXTargetDependency section */
		FBC9B9C324FAA84F0048483A /* PBXTargetDependency */ = {
			isa = PBXTargetDependency;
			target = "ViewAnimator::ViewAnimator" /* ViewAnimator */;
			targetProxy = FBC9B9C224FAA84F0048483A /* PBXContainerItemProxy */;
		};
		FBC9B9DB24FAAA160048483A /* PBXTargetDependency */ = {
			isa = PBXTargetDependency;
			target = "ViewAnimator::ViewAnimator" /* ViewAnimator */;
			targetProxy = FBC9B9DA24FAAA160048483A /* PBXContainerItemProxy */;
		};
/* End PBXTargetDependency section */

/* Begin PBXVariantGroup section */
		FB54ABFC24FAA372003A00A4 /* Main.storyboard */ = {
			isa = PBXVariantGroup;
			children = (
				FB54ABFD24FAA372003A00A4 /* Base */,
			);
			name = Main.storyboard;
			sourceTree = "<group>";
		};
		FB54AC0E24FAA372003A00A4 /* Main.storyboard */ = {
			isa = PBXVariantGroup;
			children = (
				FB54AC0F24FAA372003A00A4 /* Base */,
			);
			name = Main.storyboard;
			sourceTree = "<group>";
		};
		FBAF26C324FAA5B900B990CF /* LaunchScreen.storyboard */ = {
			isa = PBXVariantGroup;
			children = (
				FBAF26C424FAA5B900B990CF /* Base */,
			);
			name = LaunchScreen.storyboard;
			sourceTree = "<group>";
		};
/* End PBXVariantGroup section */

/* Begin XCBuildConfiguration section */
		FB54AC2124FAA505003A00A4 /* Debug */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				ALWAYS_SEARCH_USER_PATHS = NO;
				CLANG_ANALYZER_NONNULL = YES;
				CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
				CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
				CLANG_CXX_LIBRARY = "libc++";
				CLANG_ENABLE_MODULES = YES;
				CLANG_ENABLE_OBJC_WEAK = YES;
				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
				CLANG_WARN_BOOL_CONVERSION = YES;
				CLANG_WARN_COMMA = YES;
				CLANG_WARN_CONSTANT_CONVERSION = YES;
				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
				CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
				CLANG_WARN_EMPTY_BODY = YES;
				CLANG_WARN_ENUM_CONVERSION = YES;
				CLANG_WARN_INFINITE_RECURSION = YES;
				CLANG_WARN_INT_CONVERSION = YES;
				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
				CLANG_WARN_STRICT_PROTOTYPES = YES;
				CLANG_WARN_SUSPICIOUS_MOVE = YES;
				CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
				CLANG_WARN_UNREACHABLE_CODE = YES;
				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
				CODE_SIGN_IDENTITY = "iPhone Developer";
				CODE_SIGN_STYLE = Automatic;
				DEVELOPMENT_TEAM = 8PC4X7QUY9;
				ENABLE_STRICT_OBJC_MSGSEND = YES;
				ENABLE_TESTABILITY = YES;
				GCC_C_LANGUAGE_STANDARD = gnu11;
				GCC_DYNAMIC_NO_PIC = NO;
				GCC_NO_COMMON_BLOCKS = YES;
				GCC_PREPROCESSOR_DEFINITIONS = (
					"DEBUG=1",
					"$(inherited)",
				);
				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
				GCC_WARN_UNDECLARED_SELECTOR = YES;
				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
				GCC_WARN_UNUSED_FUNCTION = YES;
				GCC_WARN_UNUSED_VARIABLE = YES;
				INFOPLIST_FILE = ViewAnimatorTests/Info.plist;
				IPHONEOS_DEPLOYMENT_TARGET = 12.4;
				LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
				MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE;
				MTL_FAST_MATH = YES;
				PRODUCT_BUNDLE_IDENTIFIER = com.marcosgriselli.ViewAnimatorTests;
				PRODUCT_NAME = "$(TARGET_NAME)";
				SDKROOT = iphoneos;
				SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
				SWIFT_VERSION = 5.0;
				TARGETED_DEVICE_FAMILY = "1,2";
			};
			name = Debug;
		};
		FB54AC2224FAA505003A00A4 /* Release */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				ALWAYS_SEARCH_USER_PATHS = NO;
				CLANG_ANALYZER_NONNULL = YES;
				CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
				CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
				CLANG_CXX_LIBRARY = "libc++";
				CLANG_ENABLE_MODULES = YES;
				CLANG_ENABLE_OBJC_WEAK = YES;
				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
				CLANG_WARN_BOOL_CONVERSION = YES;
				CLANG_WARN_COMMA = YES;
				CLANG_WARN_CONSTANT_CONVERSION = YES;
				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
				CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
				CLANG_WARN_EMPTY_BODY = YES;
				CLANG_WARN_ENUM_CONVERSION = YES;
				CLANG_WARN_INFINITE_RECURSION = YES;
				CLANG_WARN_INT_CONVERSION = YES;
				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
				CLANG_WARN_STRICT_PROTOTYPES = YES;
				CLANG_WARN_SUSPICIOUS_MOVE = YES;
				CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
				CLANG_WARN_UNREACHABLE_CODE = YES;
				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
				CODE_SIGN_IDENTITY = "iPhone Developer";
				CODE_SIGN_STYLE = Automatic;
				COPY_PHASE_STRIP = NO;
				DEVELOPMENT_TEAM = 8PC4X7QUY9;
				ENABLE_NS_ASSERTIONS = NO;
				ENABLE_STRICT_OBJC_MSGSEND = YES;
				GCC_C_LANGUAGE_STANDARD = gnu11;
				GCC_NO_COMMON_BLOCKS = YES;
				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
				GCC_WARN_UNDECLARED_SELECTOR = YES;
				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
				GCC_WARN_UNUSED_FUNCTION = YES;
				GCC_WARN_UNUSED_VARIABLE = YES;
				INFOPLIST_FILE = ViewAnimatorTests/Info.plist;
				IPHONEOS_DEPLOYMENT_TARGET = 12.4;
				LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
				MTL_ENABLE_DEBUG_INFO = NO;
				MTL_FAST_MATH = YES;
				PRODUCT_BUNDLE_IDENTIFIER = com.marcosgriselli.ViewAnimatorTests;
				PRODUCT_NAME = "$(TARGET_NAME)";
				SDKROOT = iphoneos;
				SWIFT_VERSION = 5.0;
				TARGETED_DEVICE_FAMILY = "1,2";
				VALIDATE_PRODUCT = YES;
			};
			name = Release;
		};
		FBAF26C724FAA5B900B990CF /* Debug */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;
				ALWAYS_SEARCH_USER_PATHS = NO;
				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
				CLANG_ANALYZER_NONNULL = YES;
				CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
				CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
				CLANG_CXX_LIBRARY = "libc++";
				CLANG_ENABLE_MODULES = YES;
				CLANG_ENABLE_OBJC_WEAK = YES;
				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
				CLANG_WARN_BOOL_CONVERSION = YES;
				CLANG_WARN_COMMA = YES;
				CLANG_WARN_CONSTANT_CONVERSION = YES;
				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
				CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
				CLANG_WARN_EMPTY_BODY = YES;
				CLANG_WARN_ENUM_CONVERSION = YES;
				CLANG_WARN_INFINITE_RECURSION = YES;
				CLANG_WARN_INT_CONVERSION = YES;
				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
				CLANG_WARN_STRICT_PROTOTYPES = YES;
				CLANG_WARN_SUSPICIOUS_MOVE = YES;
				CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
				CLANG_WARN_UNREACHABLE_CODE = YES;
				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
				CODE_SIGN_IDENTITY = "Apple Development";
				CODE_SIGN_STYLE = Automatic;
				DEVELOPMENT_TEAM = "";
				ENABLE_STRICT_OBJC_MSGSEND = YES;
				ENABLE_TESTABILITY = YES;
				GCC_C_LANGUAGE_STANDARD = gnu11;
				GCC_DYNAMIC_NO_PIC = NO;
				GCC_NO_COMMON_BLOCKS = YES;
				GCC_PREPROCESSOR_DEFINITIONS = (
					"DEBUG=1",
					"$(inherited)",
				);
				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
				GCC_WARN_UNDECLARED_SELECTOR = YES;
				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
				GCC_WARN_UNUSED_FUNCTION = YES;
				GCC_WARN_UNUSED_VARIABLE = YES;
				INFOPLIST_FILE = Example/iOS/Info.plist;
				IPHONEOS_DEPLOYMENT_TARGET = 12.4;
				LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
				MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE;
				MTL_FAST_MATH = YES;
				PRODUCT_BUNDLE_IDENTIFIER = "com.marcosgriselli.ViewAnimator-iOS";
				PRODUCT_NAME = "$(TARGET_NAME)";
				SDKROOT = iphoneos;
				SUPPORTED_PLATFORMS = "iphonesimulator iphoneos";
				SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
				SWIFT_VERSION = 5.0;
				TARGETED_DEVICE_FAMILY = "1,2";
			};
			name = Debug;
		};
		FBAF26C824FAA5B900B990CF /* Release */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;
				ALWAYS_SEARCH_USER_PATHS = NO;
				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
				CLANG_ANALYZER_NONNULL = YES;
				CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
				CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
				CLANG_CXX_LIBRARY = "libc++";
				CLANG_ENABLE_MODULES = YES;
				CLANG_ENABLE_OBJC_WEAK = YES;
				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
				CLANG_WARN_BOOL_CONVERSION = YES;
				CLANG_WARN_COMMA = YES;
				CLANG_WARN_CONSTANT_CONVERSION = YES;
				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
				CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
				CLANG_WARN_EMPTY_BODY = YES;
				CLANG_WARN_ENUM_CONVERSION = YES;
				CLANG_WARN_INFINITE_RECURSION = YES;
				CLANG_WARN_INT_CONVERSION = YES;
				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
				CLANG_WARN_STRICT_PROTOTYPES = YES;
				CLANG_WARN_SUSPICIOUS_MOVE = YES;
				CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
				CLANG_WARN_UNREACHABLE_CODE = YES;
				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
				CODE_SIGN_IDENTITY = "Apple Development";
				CODE_SIGN_STYLE = Automatic;
				COPY_PHASE_STRIP = NO;
				DEVELOPMENT_TEAM = "";
				ENABLE_NS_ASSERTIONS = NO;
				ENABLE_STRICT_OBJC_MSGSEND = YES;
				GCC_C_LANGUAGE_STANDARD = gnu11;
				GCC_NO_COMMON_BLOCKS = YES;
				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
				GCC_WARN_UNDECLARED_SELECTOR = YES;
				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
				GCC_WARN_UNUSED_FUNCTION = YES;
				GCC_WARN_UNUSED_VARIABLE = YES;
				INFOPLIST_FILE = Example/iOS/Info.plist;
				IPHONEOS_DEPLOYMENT_TARGET = 12.4;
				LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
				MTL_ENABLE_DEBUG_INFO = NO;
				MTL_FAST_MATH = YES;
				PRODUCT_BUNDLE_IDENTIFIER = "com.marcosgriselli.ViewAnimator-iOS";
				PRODUCT_NAME = "$(TARGET_NAME)";
				SDKROOT = iphoneos;
				SUPPORTED_PLATFORMS = "iphonesimulator iphoneos";
				SWIFT_VERSION = 5.0;
				TARGETED_DEVICE_FAMILY = "1,2";
				VALIDATE_PRODUCT = YES;
			};
			name = Release;
		};
		FBC9B9D624FAA9CA0048483A /* Debug */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;
				ALWAYS_SEARCH_USER_PATHS = NO;
				ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
				ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
				CLANG_ANALYZER_NONNULL = YES;
				CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
				CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
				CLANG_CXX_LIBRARY = "libc++";
				CLANG_ENABLE_MODULES = YES;
				CLANG_ENABLE_OBJC_WEAK = YES;
				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
				CLANG_WARN_BOOL_CONVERSION = YES;
				CLANG_WARN_COMMA = YES;
				CLANG_WARN_CONSTANT_CONVERSION = YES;
				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
				CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
				CLANG_WARN_EMPTY_BODY = YES;
				CLANG_WARN_ENUM_CONVERSION = YES;
				CLANG_WARN_INFINITE_RECURSION = YES;
				CLANG_WARN_INT_CONVERSION = YES;
				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
				CLANG_WARN_STRICT_PROTOTYPES = YES;
				CLANG_WARN_SUSPICIOUS_MOVE = YES;
				CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
				CLANG_WARN_UNREACHABLE_CODE = YES;
				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
				CODE_SIGN_STYLE = Automatic;
				DEVELOPMENT_TEAM = "";
				ENABLE_STRICT_OBJC_MSGSEND = YES;
				ENABLE_TESTABILITY = YES;
				GCC_C_LANGUAGE_STANDARD = gnu11;
				GCC_DYNAMIC_NO_PIC = NO;
				GCC_NO_COMMON_BLOCKS = YES;
				GCC_PREPROCESSOR_DEFINITIONS = (
					"DEBUG=1",
					"$(inherited)",
				);
				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
				GCC_WARN_UNDECLARED_SELECTOR = YES;
				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
				GCC_WARN_UNUSED_FUNCTION = YES;
				GCC_WARN_UNUSED_VARIABLE = YES;
				INFOPLIST_FILE = Example/tvOS/Info.plist;
				LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
				MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE;
				MTL_FAST_MATH = YES;
				PRODUCT_BUNDLE_IDENTIFIER = "com.marcosgriselli.ViewAnimator-tvOS";
				PRODUCT_NAME = "$(TARGET_NAME)";
				SDKROOT = appletvos;
				SUPPORTED_PLATFORMS = "appletvsimulator appletvos";
				SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
				SWIFT_VERSION = 5.0;
				TARGETED_DEVICE_FAMILY = 3;
				TVOS_DEPLOYMENT_TARGET = 12.4;
			};
			name = Debug;
		};
		FBC9B9D724FAA9CA0048483A /* Release */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;
				ALWAYS_SEARCH_USER_PATHS = NO;
				ASSETCATALOG_COMPILER_APPICON_NAME = "App Icon & Top Shelf Image";
				ASSETCATALOG_COMPILER_LAUNCHIMAGE_NAME = LaunchImage;
				CLANG_ANALYZER_NONNULL = YES;
				CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
				CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
				CLANG_CXX_LIBRARY = "libc++";
				CLANG_ENABLE_MODULES = YES;
				CLANG_ENABLE_OBJC_WEAK = YES;
				CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
				CLANG_WARN_BOOL_CONVERSION = YES;
				CLANG_WARN_COMMA = YES;
				CLANG_WARN_CONSTANT_CONVERSION = YES;
				CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
				CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
				CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
				CLANG_WARN_EMPTY_BODY = YES;
				CLANG_WARN_ENUM_CONVERSION = YES;
				CLANG_WARN_INFINITE_RECURSION = YES;
				CLANG_WARN_INT_CONVERSION = YES;
				CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
				CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
				CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
				CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
				CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
				CLANG_WARN_STRICT_PROTOTYPES = YES;
				CLANG_WARN_SUSPICIOUS_MOVE = YES;
				CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
				CLANG_WARN_UNREACHABLE_CODE = YES;
				CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
				CODE_SIGN_STYLE = Automatic;
				COPY_PHASE_STRIP = NO;
				DEVELOPMENT_TEAM = "";
				ENABLE_NS_ASSERTIONS = NO;
				ENABLE_STRICT_OBJC_MSGSEND = YES;
				GCC_C_LANGUAGE_STANDARD = gnu11;
				GCC_NO_COMMON_BLOCKS = YES;
				GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
				GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
				GCC_WARN_UNDECLARED_SELECTOR = YES;
				GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
				GCC_WARN_UNUSED_FUNCTION = YES;
				GCC_WARN_UNUSED_VARIABLE = YES;
				INFOPLIST_FILE = Example/tvOS/Info.plist;
				LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
				MTL_ENABLE_DEBUG_INFO = NO;
				MTL_FAST_MATH = YES;
				PRODUCT_BUNDLE_IDENTIFIER = "com.marcosgriselli.ViewAnimator-tvOS";
				PRODUCT_NAME = "$(TARGET_NAME)";
				SDKROOT = appletvos;
				SUPPORTED_PLATFORMS = "appletvsimulator appletvos";
				SWIFT_VERSION = 5.0;
				TARGETED_DEVICE_FAMILY = 3;
				TVOS_DEPLOYMENT_TARGET = 12.4;
				VALIDATE_PRODUCT = YES;
			};
			name = Release;
		};
		OBJ_3 /* Debug */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				CLANG_ENABLE_OBJC_ARC = YES;
				CODE_SIGN_IDENTITY = "Apple Development";
				COMBINE_HIDPI_IMAGES = YES;
				COPY_PHASE_STRIP = NO;
				DEBUG_INFORMATION_FORMAT = dwarf;
				DYLIB_INSTALL_NAME_BASE = "@rpath";
				ENABLE_NS_ASSERTIONS = YES;
				GCC_OPTIMIZATION_LEVEL = 0;
				GCC_PREPROCESSOR_DEFINITIONS = (
					"$(inherited)",
					"SWIFT_PACKAGE=1",
					"DEBUG=1",
				);
				MACOSX_DEPLOYMENT_TARGET = 10.10;
				ONLY_ACTIVE_ARCH = YES;
				OTHER_SWIFT_FLAGS = "-DXcode";
				PRODUCT_NAME = "$(TARGET_NAME)";
				SDKROOT = iphoneos;
				SUPPORTED_PLATFORMS = "iphoneos iphonesimulator appletvos appletvsimulator";
				SWIFT_ACTIVE_COMPILATION_CONDITIONS = "$(inherited) SWIFT_PACKAGE DEBUG";
				SWIFT_OPTIMIZATION_LEVEL = "-Onone";
				SWIFT_VERSION = 5.0;
				USE_HEADERMAP = NO;
			};
			name = Debug;
		};
		OBJ_33 /* Debug */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				CODE_SIGN_IDENTITY = "Apple Development";
				DEVELOPMENT_TEAM = "";
				ENABLE_TESTABILITY = YES;
				FRAMEWORK_SEARCH_PATHS = (
					"$(inherited)",
					"$(PLATFORM_DIR)/Developer/Library/Frameworks",
				);
				HEADER_SEARCH_PATHS = "$(inherited)";
				INFOPLIST_FILE = ViewAnimator.xcodeproj/ViewAnimator_Info.plist;
				IPHONEOS_DEPLOYMENT_TARGET = 9.0;
				LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx";
				MACOSX_DEPLOYMENT_TARGET = 10.10;
				OTHER_CFLAGS = "$(inherited)";
				OTHER_LDFLAGS = "$(inherited)";
				OTHER_SWIFT_FLAGS = "$(inherited)";
				PRODUCT_BUNDLE_IDENTIFIER = ViewAnimator;
				PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)";
				PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)";
				SKIP_INSTALL = YES;
				SWIFT_ACTIVE_COMPILATION_CONDITIONS = "$(inherited)";
				SWIFT_VERSION = 5.0;
				TARGET_NAME = ViewAnimator;
				TVOS_DEPLOYMENT_TARGET = 9.0;
				WATCHOS_DEPLOYMENT_TARGET = 2.0;
			};
			name = Debug;
		};
		OBJ_34 /* Release */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				CODE_SIGN_IDENTITY = "Apple Development";
				DEVELOPMENT_TEAM = "";
				ENABLE_TESTABILITY = YES;
				FRAMEWORK_SEARCH_PATHS = (
					"$(inherited)",
					"$(PLATFORM_DIR)/Developer/Library/Frameworks",
				);
				HEADER_SEARCH_PATHS = "$(inherited)";
				INFOPLIST_FILE = ViewAnimator.xcodeproj/ViewAnimator_Info.plist;
				IPHONEOS_DEPLOYMENT_TARGET = 9.0;
				LD_RUNPATH_SEARCH_PATHS = "$(inherited) $(TOOLCHAIN_DIR)/usr/lib/swift/macosx";
				MACOSX_DEPLOYMENT_TARGET = 10.10;
				OTHER_CFLAGS = "$(inherited)";
				OTHER_LDFLAGS = "$(inherited)";
				OTHER_SWIFT_FLAGS = "$(inherited)";
				PRODUCT_BUNDLE_IDENTIFIER = ViewAnimator;
				PRODUCT_MODULE_NAME = "$(TARGET_NAME:c99extidentifier)";
				PRODUCT_NAME = "$(TARGET_NAME:c99extidentifier)";
				SKIP_INSTALL = YES;
				SWIFT_ACTIVE_COMPILATION_CONDITIONS = "$(inherited)";
				SWIFT_VERSION = 5.0;
				TARGET_NAME = ViewAnimator;
				TVOS_DEPLOYMENT_TARGET = 9.0;
				WATCHOS_DEPLOYMENT_TARGET = 2.0;
			};
			name = Release;
		};
		OBJ_4 /* Release */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				CLANG_ENABLE_OBJC_ARC = YES;
				CODE_SIGN_IDENTITY = "Apple Development";
				COMBINE_HIDPI_IMAGES = YES;
				COPY_PHASE_STRIP = YES;
				DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
				DYLIB_INSTALL_NAME_BASE = "@rpath";
				GCC_OPTIMIZATION_LEVEL = s;
				GCC_PREPROCESSOR_DEFINITIONS = (
					"$(inherited)",
					"SWIFT_PACKAGE=1",
				);
				MACOSX_DEPLOYMENT_TARGET = 10.10;
				OTHER_SWIFT_FLAGS = "-DXcode";
				PRODUCT_NAME = "$(TARGET_NAME)";
				SDKROOT = iphoneos;
				SUPPORTED_PLATFORMS = "iphoneos iphonesimulator appletvos appletvsimulator";
				SWIFT_ACTIVE_COMPILATION_CONDITIONS = "$(inherited) SWIFT_PACKAGE";
				SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule";
				SWIFT_VERSION = 5.0;
				USE_HEADERMAP = NO;
			};
			name = Release;
		};
		OBJ_46 /* Debug */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				LD = /usr/bin/true;
				OTHER_SWIFT_FLAGS = "-swift-version 5 -I $(TOOLCHAIN_DIR)/usr/lib/swift/pm/4_2 -target x86_64-apple-macosx10.10 -sdk /Applications/Xcode_10_3.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.14.sdk";
				SWIFT_VERSION = 5.0;
			};
			name = Debug;
		};
		OBJ_47 /* Release */ = {
			isa = XCBuildConfiguration;
			buildSettings = {
				LD = /usr/bin/true;
				OTHER_SWIFT_FLAGS = "-swift-version 5 -I $(TOOLCHAIN_DIR)/usr/lib/swift/pm/4_2 -target x86_64-apple-macosx10.10 -sdk /Applications/Xcode_10_3.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.14.sdk";
				SWIFT_VERSION = 5.0;
			};
			name = Release;
		};
/* End XCBuildConfiguration section */

/* Begin XCConfigurationList section */
		FB54AC2024FAA505003A00A4 /* Build configuration list for PBXNativeTarget "ViewAnimatorTests" */ = {
			isa = XCConfigurationList;
			buildConfigurations = (
				FB54AC2124FAA505003A00A4 /* Debug */,
				FB54AC2224FAA505003A00A4 /* Release */,
			);
			defaultConfigurationIsVisible = 0;
			defaultConfigurationName = Release;
		};
		FBAF26C924FAA5B900B990CF /* Build configuration list for PBXNativeTarget "ViewAnimator-iOS" */ = {
			isa = XCConfigurationList;
			buildConfigurations = (
				FBAF26C724FAA5B900B990CF /* Debug */,
				FBAF26C824FAA5B900B990CF /* Release */,
			);
			defaultConfigurationIsVisible = 0;
			defaultConfigurationName = Release;
		};
		FBC9B9D524FAA9CA0048483A /* Build configuration list for PBXNativeTarget "ViewAnimator-tvOS" */ = {
			isa = XCConfigurationList;
			buildConfigurations = (
				FBC9B9D624FAA9CA0048483A /* Debug */,
				FBC9B9D724FAA9CA0048483A /* Release */,
			);
			defaultConfigurationIsVisible = 0;
			defaultConfigurationName = Release;
		};
		OBJ_2 /* Build configuration list for PBXProject "ViewAnimator" */ = {
			isa = XCConfigurationList;
			buildConfigurations = (
				OBJ_3 /* Debug */,
				OBJ_4 /* Release */,
			);
			defaultConfigurationIsVisible = 0;
			defaultConfigurationName = Release;
		};
		OBJ_32 /* Build configuration list for PBXNativeTarget "ViewAnimator" */ = {
			isa = XCConfigurationList;
			buildConfigurations = (
				OBJ_33 /* Debug */,
				OBJ_34 /* Release */,
			);
			defaultConfigurationIsVisible = 0;
			defaultConfigurationName = Release;
		};
		OBJ_45 /* Build configuration list for PBXNativeTarget "ViewAnimatorPackageDescription" */ = {
			isa = XCConfigurationList;
			buildConfigurations = (
				OBJ_46 /* Debug */,
				OBJ_47 /* Release */,
			);
			defaultConfigurationIsVisible = 0;
			defaultConfigurationName = Release;
		};
/* End XCConfigurationList section */
	};
	rootObject = OBJ_1 /* Project object */;
}


================================================
FILE: ViewAnimator.xcodeproj/project.xcworkspace/contents.xcworkspacedata
================================================
<?xml version="1.0" encoding="UTF-8"?>
<Workspace
   version = "1.0">
   <FileRef
      location = "self:">
   </FileRef>
</Workspace>

================================================
FILE: ViewAnimator.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
================================================
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
	<key>IDEDidComputeMac32BitWarning</key>
	<true/>
</dict>
</plist>


================================================
FILE: ViewAnimator.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings
================================================
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>IDEWorkspaceSharedSettings_AutocreateContextsIfNeeded</key>
    <false/>
</dict>
</plist>

================================================
FILE: ViewAnimator.xcodeproj/xcshareddata/xcschemes/ViewAnimator-Package.xcscheme
================================================
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
   LastUpgradeVersion = "9999"
   version = "1.3">
   <BuildAction
      parallelizeBuildables = "YES"
      buildImplicitDependencies = "YES">
      <BuildActionEntries>
         <BuildActionEntry
            buildForTesting = "YES"
            buildForRunning = "YES"
            buildForProfiling = "YES"
            buildForArchiving = "YES"
            buildForAnalyzing = "YES">
            <BuildableReference
               BuildableIdentifier = "primary"
               BlueprintIdentifier = "ViewAnimator::ViewAnimator"
               BuildableName = "ViewAnimator.framework"
               BlueprintName = "ViewAnimator"
               ReferencedContainer = "container:ViewAnimator.xcodeproj">
            </BuildableReference>
         </BuildActionEntry>
      </BuildActionEntries>
   </BuildAction>
   <TestAction
      buildConfiguration = "Debug"
      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
      shouldUseLaunchSchemeArgsEnv = "YES">
      <Testables>
      </Testables>
      <AdditionalOptions>
      </AdditionalOptions>
   </TestAction>
   <LaunchAction
      buildConfiguration = "Debug"
      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
      launchStyle = "0"
      useCustomWorkingDirectory = "NO"
      ignoresPersistentStateOnLaunch = "NO"
      debugDocumentVersioning = "YES"
      debugServiceExtension = "internal"
      allowLocationSimulation = "YES">
      <MacroExpansion>
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "ViewAnimator::ViewAnimator"
            BuildableName = "ViewAnimator.framework"
            BlueprintName = "ViewAnimator"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </MacroExpansion>
      <AdditionalOptions>
      </AdditionalOptions>
   </LaunchAction>
   <ProfileAction
      buildConfiguration = "Release"
      shouldUseLaunchSchemeArgsEnv = "YES"
      savedToolIdentifier = ""
      useCustomWorkingDirectory = "NO"
      debugDocumentVersioning = "YES">
   </ProfileAction>
   <AnalyzeAction
      buildConfiguration = "Debug">
   </AnalyzeAction>
   <ArchiveAction
      buildConfiguration = "Release"
      revealArchiveInOrganizer = "YES">
   </ArchiveAction>
</Scheme>


================================================
FILE: ViewAnimator.xcodeproj/xcshareddata/xcschemes/ViewAnimator-iOS.xcscheme
================================================
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
   LastUpgradeVersion = "1030"
   version = "1.3">
   <BuildAction
      parallelizeBuildables = "YES"
      buildImplicitDependencies = "YES">
      <BuildActionEntries>
         <BuildActionEntry
            buildForTesting = "YES"
            buildForRunning = "YES"
            buildForProfiling = "YES"
            buildForArchiving = "YES"
            buildForAnalyzing = "YES">
            <BuildableReference
               BuildableIdentifier = "primary"
               BlueprintIdentifier = "FBAF26B724FAA5B700B990CF"
               BuildableName = "ViewAnimator-iOS.app"
               BlueprintName = "ViewAnimator-iOS"
               ReferencedContainer = "container:ViewAnimator.xcodeproj">
            </BuildableReference>
         </BuildActionEntry>
      </BuildActionEntries>
   </BuildAction>
   <TestAction
      buildConfiguration = "Debug"
      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
      shouldUseLaunchSchemeArgsEnv = "YES">
      <Testables>
      </Testables>
      <MacroExpansion>
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "FBAF26B724FAA5B700B990CF"
            BuildableName = "ViewAnimator-iOS.app"
            BlueprintName = "ViewAnimator-iOS"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </MacroExpansion>
      <AdditionalOptions>
      </AdditionalOptions>
   </TestAction>
   <LaunchAction
      buildConfiguration = "Debug"
      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
      launchStyle = "0"
      useCustomWorkingDirectory = "NO"
      ignoresPersistentStateOnLaunch = "NO"
      debugDocumentVersioning = "YES"
      debugServiceExtension = "internal"
      allowLocationSimulation = "YES">
      <BuildableProductRunnable
         runnableDebuggingMode = "0">
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "FBAF26B724FAA5B700B990CF"
            BuildableName = "ViewAnimator-iOS.app"
            BlueprintName = "ViewAnimator-iOS"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </BuildableProductRunnable>
      <AdditionalOptions>
      </AdditionalOptions>
   </LaunchAction>
   <ProfileAction
      buildConfiguration = "Release"
      shouldUseLaunchSchemeArgsEnv = "YES"
      savedToolIdentifier = ""
      useCustomWorkingDirectory = "NO"
      debugDocumentVersioning = "YES">
      <BuildableProductRunnable
         runnableDebuggingMode = "0">
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "FBAF26B724FAA5B700B990CF"
            BuildableName = "ViewAnimator-iOS.app"
            BlueprintName = "ViewAnimator-iOS"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </BuildableProductRunnable>
   </ProfileAction>
   <AnalyzeAction
      buildConfiguration = "Debug">
   </AnalyzeAction>
   <ArchiveAction
      buildConfiguration = "Release"
      revealArchiveInOrganizer = "YES">
   </ArchiveAction>
</Scheme>


================================================
FILE: ViewAnimator.xcodeproj/xcshareddata/xcschemes/ViewAnimator-tvOS.xcscheme
================================================
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
   LastUpgradeVersion = "1030"
   version = "1.3">
   <BuildAction
      parallelizeBuildables = "YES"
      buildImplicitDependencies = "YES">
      <BuildActionEntries>
         <BuildActionEntry
            buildForTesting = "YES"
            buildForRunning = "YES"
            buildForProfiling = "YES"
            buildForArchiving = "YES"
            buildForAnalyzing = "YES">
            <BuildableReference
               BuildableIdentifier = "primary"
               BlueprintIdentifier = "FBC9B9C824FAA9C90048483A"
               BuildableName = "ViewAnimator-tvOS.app"
               BlueprintName = "ViewAnimator-tvOS"
               ReferencedContainer = "container:ViewAnimator.xcodeproj">
            </BuildableReference>
         </BuildActionEntry>
      </BuildActionEntries>
   </BuildAction>
   <TestAction
      buildConfiguration = "Debug"
      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
      shouldUseLaunchSchemeArgsEnv = "YES">
      <Testables>
      </Testables>
      <MacroExpansion>
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "FBC9B9C824FAA9C90048483A"
            BuildableName = "ViewAnimator-tvOS.app"
            BlueprintName = "ViewAnimator-tvOS"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </MacroExpansion>
      <AdditionalOptions>
      </AdditionalOptions>
   </TestAction>
   <LaunchAction
      buildConfiguration = "Debug"
      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
      launchStyle = "0"
      useCustomWorkingDirectory = "NO"
      ignoresPersistentStateOnLaunch = "NO"
      debugDocumentVersioning = "YES"
      debugServiceExtension = "internal"
      allowLocationSimulation = "YES">
      <BuildableProductRunnable
         runnableDebuggingMode = "0">
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "FBC9B9C824FAA9C90048483A"
            BuildableName = "ViewAnimator-tvOS.app"
            BlueprintName = "ViewAnimator-tvOS"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </BuildableProductRunnable>
      <AdditionalOptions>
      </AdditionalOptions>
   </LaunchAction>
   <ProfileAction
      buildConfiguration = "Release"
      shouldUseLaunchSchemeArgsEnv = "YES"
      savedToolIdentifier = ""
      useCustomWorkingDirectory = "NO"
      debugDocumentVersioning = "YES">
      <BuildableProductRunnable
         runnableDebuggingMode = "0">
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "FBC9B9C824FAA9C90048483A"
            BuildableName = "ViewAnimator-tvOS.app"
            BlueprintName = "ViewAnimator-tvOS"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </BuildableProductRunnable>
   </ProfileAction>
   <AnalyzeAction
      buildConfiguration = "Debug">
   </AnalyzeAction>
   <ArchiveAction
      buildConfiguration = "Release"
      revealArchiveInOrganizer = "YES">
   </ArchiveAction>
</Scheme>


================================================
FILE: ViewAnimator.xcodeproj/xcshareddata/xcschemes/ViewAnimator.xcscheme
================================================
<?xml version="1.0" encoding="UTF-8"?>
<Scheme
   LastUpgradeVersion = "1030"
   version = "1.3">
   <BuildAction
      parallelizeBuildables = "YES"
      buildImplicitDependencies = "YES">
      <BuildActionEntries>
         <BuildActionEntry
            buildForTesting = "YES"
            buildForRunning = "YES"
            buildForProfiling = "YES"
            buildForArchiving = "YES"
            buildForAnalyzing = "YES">
            <BuildableReference
               BuildableIdentifier = "primary"
               BlueprintIdentifier = "ViewAnimator::ViewAnimator"
               BuildableName = "ViewAnimator.framework"
               BlueprintName = "ViewAnimator"
               ReferencedContainer = "container:ViewAnimator.xcodeproj">
            </BuildableReference>
         </BuildActionEntry>
      </BuildActionEntries>
   </BuildAction>
   <TestAction
      buildConfiguration = "Debug"
      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
      shouldUseLaunchSchemeArgsEnv = "YES">
      <Testables>
         <TestableReference
            skipped = "NO">
            <BuildableReference
               BuildableIdentifier = "primary"
               BlueprintIdentifier = "FB54AC1A24FAA505003A00A4"
               BuildableName = "ViewAnimatorTests.xctest"
               BlueprintName = "ViewAnimatorTests"
               ReferencedContainer = "container:ViewAnimator.xcodeproj">
            </BuildableReference>
         </TestableReference>
      </Testables>
      <MacroExpansion>
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "ViewAnimator::ViewAnimator"
            BuildableName = "ViewAnimator.framework"
            BlueprintName = "ViewAnimator"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </MacroExpansion>
      <AdditionalOptions>
      </AdditionalOptions>
   </TestAction>
   <LaunchAction
      buildConfiguration = "Debug"
      selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
      selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
      launchStyle = "0"
      useCustomWorkingDirectory = "NO"
      ignoresPersistentStateOnLaunch = "NO"
      debugDocumentVersioning = "YES"
      debugServiceExtension = "internal"
      allowLocationSimulation = "YES">
      <MacroExpansion>
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "ViewAnimator::ViewAnimator"
            BuildableName = "ViewAnimator.framework"
            BlueprintName = "ViewAnimator"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </MacroExpansion>
      <AdditionalOptions>
      </AdditionalOptions>
   </LaunchAction>
   <ProfileAction
      buildConfiguration = "Release"
      shouldUseLaunchSchemeArgsEnv = "YES"
      savedToolIdentifier = ""
      useCustomWorkingDirectory = "NO"
      debugDocumentVersioning = "YES">
      <MacroExpansion>
         <BuildableReference
            BuildableIdentifier = "primary"
            BlueprintIdentifier = "ViewAnimator::ViewAnimator"
            BuildableName = "ViewAnimator.framework"
            BlueprintName = "ViewAnimator"
            ReferencedContainer = "container:ViewAnimator.xcodeproj">
         </BuildableReference>
      </MacroExpansion>
   </ProfileAction>
   <AnalyzeAction
      buildConfiguration = "Debug">
   </AnalyzeAction>
   <ArchiveAction
      buildConfiguration = "Release"
      revealArchiveInOrganizer = "YES">
   </ArchiveAction>
</Scheme>


================================================
FILE: ViewAnimatorTests/Info.plist
================================================
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
	<key>CFBundleDevelopmentRegion</key>
	<string>$(DEVELOPMENT_LANGUAGE)</string>
	<key>CFBundleExecutable</key>
	<string>$(EXECUTABLE_NAME)</string>
	<key>CFBundleIdentifier</key>
	<string>$(PRODUCT_BUNDLE_IDENTIFIER)</string>
	<key>CFBundleInfoDictionaryVersion</key>
	<string>6.0</string>
	<key>CFBundleName</key>
	<string>$(PRODUCT_NAME)</string>
	<key>CFBundlePackageType</key>
	<string>BNDL</string>
	<key>CFBundleShortVersionString</key>
	<string>1.0</string>
	<key>CFBundleVersion</key>
	<string>1</string>
</dict>
</plist>


================================================
FILE: ViewAnimatorTests/Tests.swift
================================================
import UIKit
import XCTest
import ViewAnimator

class Tests: XCTestCase {
    
    override func setUp() {
        super.setUp()
        // Put setup code here. This method is called before the invocation of each test method in the class.
    }
    
    override func tearDown() {
        // Put teardown code here. This method is called after the invocation of each test method in the class.
        super.tearDown()
    }
    
    func testPreservesTransform() {
        let view = UIView()
        let preTransform = CGAffineTransform(rotationAngle: 3.14)
        view.transform = preTransform
        
        let zoom = AnimationType.zoom(scale: 2.5)
        let translate = AnimationType.vector(CGVector(dx: 0, dy: 50))
        
        let animationCompleteExpectation = expectation(description: "Animate with multiple transforms")
        
        view.animate(animations: [zoom, translate]) {
            animationCompleteExpectation.fulfill()
            XCTAssert(view.transform == preTransform)
        }
        
        waitForExpectations(timeout: 1.0, handler: nil)
    }
    
    func testTransformOnReverse() {
        let view = UIView()
        
        let rotate = AnimationType.rotate(angle: CGFloat.pi)
        let translate = AnimationType.vector(CGVector(dx: 20, dy: 0))
        let animations = [rotate, translate]
        
        var expectedTransform = view.transform
        animations.forEach { expectedTransform = expectedTransform.concatenating($0.initialTransform) }
        
        let animationCompleteExpectation = expectation(description: "Animate with multiple transforms")
        
        view.animate(animations: animations, reversed: true) {
            animationCompleteExpectation.fulfill()
            XCTAssert(view.transform == expectedTransform)
        }
        
        waitForExpectations(timeout: 1.0, handler: nil)
    }
    
}



================================================
FILE: fastlane/Appfile
================================================
# app_identifier "[[APP_IDENTIFIER]]" # The bundle identifier of your app
# apple_id "[[APPLE_ID]]" # Your Apple email address


# For more information about the Appfile, see:
#     https://docs.fastlane.tools/advanced/#appfile


================================================
FILE: fastlane/Fastfile
================================================
default_platform(:ios)

platform :ios do

  before_all do 
    @podspec_name = "ViewAnimator.podspec"
  end

  lane :test do
    scan(scheme: "ViewAnimator", device: "iPhone 8")
  end

  desc "Release a new version with a patch bump_type"
  lane :patch do
    release("patch")
  end

  desc "Release a new version with a minor bump_type"
  lane :minor do 
    release("minor")
  end 

  desc "Release a new version with a major bump_type"
  lane :major do 
    release("major")
  end 

  def release(type)
    pod_lib_lint
    version = version_bump_podspec(path: @podspec_name, 
                                   bump_type: type)
    git_add(path: @podspec_name)
    git_commit(path: [@podspec_name],
               message: "#{version} release")
    add_git_tag(tag: "#{version}")
    push_to_git_remote
    pod_push
  end

  lane :release_current do
    version = version_get_podspec(path: @podspec_name)
    if git_tag_exists(tag: version)
      UI.user_error!("The tag #{version} already exists on the repo. To release a new version of the library bump the version on #{@podspec_name}")
    end
    pod_lib_lint
    add_git_tag(tag: "#{version}")
    push_git_tags
    pod_push
  end
end
Download .txt
gitextract_e466d0tl/

├── .gitattributes
├── .github/
│   ├── CODE_OF_CONDUCT.md
│   └── ISSUE_TEMPLATE.md
├── .gitignore
├── Example/
│   ├── iOS/
│   │   ├── AppDelegate.swift
│   │   ├── Assets.xcassets/
│   │   │   ├── 0.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── 1.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── 2.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── 3.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── 4.imageset/
│   │   │   │   └── Contents.json
│   │   │   ├── AppIcon.appiconset/
│   │   │   │   └── Contents.json
│   │   │   ├── Contents.json
│   │   │   ├── background.imageset/
│   │   │   │   └── Contents.json
│   │   │   └── icon.imageset/
│   │   │       └── Contents.json
│   │   ├── Base.lproj/
│   │   │   ├── LaunchScreen.storyboard
│   │   │   └── Main.storyboard
│   │   ├── Info.plist
│   │   ├── ViewControllers/
│   │   │   ├── CollectionViewController.swift
│   │   │   ├── TableViewController.swift
│   │   │   └── ViewController.swift
│   │   └── Views/
│   │       ├── Cells/
│   │       │   ├── CollectionViewCell.swift
│   │       │   └── TableViewCell.swift
│   │       └── Designable.swift
│   └── tvOS/
│       ├── AppDelegate.swift
│       ├── Assets.xcassets/
│       │   ├── App Icon & Top Shelf Image.brandassets/
│       │   │   ├── App Icon - App Store.imagestack/
│       │   │   │   ├── Contents.json
│       │   │   │   ├── tv-icon-back.imagestacklayer/
│       │   │   │   │   ├── Content.imageset/
│       │   │   │   │   │   └── Contents.json
│       │   │   │   │   └── Contents.json
│       │   │   │   └── tv-icon-front.imagestacklayer/
│       │   │   │       ├── Content.imageset/
│       │   │   │       │   └── Contents.json
│       │   │   │       └── Contents.json
│       │   │   ├── App Icon.imagestack/
│       │   │   │   ├── Contents.json
│       │   │   │   ├── tv-icon-back.imagestacklayer/
│       │   │   │   │   ├── Content.imageset/
│       │   │   │   │   │   └── Contents.json
│       │   │   │   │   └── Contents.json
│       │   │   │   └── tv-icon-front.imagestacklayer/
│       │   │   │       ├── Content.imageset/
│       │   │   │       │   └── Contents.json
│       │   │   │       └── Contents.json
│       │   │   ├── Contents.json
│       │   │   ├── Top Shelf Image Wide.imageset/
│       │   │   │   └── Contents.json
│       │   │   └── Top Shelf Image.imageset/
│       │   │       └── Contents.json
│       │   ├── Contents.json
│       │   ├── Launch Image.launchimage/
│       │   │   └── Contents.json
│       │   ├── detail_1.imageset/
│       │   │   └── Contents.json
│       │   ├── detail_2.imageset/
│       │   │   └── Contents.json
│       │   ├── detail_3.imageset/
│       │   │   └── Contents.json
│       │   ├── detail_4.imageset/
│       │   │   └── Contents.json
│       │   ├── detail_5.imageset/
│       │   │   └── Contents.json
│       │   └── detail_6.imageset/
│       │       └── Contents.json
│       ├── Base.lproj/
│       │   └── Main.storyboard
│       ├── Cells/
│       │   └── CollectionViewCell.swift
│       ├── CollectionViewController.swift
│       └── Info.plist
├── Gemfile
├── LICENSE
├── Package.swift
├── README.md
├── Sources/
│   ├── .gitkeep
│   ├── Extensions/
│   │   ├── UICollectionView + ViewAnimator.swift
│   │   └── UITableView + ViewAnimator.swift
│   ├── Models/
│   │   ├── AnimationType.swift
│   │   └── Directions.swift
│   ├── Protocols/
│   │   └── Animation.swift
│   ├── ViewAnimator.swift
│   └── ViewAnimatorConfig.swift
├── ViewAnimator.podspec
├── ViewAnimator.xcodeproj/
│   ├── ViewAnimator_Info.plist
│   ├── project.pbxproj
│   ├── project.xcworkspace/
│   │   ├── contents.xcworkspacedata
│   │   └── xcshareddata/
│   │       ├── IDEWorkspaceChecks.plist
│   │       └── WorkspaceSettings.xcsettings
│   └── xcshareddata/
│       └── xcschemes/
│           ├── ViewAnimator-Package.xcscheme
│           ├── ViewAnimator-iOS.xcscheme
│           ├── ViewAnimator-tvOS.xcscheme
│           └── ViewAnimator.xcscheme
├── ViewAnimatorTests/
│   ├── Info.plist
│   └── Tests.swift
└── fastlane/
    ├── Appfile
    └── Fastfile
Condensed preview — 75 files, each showing path, character count, and a content snippet. Download the .json file or copy for the full structured content (196K chars).
[
  {
    "path": ".gitattributes",
    "chars": 114,
    "preview": "*.sh linguist-language=Swift\n*.m linguist-language=Swift\n*.h linguist-language=Swift\n*.rb linguist-language=Swift\n"
  },
  {
    "path": ".github/CODE_OF_CONDUCT.md",
    "chars": 3221,
    "preview": "# Contributor Covenant Code of Conduct\n\n## Our Pledge\n\nIn the interest of fostering an open and welcoming environment, w"
  },
  {
    "path": ".github/ISSUE_TEMPLATE.md",
    "chars": 156,
    "preview": "## Expected Behavior\n\n\n## Actual Behavior\n\n\n## Steps to Reproduce the Problem\n\n  1.\n  1.\n  1.\n\n## Specifications\n\n  - Ve"
  },
  {
    "path": ".gitignore",
    "chars": 820,
    "preview": "# OS X\n.DS_Store\n\n# Xcode\nbuild/\n*.pbxuser\n!default.pbxuser\n*.mode1v3\n!default.mode1v3\n*.mode2v3\n!default.mode2v3\n*.pers"
  },
  {
    "path": "Example/iOS/AppDelegate.swift",
    "chars": 2132,
    "preview": "//\n//  AppDelegate.swift\n//  ViewAnimator-iOS\n//\n//  Created by Marcos Griselli on 29/08/2020.\n//\n\nimport UIKit\n\n@UIAppl"
  },
  {
    "path": "Example/iOS/Assets.xcassets/0.imageset/Contents.json",
    "chars": 360,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"5.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      "
  },
  {
    "path": "Example/iOS/Assets.xcassets/1.imageset/Contents.json",
    "chars": 360,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"1.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      "
  },
  {
    "path": "Example/iOS/Assets.xcassets/2.imageset/Contents.json",
    "chars": 360,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"2.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      "
  },
  {
    "path": "Example/iOS/Assets.xcassets/3.imageset/Contents.json",
    "chars": 360,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"3.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      "
  },
  {
    "path": "Example/iOS/Assets.xcassets/4.imageset/Contents.json",
    "chars": 360,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"4.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n      "
  },
  {
    "path": "Example/iOS/Assets.xcassets/AppIcon.appiconset/Contents.json",
    "chars": 3143,
    "preview": "{\n  \"info\" : {\n    \"version\" : 1,\n    \"author\" : \"xcode\"\n  },\n  \"images\" : [\n    {\n      \"filename\" : \"Icon-40.png\",\n   "
  },
  {
    "path": "Example/iOS/Assets.xcassets/Contents.json",
    "chars": 62,
    "preview": "{\n  \"info\" : {\n    \"version\" : 1,\n    \"author\" : \"xcode\"\n  }\n}"
  },
  {
    "path": "Example/iOS/Assets.xcassets/background.imageset/Contents.json",
    "chars": 159,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"background.pdf\"\n    }\n  ],\n  \"info\" : {\n    \"ver"
  },
  {
    "path": "Example/iOS/Assets.xcassets/icon.imageset/Contents.json",
    "chars": 369,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"icon.png\",\n      \"scale\" : \"1x\"\n    },\n    {\n   "
  },
  {
    "path": "Example/iOS/Base.lproj/LaunchScreen.storyboard",
    "chars": 1658,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?>\n<document type=\"com.apple.InterfaceBuilder3.CocoaTouch.Storyboard"
  },
  {
    "path": "Example/iOS/Base.lproj/Main.storyboard",
    "chars": 32265,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<document type=\"com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB\" version=\"3"
  },
  {
    "path": "Example/iOS/Info.plist",
    "chars": 1463,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/P"
  },
  {
    "path": "Example/iOS/ViewControllers/CollectionViewController.swift",
    "chars": 3671,
    "preview": "//\n//  CollectionViewController.swift\n//  ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 04/02/2018.\n//  Copy"
  },
  {
    "path": "Example/iOS/ViewControllers/TableViewController.swift",
    "chars": 2079,
    "preview": "//\n//  TableViewController.swift\n//  ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 1/14/18.\n//  Copyright © "
  },
  {
    "path": "Example/iOS/ViewControllers/ViewController.swift",
    "chars": 2530,
    "preview": "//\n//  ViewController.swift\n//  ViewAnimator\n//\n//  Created by marcosgriselli@gmail.com on 10/05/2017.\n//  Copyright (c)"
  },
  {
    "path": "Example/iOS/Views/Cells/CollectionViewCell.swift",
    "chars": 637,
    "preview": "//\n//  CollectionViewCell.swift\n//  ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 10/9/17.\n//  Copyright © 2"
  },
  {
    "path": "Example/iOS/Views/Cells/TableViewCell.swift",
    "chars": 295,
    "preview": "//\n//  TableViewCell.swift\n//  ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 10/9/17.\n//  Copyright © 2017 C"
  },
  {
    "path": "Example/iOS/Views/Designable.swift",
    "chars": 2093,
    "preview": "//\n//  Designable.swift\n//  ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 10/9/17.\n//  Copyright © 2017 Coco"
  },
  {
    "path": "Example/tvOS/AppDelegate.swift",
    "chars": 2181,
    "preview": "//\n//  AppDelegate.swift\n//  ViewAnimatorTVOS\n//\n//  Created by Marcos Griselli on 28/04/2018.\n//  Copyright © 2018 Coco"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/Contents.json",
    "chars": 302,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"layers\" : [\n    {\n      \"filename\" : \"tv-icon-front.ima"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/tv-icon-back.imagestacklayer/Content.imageset/Contents.json",
    "chars": 232,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"images\" : [\n    {\n      \"idiom\" : \"tv\",\n      \"filename"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/tv-icon-back.imagestacklayer/Contents.json",
    "chars": 219,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"properties\" : {\n    \"frame-size\" : {\n      \"height\" : 7"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/tv-icon-front.imagestacklayer/Content.imageset/Contents.json",
    "chars": 233,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"images\" : [\n    {\n      \"idiom\" : \"tv\",\n      \"filename"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon - App Store.imagestack/tv-icon-front.imagestacklayer/Contents.json",
    "chars": 219,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"properties\" : {\n    \"frame-size\" : {\n      \"height\" : 7"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/Contents.json",
    "chars": 301,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"layers\" : [\n    {\n      \"filename\" : \"tv-icon-front.ima"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/tv-icon-back.imagestacklayer/Content.imageset/Contents.json",
    "chars": 274,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"images\" : [\n    {\n      \"idiom\" : \"tv\",\n      \"filename"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/tv-icon-back.imagestacklayer/Contents.json",
    "chars": 218,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"properties\" : {\n    \"frame-size\" : {\n      \"height\" : 2"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/tv-icon-front.imagestacklayer/Content.imageset/Contents.json",
    "chars": 276,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"images\" : [\n    {\n      \"idiom\" : \"tv\",\n      \"filename"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/App Icon.imagestack/tv-icon-front.imagestacklayer/Contents.json",
    "chars": 218,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"properties\" : {\n    \"frame-size\" : {\n      \"height\" : 2"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/Contents.json",
    "chars": 662,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"assets\" : [\n    {\n      \"filename\" : \"App Icon - App St"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/Top Shelf Image Wide.imageset/Contents.json",
    "chars": 193,
    "preview": "{\n  \"info\" : {\n    \"version\" : 1,\n    \"author\" : \"xcode\"\n  },\n  \"images\" : [\n    {\n      \"idiom\" : \"tv\",\n      \"scale\" :"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/App Icon & Top Shelf Image.brandassets/Top Shelf Image.imageset/Contents.json",
    "chars": 193,
    "preview": "{\n  \"info\" : {\n    \"version\" : 1,\n    \"author\" : \"xcode\"\n  },\n  \"images\" : [\n    {\n      \"idiom\" : \"tv\",\n      \"scale\" :"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/Contents.json",
    "chars": 62,
    "preview": "{\n  \"info\" : {\n    \"version\" : 1,\n    \"author\" : \"xcode\"\n  }\n}"
  },
  {
    "path": "Example/tvOS/Assets.xcassets/Launch Image.launchimage/Contents.json",
    "chars": 495,
    "preview": "{\n  \"info\" : {\n    \"author\" : \"xcode\",\n    \"version\" : 1\n  },\n  \"images\" : [\n    {\n      \"extent\" : \"full-screen\",\n     "
  },
  {
    "path": "Example/tvOS/Assets.xcassets/detail_1.imageset/Contents.json",
    "chars": 346,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"detail_1@2x.png\",\n      \"scale\" : \"1x\"\n    },\n  "
  },
  {
    "path": "Example/tvOS/Assets.xcassets/detail_2.imageset/Contents.json",
    "chars": 346,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"detail_2@2x.png\",\n      \"scale\" : \"1x\"\n    },\n  "
  },
  {
    "path": "Example/tvOS/Assets.xcassets/detail_3.imageset/Contents.json",
    "chars": 346,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"detail_3@2x.png\",\n      \"scale\" : \"1x\"\n    },\n  "
  },
  {
    "path": "Example/tvOS/Assets.xcassets/detail_4.imageset/Contents.json",
    "chars": 346,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"detail_4@2x.png\",\n      \"scale\" : \"1x\"\n    },\n  "
  },
  {
    "path": "Example/tvOS/Assets.xcassets/detail_5.imageset/Contents.json",
    "chars": 346,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"detail_5@2x.png\",\n      \"scale\" : \"1x\"\n    },\n  "
  },
  {
    "path": "Example/tvOS/Assets.xcassets/detail_6.imageset/Contents.json",
    "chars": 346,
    "preview": "{\n  \"images\" : [\n    {\n      \"idiom\" : \"universal\",\n      \"filename\" : \"detail_6@2x.png\",\n      \"scale\" : \"1x\"\n    },\n  "
  },
  {
    "path": "Example/tvOS/Base.lproj/Main.storyboard",
    "chars": 10180,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<document type=\"com.apple.InterfaceBuilder.AppleTV.Storyboard\" version=\"3.0\" tool"
  },
  {
    "path": "Example/tvOS/Cells/CollectionViewCell.swift",
    "chars": 271,
    "preview": "//\n//  CollectionViewCell.swift\n//  ViewAnimatorTVOS\n//\n//  Created by Marcos Griselli on 28/04/2018.\n//  Copyright © 20"
  },
  {
    "path": "Example/tvOS/CollectionViewController.swift",
    "chars": 2430,
    "preview": "//\n//  ViewController.swift\n//  ViewAnimatorTVOS\n//\n//  Created by Marcos Griselli on 28/04/2018.\n//  Copyright © 2018 C"
  },
  {
    "path": "Example/tvOS/Info.plist",
    "chars": 943,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/P"
  },
  {
    "path": "Gemfile",
    "chars": 62,
    "preview": "source \"https://rubygems.org\"\n\ngem 'fastlane'\ngem 'cocoapods'\n"
  },
  {
    "path": "LICENSE",
    "chars": 1095,
    "preview": "Copyright (c) 2018 marcosgriselli@gmail.com <marcosgriselli@gmail.com>\n\nPermission is hereby granted, free of charge, to"
  },
  {
    "path": "Package.swift",
    "chars": 554,
    "preview": "// swift-tools-version:5.0\nimport PackageDescription\n\nlet package = Package(\n    name: \"ViewAnimator\",\n    platforms: [."
  },
  {
    "path": "README.md",
    "chars": 9541,
    "preview": "<p align=\"center\">\n<img src=\"./Resources/banner_new.svg\"/>\n</p>\n\n<p align=\"center\">\n    <img src=\"https://img.shields.io"
  },
  {
    "path": "Sources/.gitkeep",
    "chars": 0,
    "preview": ""
  },
  {
    "path": "Sources/Extensions/UICollectionView + ViewAnimator.swift",
    "chars": 754,
    "preview": "//\n//  UICollectionView + ViewAnimator.swift\n//  ViewAnimator\n//\n//  Created by Marcos Griselli on 15/04/2018.\n//\n\nimpor"
  },
  {
    "path": "Sources/Extensions/UITableView + ViewAnimator.swift",
    "chars": 523,
    "preview": "//\n//  UITableView + ViewAnimator.swift\n//  ViewAnimator\n//\n//  Created by Marcos Griselli on 15/04/2018.\n//\n\nimport Fou"
  },
  {
    "path": "Sources/Models/AnimationType.swift",
    "chars": 1948,
    "preview": "//\n//  AnimationType.swift\n//  Pods-ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 10/5/17.\n//\n\nimport UIKit\n"
  },
  {
    "path": "Sources/Models/Directions.swift",
    "chars": 844,
    "preview": "//\n//  Direction.swift\n//  Pods-ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 10/5/17.\n//\nimport UIKit\n\n/// "
  },
  {
    "path": "Sources/Protocols/Animation.swift",
    "chars": 369,
    "preview": "//\n//  Animation.swift\n//  Pods-ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 10/16/17.\n//\n\nimport UIKit\n\n//"
  },
  {
    "path": "Sources/ViewAnimator.swift",
    "chars": 13141,
    "preview": "//\n//  ViewAnimator.swift\n//  Pods-ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 10/5/17.\n//\n\nimport Foundat"
  },
  {
    "path": "Sources/ViewAnimatorConfig.swift",
    "chars": 1378,
    "preview": "//\n//  ViewAnimatorConfig.swift\n//  Pods-ViewAnimator_Example\n//\n//  Created by Marcos Griselli on 10/9/17.\n//\n\nimport U"
  },
  {
    "path": "ViewAnimator.podspec",
    "chars": 1044,
    "preview": "Pod::Spec.new do |s|\n  s.name             = 'ViewAnimator'\n  s.version          = '3.1.0'\n  s.summary          = 'ViewAn"
  },
  {
    "path": "ViewAnimator.xcodeproj/ViewAnimator_Info.plist",
    "chars": 781,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/P"
  },
  {
    "path": "ViewAnimator.xcodeproj/project.pbxproj",
    "chars": 46401,
    "preview": "// !$*UTF8*$!\n{\n\tarchiveVersion = 1;\n\tclasses = {\n\t};\n\tobjectVersion = 46;\n\tobjects = {\n\n/* Begin PBXBuildFile section *"
  },
  {
    "path": "ViewAnimator.xcodeproj/project.xcworkspace/contents.xcworkspacedata",
    "chars": 134,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Workspace\n   version = \"1.0\">\n   <FileRef\n      location = \"self:\">\n   </FileRef"
  },
  {
    "path": "ViewAnimator.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist",
    "chars": 238,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/P"
  },
  {
    "path": "ViewAnimator.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings",
    "chars": 269,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/P"
  },
  {
    "path": "ViewAnimator.xcodeproj/xcshareddata/xcschemes/ViewAnimator-Package.xcscheme",
    "chars": 2521,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Scheme\n   LastUpgradeVersion = \"9999\"\n   version = \"1.3\">\n   <BuildAction\n      "
  },
  {
    "path": "ViewAnimator.xcodeproj/xcshareddata/xcschemes/ViewAnimator-iOS.xcscheme",
    "chars": 3395,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Scheme\n   LastUpgradeVersion = \"1030\"\n   version = \"1.3\">\n   <BuildAction\n      "
  },
  {
    "path": "ViewAnimator.xcodeproj/xcshareddata/xcschemes/ViewAnimator-tvOS.xcscheme",
    "chars": 3403,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Scheme\n   LastUpgradeVersion = \"1030\"\n   version = \"1.3\">\n   <BuildAction\n      "
  },
  {
    "path": "ViewAnimator.xcodeproj/xcshareddata/xcschemes/ViewAnimator.xcscheme",
    "chars": 3726,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Scheme\n   LastUpgradeVersion = \"1030\"\n   version = \"1.3\">\n   <BuildAction\n      "
  },
  {
    "path": "ViewAnimatorTests/Info.plist",
    "chars": 701,
    "preview": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<!DOCTYPE plist PUBLIC \"-//Apple//DTD PLIST 1.0//EN\" \"http://www.apple.com/DTDs/P"
  },
  {
    "path": "ViewAnimatorTests/Tests.swift",
    "chars": 1886,
    "preview": "import UIKit\nimport XCTest\nimport ViewAnimator\n\nclass Tests: XCTestCase {\n    \n    override func setUp() {\n        super"
  },
  {
    "path": "fastlane/Appfile",
    "chars": 228,
    "preview": "# app_identifier \"[[APP_IDENTIFIER]]\" # The bundle identifier of your app\n# apple_id \"[[APPLE_ID]]\" # Your Apple email a"
  },
  {
    "path": "fastlane/Fastfile",
    "chars": 1194,
    "preview": "default_platform(:ios)\n\nplatform :ios do\n\n  before_all do \n    @podspec_name = \"ViewAnimator.podspec\"\n  end\n\n  lane :tes"
  }
]

About this extraction

This page contains the full source code of the marcosgriselli/ViewAnimator GitHub repository, extracted and formatted as plain text for AI agents and large language models (LLMs). The extraction includes 75 files (172.8 KB), approximately 48.7k tokens. Use this with OpenClaw, Claude, ChatGPT, Cursor, Windsurf, or any other AI tool that accepts text input. You can copy the full output to your clipboard or download it as a .txt file.

Extracted by GitExtract — free GitHub repo to text converter for AI. Built by Nikandr Surkov.

Copied to clipboard!