diff --git a/enzevalos_iphone.xcodeproj/project.pbxproj b/enzevalos_iphone.xcodeproj/project.pbxproj
index 6a8125c950646ae34c08a8b7650dd4784ddb4092..7965da0bd4f00e6c6fa8e5e3f702c7bfd7c4b6db 100644
--- a/enzevalos_iphone.xcodeproj/project.pbxproj
+++ b/enzevalos_iphone.xcodeproj/project.pbxproj
@@ -7,14 +7,73 @@
 	objects = {
 
 /* Begin PBXBuildFile section */
+		6F4F718DEF29038C629100F3 /* Pods_enzevalos_iphone.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = FC2DE71EDB6C5C054D57F260 /* Pods_enzevalos_iphone.framework */; };
 		A13526791D955BDF00D3BFE1 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = A13526781D955BDF00D3BFE1 /* AppDelegate.swift */; };
-		A135267B1D955BDF00D3BFE1 /* ViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = A135267A1D955BDF00D3BFE1 /* ViewController.swift */; };
-		A135267E1D955BDF00D3BFE1 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = A135267C1D955BDF00D3BFE1 /* Main.storyboard */; };
 		A13526811D955BDF00D3BFE1 /* enzevalos_iphone.xcdatamodeld in Sources */ = {isa = PBXBuildFile; fileRef = A135267F1D955BDF00D3BFE1 /* enzevalos_iphone.xcdatamodeld */; };
-		A13526831D955BDF00D3BFE1 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = A13526821D955BDF00D3BFE1 /* Assets.xcassets */; };
 		A13526861D955BDF00D3BFE1 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = A13526841D955BDF00D3BFE1 /* LaunchScreen.storyboard */; };
 		A13526911D955BE000D3BFE1 /* enzevalos_iphoneTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = A13526901D955BE000D3BFE1 /* enzevalos_iphoneTests.swift */; };
 		A135269C1D955BE000D3BFE1 /* enzevalos_iphoneUITests.swift in Sources */ = {isa = PBXBuildFile; fileRef = A135269B1D955BE000D3BFE1 /* enzevalos_iphoneUITests.swift */; };
+		A1EB05781D956817008659C1 /* ImageExtension.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05771D956817008659C1 /* ImageExtension.swift */; };
+		A1EB057A1D956829008659C1 /* ContactCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05791D956829008659C1 /* ContactCell.swift */; };
+		A1EB057C1D956838008659C1 /* MailHandler.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB057B1D956838008659C1 /* MailHandler.swift */; };
+		A1EB057E1D956848008659C1 /* VENDataDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB057D1D956848008659C1 /* VENDataDelegate.swift */; };
+		A1EB05801D956851008659C1 /* VCSend04.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB057F1D956851008659C1 /* VCSend04.swift */; };
+		A1EB05821D95685B008659C1 /* CollectionDataDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05811D95685B008659C1 /* CollectionDataDelegate.swift */; };
+		A1EB05841D956867008659C1 /* TableViewDataDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05831D956867008659C1 /* TableViewDataDelegate.swift */; };
+		A1EB05861D956872008659C1 /* FrequentCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05851D956872008659C1 /* FrequentCell.swift */; };
+		A1EB05881D956879008659C1 /* AddressHandler.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05871D956879008659C1 /* AddressHandler.swift */; };
+		A1EB058A1D956890008659C1 /* ContactCell.xib in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05891D956890008659C1 /* ContactCell.xib */; };
+		A1EB058C1D9568AB008659C1 /* FrequentCell.xib in Resources */ = {isa = PBXBuildFile; fileRef = A1EB058B1D9568AB008659C1 /* FrequentCell.xib */; };
+		A1EB058E1D956913008659C1 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = A1EB058D1D956913008659C1 /* Main.storyboard */; };
+		A1EB05901D956923008659C1 /* ReadViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB058F1D956923008659C1 /* ReadViewController.swift */; };
+		A1EB05921D95692A008659C1 /* MailObject.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05911D95692A008659C1 /* MailObject.swift */; };
+		A1EB05941D956931008659C1 /* InboxCellDelegator.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05931D956931008659C1 /* InboxCellDelegator.swift */; };
+		A1EB05961D956939008659C1 /* InboxTableViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05951D956939008659C1 /* InboxTableViewCell.swift */; };
+		A1EB05981D956947008659C1 /* InboxViewController.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05971D956947008659C1 /* InboxViewController.swift */; };
+		A1EB059A1D95694E008659C1 /* FillInbox.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB05991D95694E008659C1 /* FillInbox.swift */; };
+		A1EB059C1D956957008659C1 /* NSDateCompare.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB059B1D956957008659C1 /* NSDateCompare.swift */; };
+		A1EB059E1D956963008659C1 /* EnzevalosContact.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB059D1D956963008659C1 /* EnzevalosContact.swift */; };
+		A1EB05A01D95696C008659C1 /* MessageBodyTableViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = A1EB059F1D95696C008659C1 /* MessageBodyTableViewCell.swift */; };
+		A1EB05A21D956972008659C1 /* InboxTableViewCell.xib in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05A11D956972008659C1 /* InboxTableViewCell.xib */; };
+		A1EB05A41D956E32008659C1 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05A31D956E32008659C1 /* Assets.xcassets */; };
+		A1EB05CA1D956F8E008659C1 /* home2_white.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05A61D956F8E008659C1 /* home2_white.png */; };
+		A1EB05CB1D956F8E008659C1 /* home2_white@2x.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05A71D956F8E008659C1 /* home2_white@2x.png */; };
+		A1EB05CC1D956F8E008659C1 /* home2_white@3x.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05A81D956F8E008659C1 /* home2_white@3x.png */; };
+		A1EB05CD1D956F8E008659C1 /* work2_white.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05A91D956F8E008659C1 /* work2_white.png */; };
+		A1EB05CE1D956F8E008659C1 /* work2_white@2x.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05AA1D956F8E008659C1 /* work2_white@2x.png */; };
+		A1EB05CF1D956F8E008659C1 /* work2_white@3x.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05AB1D956F8E008659C1 /* work2_white@3x.png */; };
+		A1EB05D01D956F8E008659C1 /* work.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05AC1D956F8E008659C1 /* work.png */; };
+		A1EB05D11D956F8E008659C1 /* work@3x.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05AD1D956F8E008659C1 /* work@3x.png */; };
+		A1EB05D21D956F8E008659C1 /* work@2x.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05AE1D956F8E008659C1 /* work@2x.png */; };
+		A1EB05D31D956F8E008659C1 /* home2.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05AF1D956F8E008659C1 /* home2.png */; };
+		A1EB05D41D956F8E008659C1 /* home2@2x.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B01D956F8E008659C1 /* home2@2x.png */; };
+		A1EB05D51D956F8E008659C1 /* home2@3x.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B11D956F8E008659C1 /* home2@3x.png */; };
+		A1EB05D61D956F8E008659C1 /* Icon_animated001-001_alpha_breit.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B21D956F8E008659C1 /* Icon_animated001-001_alpha_breit.png */; };
+		A1EB05D71D956F8E008659C1 /* Icon_animated001-002_alpha.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B31D956F8E008659C1 /* Icon_animated001-002_alpha.png */; };
+		A1EB05D81D956F8E008659C1 /* Icon_animated001-003_alpha.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B41D956F8E008659C1 /* Icon_animated001-003_alpha.png */; };
+		A1EB05D91D956F8E008659C1 /* Icon_animated001-004_alpha.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B51D956F8E008659C1 /* Icon_animated001-004_alpha.png */; };
+		A1EB05DA1D956F8E008659C1 /* Icon_animated001-005_alpha.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B61D956F8E008659C1 /* Icon_animated001-005_alpha.png */; };
+		A1EB05DB1D956F8E008659C1 /* Icon_animated001-006_alpha.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B71D956F8E008659C1 /* Icon_animated001-006_alpha.png */; };
+		A1EB05DC1D956F8E008659C1 /* Icon_animated001-001_alpha_verschoben-90.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B81D956F8E008659C1 /* Icon_animated001-001_alpha_verschoben-90.png */; };
+		A1EB05DD1D956F8E008659C1 /* Icon_animated001-002_alpha_verschoben-90.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05B91D956F8E008659C1 /* Icon_animated001-002_alpha_verschoben-90.png */; };
+		A1EB05DE1D956F8E008659C1 /* Icon_animated001-003_alpha_verschoben-90.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05BA1D956F8E008659C1 /* Icon_animated001-003_alpha_verschoben-90.png */; };
+		A1EB05DF1D956F8E008659C1 /* Icon_animated001-004_alpha_verschoben-90.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05BB1D956F8E008659C1 /* Icon_animated001-004_alpha_verschoben-90.png */; };
+		A1EB05E01D956F8E008659C1 /* Icon_animated001-005_alpha_verschoben-90.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05BC1D956F8E008659C1 /* Icon_animated001-005_alpha_verschoben-90.png */; };
+		A1EB05E11D956F8E008659C1 /* Icon_animated001-006_alpha_verschoben-90.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05BD1D956F8E008659C1 /* Icon_animated001-006_alpha_verschoben-90.png */; };
+		A1EB05E21D956F8E008659C1 /* Icon_animated001-007_alpha_verschoben-90.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05BE1D956F8E008659C1 /* Icon_animated001-007_alpha_verschoben-90.png */; };
+		A1EB05E31D956F8E008659C1 /* Icon_animated001-007_alpha.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05BF1D956F8E008659C1 /* Icon_animated001-007_alpha.png */; };
+		A1EB05E41D956F8E008659C1 /* Icon_animated001-001.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C01D956F8E008659C1 /* Icon_animated001-001.png */; };
+		A1EB05E51D956F8E008659C1 /* Icon_animated001-001_alpha.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C11D956F8E008659C1 /* Icon_animated001-001_alpha.png */; };
+		A1EB05E61D956F8E008659C1 /* Icon_animated001-002.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C21D956F8E008659C1 /* Icon_animated001-002.png */; };
+		A1EB05E71D956F8E008659C1 /* Icon_animated001-003.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C31D956F8E008659C1 /* Icon_animated001-003.png */; };
+		A1EB05E81D956F8E008659C1 /* Icon_animated001-004.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C41D956F8E008659C1 /* Icon_animated001-004.png */; };
+		A1EB05E91D956F8E008659C1 /* Icon_animated001-005.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C51D956F8E008659C1 /* Icon_animated001-005.png */; };
+		A1EB05EA1D956F8E008659C1 /* Icon_animated001-006.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C61D956F8E008659C1 /* Icon_animated001-006.png */; };
+		A1EB05EB1D956F8E008659C1 /* Icon_animated001-007.png in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C71D956F8E008659C1 /* Icon_animated001-007.png */; };
+		A1EB05EC1D956F8E008659C1 /* gruen.gif in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C81D956F8E008659C1 /* gruen.gif */; };
+		A1EB05ED1D956F8E008659C1 /* Unbenannt.gif in Resources */ = {isa = PBXBuildFile; fileRef = A1EB05C91D956F8E008659C1 /* Unbenannt.gif */; };
+		EE57562DDC09AD98702A0BA4 /* Pods_enzevalos_iphoneUITests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DDF1ED2111398B0F43FD783D /* Pods_enzevalos_iphoneUITests.framework */; };
+		EE9FF2F1FD02293642A4B05C /* Pods_enzevalos_iphoneTests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 22C1165F07662D8C13674825 /* Pods_enzevalos_iphoneTests.framework */; };
 /* End PBXBuildFile section */
 
 /* Begin PBXContainerItemProxy section */
@@ -35,12 +94,14 @@
 /* End PBXContainerItemProxy section */
 
 /* Begin PBXFileReference section */
+		22C1165F07662D8C13674825 /* Pods_enzevalos_iphoneTests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_enzevalos_iphoneTests.framework; sourceTree = BUILT_PRODUCTS_DIR; };
+		411EB2B85F99B48FFD36F966 /* Pods-enzevalos_iphoneTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-enzevalos_iphoneTests.debug.xcconfig"; path = "../workspace/Pods/Target Support Files/Pods-enzevalos_iphoneTests/Pods-enzevalos_iphoneTests.debug.xcconfig"; sourceTree = "<group>"; };
+		796D16D79BED5D60B580E602 /* Pods-enzevalos_iphoneUITests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-enzevalos_iphoneUITests.release.xcconfig"; path = "../workspace/Pods/Target Support Files/Pods-enzevalos_iphoneUITests/Pods-enzevalos_iphoneUITests.release.xcconfig"; sourceTree = "<group>"; };
+		9857108F0823A3919046C491 /* Pods-enzevalos_iphone.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-enzevalos_iphone.release.xcconfig"; path = "../workspace/Pods/Target Support Files/Pods-enzevalos_iphone/Pods-enzevalos_iphone.release.xcconfig"; sourceTree = "<group>"; };
+		9A132EDE8BCA06ACDB505C22 /* Pods-enzevalos_iphoneUITests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-enzevalos_iphoneUITests.debug.xcconfig"; path = "../workspace/Pods/Target Support Files/Pods-enzevalos_iphoneUITests/Pods-enzevalos_iphoneUITests.debug.xcconfig"; sourceTree = "<group>"; };
 		A13526751D955BDF00D3BFE1 /* enzevalos_iphone.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = enzevalos_iphone.app; sourceTree = BUILT_PRODUCTS_DIR; };
 		A13526781D955BDF00D3BFE1 /* AppDelegate.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
-		A135267A1D955BDF00D3BFE1 /* ViewController.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ViewController.swift; sourceTree = "<group>"; };
-		A135267D1D955BDF00D3BFE1 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = "<group>"; };
 		A13526801D955BDF00D3BFE1 /* enzevalos_iphone.xcdatamodel */ = {isa = PBXFileReference; lastKnownFileType = wrapper.xcdatamodel; path = enzevalos_iphone.xcdatamodel; sourceTree = "<group>"; };
-		A13526821D955BDF00D3BFE1 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
 		A13526851D955BDF00D3BFE1 /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
 		A13526871D955BDF00D3BFE1 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
 		A135268C1D955BE000D3BFE1 /* enzevalos_iphoneTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = enzevalos_iphoneTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
@@ -49,6 +110,69 @@
 		A13526971D955BE000D3BFE1 /* enzevalos_iphoneUITests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = enzevalos_iphoneUITests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
 		A135269B1D955BE000D3BFE1 /* enzevalos_iphoneUITests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = enzevalos_iphoneUITests.swift; sourceTree = "<group>"; };
 		A135269D1D955BE000D3BFE1 /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
+		A1EB05771D956817008659C1 /* ImageExtension.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ImageExtension.swift; sourceTree = "<group>"; };
+		A1EB05791D956829008659C1 /* ContactCell.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ContactCell.swift; sourceTree = "<group>"; };
+		A1EB057B1D956838008659C1 /* MailHandler.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = MailHandler.swift; sourceTree = "<group>"; };
+		A1EB057D1D956848008659C1 /* VENDataDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = VENDataDelegate.swift; sourceTree = "<group>"; };
+		A1EB057F1D956851008659C1 /* VCSend04.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = VCSend04.swift; sourceTree = "<group>"; };
+		A1EB05811D95685B008659C1 /* CollectionDataDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = CollectionDataDelegate.swift; sourceTree = "<group>"; };
+		A1EB05831D956867008659C1 /* TableViewDataDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TableViewDataDelegate.swift; sourceTree = "<group>"; };
+		A1EB05851D956872008659C1 /* FrequentCell.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = FrequentCell.swift; sourceTree = "<group>"; };
+		A1EB05871D956879008659C1 /* AddressHandler.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AddressHandler.swift; sourceTree = "<group>"; };
+		A1EB05891D956890008659C1 /* ContactCell.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = ContactCell.xib; sourceTree = "<group>"; };
+		A1EB058B1D9568AB008659C1 /* FrequentCell.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = FrequentCell.xib; sourceTree = "<group>"; };
+		A1EB058D1D956913008659C1 /* Main.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; path = Main.storyboard; sourceTree = "<group>"; };
+		A1EB058F1D956923008659C1 /* ReadViewController.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ReadViewController.swift; sourceTree = "<group>"; };
+		A1EB05911D95692A008659C1 /* MailObject.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = MailObject.swift; sourceTree = "<group>"; };
+		A1EB05931D956931008659C1 /* InboxCellDelegator.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = InboxCellDelegator.swift; sourceTree = "<group>"; };
+		A1EB05951D956939008659C1 /* InboxTableViewCell.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = InboxTableViewCell.swift; sourceTree = "<group>"; };
+		A1EB05971D956947008659C1 /* InboxViewController.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = InboxViewController.swift; sourceTree = "<group>"; };
+		A1EB05991D95694E008659C1 /* FillInbox.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = FillInbox.swift; sourceTree = "<group>"; };
+		A1EB059B1D956957008659C1 /* NSDateCompare.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = NSDateCompare.swift; sourceTree = "<group>"; };
+		A1EB059D1D956963008659C1 /* EnzevalosContact.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = EnzevalosContact.swift; sourceTree = "<group>"; };
+		A1EB059F1D95696C008659C1 /* MessageBodyTableViewCell.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = MessageBodyTableViewCell.swift; sourceTree = "<group>"; };
+		A1EB05A11D956972008659C1 /* InboxTableViewCell.xib */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.xib; path = InboxTableViewCell.xib; sourceTree = "<group>"; };
+		A1EB05A31D956E32008659C1 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
+		A1EB05A61D956F8E008659C1 /* home2_white.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = home2_white.png; sourceTree = "<group>"; };
+		A1EB05A71D956F8E008659C1 /* home2_white@2x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "home2_white@2x.png"; sourceTree = "<group>"; };
+		A1EB05A81D956F8E008659C1 /* home2_white@3x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "home2_white@3x.png"; sourceTree = "<group>"; };
+		A1EB05A91D956F8E008659C1 /* work2_white.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = work2_white.png; sourceTree = "<group>"; };
+		A1EB05AA1D956F8E008659C1 /* work2_white@2x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "work2_white@2x.png"; sourceTree = "<group>"; };
+		A1EB05AB1D956F8E008659C1 /* work2_white@3x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "work2_white@3x.png"; sourceTree = "<group>"; };
+		A1EB05AC1D956F8E008659C1 /* work.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = work.png; sourceTree = "<group>"; };
+		A1EB05AD1D956F8E008659C1 /* work@3x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "work@3x.png"; sourceTree = "<group>"; };
+		A1EB05AE1D956F8E008659C1 /* work@2x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "work@2x.png"; sourceTree = "<group>"; };
+		A1EB05AF1D956F8E008659C1 /* home2.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = home2.png; sourceTree = "<group>"; };
+		A1EB05B01D956F8E008659C1 /* home2@2x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "home2@2x.png"; sourceTree = "<group>"; };
+		A1EB05B11D956F8E008659C1 /* home2@3x.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "home2@3x.png"; sourceTree = "<group>"; };
+		A1EB05B21D956F8E008659C1 /* Icon_animated001-001_alpha_breit.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-001_alpha_breit.png"; sourceTree = "<group>"; };
+		A1EB05B31D956F8E008659C1 /* Icon_animated001-002_alpha.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-002_alpha.png"; sourceTree = "<group>"; };
+		A1EB05B41D956F8E008659C1 /* Icon_animated001-003_alpha.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-003_alpha.png"; sourceTree = "<group>"; };
+		A1EB05B51D956F8E008659C1 /* Icon_animated001-004_alpha.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-004_alpha.png"; sourceTree = "<group>"; };
+		A1EB05B61D956F8E008659C1 /* Icon_animated001-005_alpha.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-005_alpha.png"; sourceTree = "<group>"; };
+		A1EB05B71D956F8E008659C1 /* Icon_animated001-006_alpha.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-006_alpha.png"; sourceTree = "<group>"; };
+		A1EB05B81D956F8E008659C1 /* Icon_animated001-001_alpha_verschoben-90.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-001_alpha_verschoben-90.png"; sourceTree = "<group>"; };
+		A1EB05B91D956F8E008659C1 /* Icon_animated001-002_alpha_verschoben-90.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-002_alpha_verschoben-90.png"; sourceTree = "<group>"; };
+		A1EB05BA1D956F8E008659C1 /* Icon_animated001-003_alpha_verschoben-90.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-003_alpha_verschoben-90.png"; sourceTree = "<group>"; };
+		A1EB05BB1D956F8E008659C1 /* Icon_animated001-004_alpha_verschoben-90.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-004_alpha_verschoben-90.png"; sourceTree = "<group>"; };
+		A1EB05BC1D956F8E008659C1 /* Icon_animated001-005_alpha_verschoben-90.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-005_alpha_verschoben-90.png"; sourceTree = "<group>"; };
+		A1EB05BD1D956F8E008659C1 /* Icon_animated001-006_alpha_verschoben-90.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-006_alpha_verschoben-90.png"; sourceTree = "<group>"; };
+		A1EB05BE1D956F8E008659C1 /* Icon_animated001-007_alpha_verschoben-90.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-007_alpha_verschoben-90.png"; sourceTree = "<group>"; };
+		A1EB05BF1D956F8E008659C1 /* Icon_animated001-007_alpha.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-007_alpha.png"; sourceTree = "<group>"; };
+		A1EB05C01D956F8E008659C1 /* Icon_animated001-001.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-001.png"; sourceTree = "<group>"; };
+		A1EB05C11D956F8E008659C1 /* Icon_animated001-001_alpha.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-001_alpha.png"; sourceTree = "<group>"; };
+		A1EB05C21D956F8E008659C1 /* Icon_animated001-002.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-002.png"; sourceTree = "<group>"; };
+		A1EB05C31D956F8E008659C1 /* Icon_animated001-003.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-003.png"; sourceTree = "<group>"; };
+		A1EB05C41D956F8E008659C1 /* Icon_animated001-004.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-004.png"; sourceTree = "<group>"; };
+		A1EB05C51D956F8E008659C1 /* Icon_animated001-005.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-005.png"; sourceTree = "<group>"; };
+		A1EB05C61D956F8E008659C1 /* Icon_animated001-006.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-006.png"; sourceTree = "<group>"; };
+		A1EB05C71D956F8E008659C1 /* Icon_animated001-007.png */ = {isa = PBXFileReference; lastKnownFileType = image.png; path = "Icon_animated001-007.png"; sourceTree = "<group>"; };
+		A1EB05C81D956F8E008659C1 /* gruen.gif */ = {isa = PBXFileReference; lastKnownFileType = image.gif; path = gruen.gif; sourceTree = "<group>"; };
+		A1EB05C91D956F8E008659C1 /* Unbenannt.gif */ = {isa = PBXFileReference; lastKnownFileType = image.gif; path = Unbenannt.gif; sourceTree = "<group>"; };
+		AE7C40F081DAC9A0A130BE21 /* Pods-enzevalos_iphone.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-enzevalos_iphone.debug.xcconfig"; path = "../workspace/Pods/Target Support Files/Pods-enzevalos_iphone/Pods-enzevalos_iphone.debug.xcconfig"; sourceTree = "<group>"; };
+		C7733DFEFB7E7CFF38EC1665 /* Pods-enzevalos_iphoneTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-enzevalos_iphoneTests.release.xcconfig"; path = "../workspace/Pods/Target Support Files/Pods-enzevalos_iphoneTests/Pods-enzevalos_iphoneTests.release.xcconfig"; sourceTree = "<group>"; };
+		DDF1ED2111398B0F43FD783D /* Pods_enzevalos_iphoneUITests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_enzevalos_iphoneUITests.framework; sourceTree = BUILT_PRODUCTS_DIR; };
+		FC2DE71EDB6C5C054D57F260 /* Pods_enzevalos_iphone.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_enzevalos_iphone.framework; sourceTree = BUILT_PRODUCTS_DIR; };
 /* End PBXFileReference section */
 
 /* Begin PBXFrameworksBuildPhase section */
@@ -56,6 +180,7 @@
 			isa = PBXFrameworksBuildPhase;
 			buildActionMask = 2147483647;
 			files = (
+				6F4F718DEF29038C629100F3 /* Pods_enzevalos_iphone.framework in Frameworks */,
 			);
 			runOnlyForDeploymentPostprocessing = 0;
 		};
@@ -63,6 +188,7 @@
 			isa = PBXFrameworksBuildPhase;
 			buildActionMask = 2147483647;
 			files = (
+				EE9FF2F1FD02293642A4B05C /* Pods_enzevalos_iphoneTests.framework in Frameworks */,
 			);
 			runOnlyForDeploymentPostprocessing = 0;
 		};
@@ -70,12 +196,36 @@
 			isa = PBXFrameworksBuildPhase;
 			buildActionMask = 2147483647;
 			files = (
+				EE57562DDC09AD98702A0BA4 /* Pods_enzevalos_iphoneUITests.framework in Frameworks */,
 			);
 			runOnlyForDeploymentPostprocessing = 0;
 		};
 /* End PBXFrameworksBuildPhase section */
 
 /* Begin PBXGroup section */
+		24472862977D71D3F0AD0D58 /* Pods */ = {
+			isa = PBXGroup;
+			children = (
+				AE7C40F081DAC9A0A130BE21 /* Pods-enzevalos_iphone.debug.xcconfig */,
+				9857108F0823A3919046C491 /* Pods-enzevalos_iphone.release.xcconfig */,
+				411EB2B85F99B48FFD36F966 /* Pods-enzevalos_iphoneTests.debug.xcconfig */,
+				C7733DFEFB7E7CFF38EC1665 /* Pods-enzevalos_iphoneTests.release.xcconfig */,
+				9A132EDE8BCA06ACDB505C22 /* Pods-enzevalos_iphoneUITests.debug.xcconfig */,
+				796D16D79BED5D60B580E602 /* Pods-enzevalos_iphoneUITests.release.xcconfig */,
+			);
+			name = Pods;
+			sourceTree = "<group>";
+		};
+		78280F99990BFF65543B7F0B /* Frameworks */ = {
+			isa = PBXGroup;
+			children = (
+				FC2DE71EDB6C5C054D57F260 /* Pods_enzevalos_iphone.framework */,
+				22C1165F07662D8C13674825 /* Pods_enzevalos_iphoneTests.framework */,
+				DDF1ED2111398B0F43FD783D /* Pods_enzevalos_iphoneUITests.framework */,
+			);
+			name = Frameworks;
+			sourceTree = "<group>";
+		};
 		A135266C1D955BDF00D3BFE1 = {
 			isa = PBXGroup;
 			children = (
@@ -83,6 +233,8 @@
 				A135268F1D955BE000D3BFE1 /* enzevalos_iphoneTests */,
 				A135269A1D955BE000D3BFE1 /* enzevalos_iphoneUITests */,
 				A13526761D955BDF00D3BFE1 /* Products */,
+				24472862977D71D3F0AD0D58 /* Pods */,
+				78280F99990BFF65543B7F0B /* Frameworks */,
 			);
 			sourceTree = "<group>";
 		};
@@ -99,11 +251,13 @@
 		A13526771D955BDF00D3BFE1 /* enzevalos_iphone */ = {
 			isa = PBXGroup;
 			children = (
+				A1EB05761D9567F2008659C1 /* read */,
+				A1EB05751D956748008659C1 /* send */,
 				A13526781D955BDF00D3BFE1 /* AppDelegate.swift */,
-				A135267A1D955BDF00D3BFE1 /* ViewController.swift */,
-				A135267C1D955BDF00D3BFE1 /* Main.storyboard */,
-				A13526821D955BDF00D3BFE1 /* Assets.xcassets */,
+				A1EB05771D956817008659C1 /* ImageExtension.swift */,
+				A1EB058D1D956913008659C1 /* Main.storyboard */,
 				A13526841D955BDF00D3BFE1 /* LaunchScreen.storyboard */,
+				A1EB05A31D956E32008659C1 /* Assets.xcassets */,
 				A13526871D955BDF00D3BFE1 /* Info.plist */,
 				A135267F1D955BDF00D3BFE1 /* enzevalos_iphone.xcdatamodeld */,
 			);
@@ -128,6 +282,84 @@
 			path = enzevalos_iphoneUITests;
 			sourceTree = "<group>";
 		};
+		A1EB05751D956748008659C1 /* send */ = {
+			isa = PBXGroup;
+			children = (
+				A1EB05A51D956F73008659C1 /* images */,
+				A1EB057F1D956851008659C1 /* VCSend04.swift */,
+				A1EB057D1D956848008659C1 /* VENDataDelegate.swift */,
+				A1EB05811D95685B008659C1 /* CollectionDataDelegate.swift */,
+				A1EB05831D956867008659C1 /* TableViewDataDelegate.swift */,
+				A1EB057B1D956838008659C1 /* MailHandler.swift */,
+				A1EB05871D956879008659C1 /* AddressHandler.swift */,
+				A1EB05791D956829008659C1 /* ContactCell.swift */,
+				A1EB05851D956872008659C1 /* FrequentCell.swift */,
+				A1EB05891D956890008659C1 /* ContactCell.xib */,
+				A1EB058B1D9568AB008659C1 /* FrequentCell.xib */,
+			);
+			name = send;
+			sourceTree = "<group>";
+		};
+		A1EB05761D9567F2008659C1 /* read */ = {
+			isa = PBXGroup;
+			children = (
+				A1EB058F1D956923008659C1 /* ReadViewController.swift */,
+				A1EB05911D95692A008659C1 /* MailObject.swift */,
+				A1EB05931D956931008659C1 /* InboxCellDelegator.swift */,
+				A1EB05951D956939008659C1 /* InboxTableViewCell.swift */,
+				A1EB05971D956947008659C1 /* InboxViewController.swift */,
+				A1EB05991D95694E008659C1 /* FillInbox.swift */,
+				A1EB059B1D956957008659C1 /* NSDateCompare.swift */,
+				A1EB059D1D956963008659C1 /* EnzevalosContact.swift */,
+				A1EB059F1D95696C008659C1 /* MessageBodyTableViewCell.swift */,
+				A1EB05A11D956972008659C1 /* InboxTableViewCell.xib */,
+			);
+			name = read;
+			sourceTree = "<group>";
+		};
+		A1EB05A51D956F73008659C1 /* images */ = {
+			isa = PBXGroup;
+			children = (
+				A1EB05A61D956F8E008659C1 /* home2_white.png */,
+				A1EB05A71D956F8E008659C1 /* home2_white@2x.png */,
+				A1EB05A81D956F8E008659C1 /* home2_white@3x.png */,
+				A1EB05A91D956F8E008659C1 /* work2_white.png */,
+				A1EB05AA1D956F8E008659C1 /* work2_white@2x.png */,
+				A1EB05AB1D956F8E008659C1 /* work2_white@3x.png */,
+				A1EB05AC1D956F8E008659C1 /* work.png */,
+				A1EB05AD1D956F8E008659C1 /* work@3x.png */,
+				A1EB05AE1D956F8E008659C1 /* work@2x.png */,
+				A1EB05AF1D956F8E008659C1 /* home2.png */,
+				A1EB05B01D956F8E008659C1 /* home2@2x.png */,
+				A1EB05B11D956F8E008659C1 /* home2@3x.png */,
+				A1EB05B21D956F8E008659C1 /* Icon_animated001-001_alpha_breit.png */,
+				A1EB05B31D956F8E008659C1 /* Icon_animated001-002_alpha.png */,
+				A1EB05B41D956F8E008659C1 /* Icon_animated001-003_alpha.png */,
+				A1EB05B51D956F8E008659C1 /* Icon_animated001-004_alpha.png */,
+				A1EB05B61D956F8E008659C1 /* Icon_animated001-005_alpha.png */,
+				A1EB05B71D956F8E008659C1 /* Icon_animated001-006_alpha.png */,
+				A1EB05B81D956F8E008659C1 /* Icon_animated001-001_alpha_verschoben-90.png */,
+				A1EB05B91D956F8E008659C1 /* Icon_animated001-002_alpha_verschoben-90.png */,
+				A1EB05BA1D956F8E008659C1 /* Icon_animated001-003_alpha_verschoben-90.png */,
+				A1EB05BB1D956F8E008659C1 /* Icon_animated001-004_alpha_verschoben-90.png */,
+				A1EB05BC1D956F8E008659C1 /* Icon_animated001-005_alpha_verschoben-90.png */,
+				A1EB05BD1D956F8E008659C1 /* Icon_animated001-006_alpha_verschoben-90.png */,
+				A1EB05BE1D956F8E008659C1 /* Icon_animated001-007_alpha_verschoben-90.png */,
+				A1EB05BF1D956F8E008659C1 /* Icon_animated001-007_alpha.png */,
+				A1EB05C01D956F8E008659C1 /* Icon_animated001-001.png */,
+				A1EB05C11D956F8E008659C1 /* Icon_animated001-001_alpha.png */,
+				A1EB05C21D956F8E008659C1 /* Icon_animated001-002.png */,
+				A1EB05C31D956F8E008659C1 /* Icon_animated001-003.png */,
+				A1EB05C41D956F8E008659C1 /* Icon_animated001-004.png */,
+				A1EB05C51D956F8E008659C1 /* Icon_animated001-005.png */,
+				A1EB05C61D956F8E008659C1 /* Icon_animated001-006.png */,
+				A1EB05C71D956F8E008659C1 /* Icon_animated001-007.png */,
+				A1EB05C81D956F8E008659C1 /* gruen.gif */,
+				A1EB05C91D956F8E008659C1 /* Unbenannt.gif */,
+			);
+			name = images;
+			sourceTree = "<group>";
+		};
 /* End PBXGroup section */
 
 /* Begin PBXNativeTarget section */
@@ -135,9 +367,12 @@
 			isa = PBXNativeTarget;
 			buildConfigurationList = A13526A01D955BE000D3BFE1 /* Build configuration list for PBXNativeTarget "enzevalos_iphone" */;
 			buildPhases = (
+				60E197910FD6B0523F9273AE /* [CP] Check Pods Manifest.lock */,
 				A13526711D955BDF00D3BFE1 /* Sources */,
 				A13526721D955BDF00D3BFE1 /* Frameworks */,
 				A13526731D955BDF00D3BFE1 /* Resources */,
+				1B3A7EC4B7EC43108D4CA42F /* [CP] Embed Pods Frameworks */,
+				9C00DB37D91C40FACD06D614 /* [CP] Copy Pods Resources */,
 			);
 			buildRules = (
 			);
@@ -152,9 +387,12 @@
 			isa = PBXNativeTarget;
 			buildConfigurationList = A13526A31D955BE000D3BFE1 /* Build configuration list for PBXNativeTarget "enzevalos_iphoneTests" */;
 			buildPhases = (
+				D6F0EB205D61EA8C8A045390 /* [CP] Check Pods Manifest.lock */,
 				A13526881D955BE000D3BFE1 /* Sources */,
 				A13526891D955BE000D3BFE1 /* Frameworks */,
 				A135268A1D955BE000D3BFE1 /* Resources */,
+				6C4CB727DDC2AC31CCE50B26 /* [CP] Embed Pods Frameworks */,
+				E98D3D9213C0A8CF7EDD28B1 /* [CP] Copy Pods Resources */,
 			);
 			buildRules = (
 			);
@@ -170,9 +408,11 @@
 			isa = PBXNativeTarget;
 			buildConfigurationList = A13526A61D955BE000D3BFE1 /* Build configuration list for PBXNativeTarget "enzevalos_iphoneUITests" */;
 			buildPhases = (
+				CB3E7E0953A94645ED8E830A /* [CP] Check Pods Manifest.lock */,
 				A13526931D955BE000D3BFE1 /* Sources */,
 				A13526941D955BE000D3BFE1 /* Frameworks */,
 				A13526951D955BE000D3BFE1 /* Resources */,
+				F855B7C77E9E7734BC50BC72 /* [CP] Copy Pods Resources */,
 			);
 			buildRules = (
 			);
@@ -235,9 +475,48 @@
 			isa = PBXResourcesBuildPhase;
 			buildActionMask = 2147483647;
 			files = (
+				A1EB05CC1D956F8E008659C1 /* home2_white@3x.png in Resources */,
+				A1EB05CF1D956F8E008659C1 /* work2_white@3x.png in Resources */,
+				A1EB05E41D956F8E008659C1 /* Icon_animated001-001.png in Resources */,
+				A1EB05A21D956972008659C1 /* InboxTableViewCell.xib in Resources */,
+				A1EB05DA1D956F8E008659C1 /* Icon_animated001-005_alpha.png in Resources */,
+				A1EB058A1D956890008659C1 /* ContactCell.xib in Resources */,
+				A1EB05E51D956F8E008659C1 /* Icon_animated001-001_alpha.png in Resources */,
+				A1EB05DC1D956F8E008659C1 /* Icon_animated001-001_alpha_verschoben-90.png in Resources */,
+				A1EB05D11D956F8E008659C1 /* work@3x.png in Resources */,
+				A1EB05E21D956F8E008659C1 /* Icon_animated001-007_alpha_verschoben-90.png in Resources */,
+				A1EB05E11D956F8E008659C1 /* Icon_animated001-006_alpha_verschoben-90.png in Resources */,
+				A1EB05D81D956F8E008659C1 /* Icon_animated001-003_alpha.png in Resources */,
+				A1EB05E61D956F8E008659C1 /* Icon_animated001-002.png in Resources */,
+				A1EB05D71D956F8E008659C1 /* Icon_animated001-002_alpha.png in Resources */,
+				A1EB05CD1D956F8E008659C1 /* work2_white.png in Resources */,
+				A1EB05CB1D956F8E008659C1 /* home2_white@2x.png in Resources */,
+				A1EB05D31D956F8E008659C1 /* home2.png in Resources */,
+				A1EB05CA1D956F8E008659C1 /* home2_white.png in Resources */,
+				A1EB05D01D956F8E008659C1 /* work.png in Resources */,
+				A1EB05DB1D956F8E008659C1 /* Icon_animated001-006_alpha.png in Resources */,
+				A1EB05DE1D956F8E008659C1 /* Icon_animated001-003_alpha_verschoben-90.png in Resources */,
+				A1EB058E1D956913008659C1 /* Main.storyboard in Resources */,
+				A1EB05E81D956F8E008659C1 /* Icon_animated001-004.png in Resources */,
+				A1EB05DF1D956F8E008659C1 /* Icon_animated001-004_alpha_verschoben-90.png in Resources */,
+				A1EB05E71D956F8E008659C1 /* Icon_animated001-003.png in Resources */,
+				A1EB05D61D956F8E008659C1 /* Icon_animated001-001_alpha_breit.png in Resources */,
+				A1EB05ED1D956F8E008659C1 /* Unbenannt.gif in Resources */,
+				A1EB05E01D956F8E008659C1 /* Icon_animated001-005_alpha_verschoben-90.png in Resources */,
+				A1EB05EB1D956F8E008659C1 /* Icon_animated001-007.png in Resources */,
+				A1EB05E31D956F8E008659C1 /* Icon_animated001-007_alpha.png in Resources */,
+				A1EB05DD1D956F8E008659C1 /* Icon_animated001-002_alpha_verschoben-90.png in Resources */,
 				A13526861D955BDF00D3BFE1 /* LaunchScreen.storyboard in Resources */,
-				A13526831D955BDF00D3BFE1 /* Assets.xcassets in Resources */,
-				A135267E1D955BDF00D3BFE1 /* Main.storyboard in Resources */,
+				A1EB05D91D956F8E008659C1 /* Icon_animated001-004_alpha.png in Resources */,
+				A1EB05E91D956F8E008659C1 /* Icon_animated001-005.png in Resources */,
+				A1EB05EC1D956F8E008659C1 /* gruen.gif in Resources */,
+				A1EB05D41D956F8E008659C1 /* home2@2x.png in Resources */,
+				A1EB05CE1D956F8E008659C1 /* work2_white@2x.png in Resources */,
+				A1EB05A41D956E32008659C1 /* Assets.xcassets in Resources */,
+				A1EB05EA1D956F8E008659C1 /* Icon_animated001-006.png in Resources */,
+				A1EB05D21D956F8E008659C1 /* work@2x.png in Resources */,
+				A1EB058C1D9568AB008659C1 /* FrequentCell.xib in Resources */,
+				A1EB05D51D956F8E008659C1 /* home2@3x.png in Resources */,
 			);
 			runOnlyForDeploymentPostprocessing = 0;
 		};
@@ -257,14 +536,154 @@
 		};
 /* End PBXResourcesBuildPhase section */
 
+/* Begin PBXShellScriptBuildPhase section */
+		1B3A7EC4B7EC43108D4CA42F /* [CP] Embed Pods Frameworks */ = {
+			isa = PBXShellScriptBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			inputPaths = (
+			);
+			name = "[CP] Embed Pods Frameworks";
+			outputPaths = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+			shellPath = /bin/sh;
+			shellScript = "\"${SRCROOT}/../workspace/Pods/Target Support Files/Pods-enzevalos_iphone/Pods-enzevalos_iphone-frameworks.sh\"\n";
+			showEnvVarsInLog = 0;
+		};
+		60E197910FD6B0523F9273AE /* [CP] Check Pods Manifest.lock */ = {
+			isa = PBXShellScriptBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			inputPaths = (
+			);
+			name = "[CP] Check Pods Manifest.lock";
+			outputPaths = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+			shellPath = /bin/sh;
+			shellScript = "diff \"${PODS_ROOT}/../Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [[ $? != 0 ]] ; then\n    cat << EOM\nerror: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\nEOM\n    exit 1\nfi\n";
+			showEnvVarsInLog = 0;
+		};
+		6C4CB727DDC2AC31CCE50B26 /* [CP] Embed Pods Frameworks */ = {
+			isa = PBXShellScriptBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			inputPaths = (
+			);
+			name = "[CP] Embed Pods Frameworks";
+			outputPaths = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+			shellPath = /bin/sh;
+			shellScript = "\"${SRCROOT}/../workspace/Pods/Target Support Files/Pods-enzevalos_iphoneTests/Pods-enzevalos_iphoneTests-frameworks.sh\"\n";
+			showEnvVarsInLog = 0;
+		};
+		9C00DB37D91C40FACD06D614 /* [CP] Copy Pods Resources */ = {
+			isa = PBXShellScriptBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			inputPaths = (
+			);
+			name = "[CP] Copy Pods Resources";
+			outputPaths = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+			shellPath = /bin/sh;
+			shellScript = "\"${SRCROOT}/../workspace/Pods/Target Support Files/Pods-enzevalos_iphone/Pods-enzevalos_iphone-resources.sh\"\n";
+			showEnvVarsInLog = 0;
+		};
+		CB3E7E0953A94645ED8E830A /* [CP] Check Pods Manifest.lock */ = {
+			isa = PBXShellScriptBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			inputPaths = (
+			);
+			name = "[CP] Check Pods Manifest.lock";
+			outputPaths = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+			shellPath = /bin/sh;
+			shellScript = "diff \"${PODS_ROOT}/../Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [[ $? != 0 ]] ; then\n    cat << EOM\nerror: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\nEOM\n    exit 1\nfi\n";
+			showEnvVarsInLog = 0;
+		};
+		D6F0EB205D61EA8C8A045390 /* [CP] Check Pods Manifest.lock */ = {
+			isa = PBXShellScriptBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			inputPaths = (
+			);
+			name = "[CP] Check Pods Manifest.lock";
+			outputPaths = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+			shellPath = /bin/sh;
+			shellScript = "diff \"${PODS_ROOT}/../Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [[ $? != 0 ]] ; then\n    cat << EOM\nerror: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\nEOM\n    exit 1\nfi\n";
+			showEnvVarsInLog = 0;
+		};
+		E98D3D9213C0A8CF7EDD28B1 /* [CP] Copy Pods Resources */ = {
+			isa = PBXShellScriptBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			inputPaths = (
+			);
+			name = "[CP] Copy Pods Resources";
+			outputPaths = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+			shellPath = /bin/sh;
+			shellScript = "\"${SRCROOT}/../workspace/Pods/Target Support Files/Pods-enzevalos_iphoneTests/Pods-enzevalos_iphoneTests-resources.sh\"\n";
+			showEnvVarsInLog = 0;
+		};
+		F855B7C77E9E7734BC50BC72 /* [CP] Copy Pods Resources */ = {
+			isa = PBXShellScriptBuildPhase;
+			buildActionMask = 2147483647;
+			files = (
+			);
+			inputPaths = (
+			);
+			name = "[CP] Copy Pods Resources";
+			outputPaths = (
+			);
+			runOnlyForDeploymentPostprocessing = 0;
+			shellPath = /bin/sh;
+			shellScript = "\"${SRCROOT}/../workspace/Pods/Target Support Files/Pods-enzevalos_iphoneUITests/Pods-enzevalos_iphoneUITests-resources.sh\"\n";
+			showEnvVarsInLog = 0;
+		};
+/* End PBXShellScriptBuildPhase section */
+
 /* Begin PBXSourcesBuildPhase section */
 		A13526711D955BDF00D3BFE1 /* Sources */ = {
 			isa = PBXSourcesBuildPhase;
 			buildActionMask = 2147483647;
 			files = (
-				A135267B1D955BDF00D3BFE1 /* ViewController.swift in Sources */,
+				A1EB059C1D956957008659C1 /* NSDateCompare.swift in Sources */,
+				A1EB05941D956931008659C1 /* InboxCellDelegator.swift in Sources */,
+				A1EB05821D95685B008659C1 /* CollectionDataDelegate.swift in Sources */,
+				A1EB05801D956851008659C1 /* VCSend04.swift in Sources */,
+				A1EB05981D956947008659C1 /* InboxViewController.swift in Sources */,
+				A1EB059A1D95694E008659C1 /* FillInbox.swift in Sources */,
+				A1EB057E1D956848008659C1 /* VENDataDelegate.swift in Sources */,
+				A1EB057A1D956829008659C1 /* ContactCell.swift in Sources */,
+				A1EB059E1D956963008659C1 /* EnzevalosContact.swift in Sources */,
 				A13526811D955BDF00D3BFE1 /* enzevalos_iphone.xcdatamodeld in Sources */,
+				A1EB05781D956817008659C1 /* ImageExtension.swift in Sources */,
+				A1EB05A01D95696C008659C1 /* MessageBodyTableViewCell.swift in Sources */,
+				A1EB05841D956867008659C1 /* TableViewDataDelegate.swift in Sources */,
+				A1EB05961D956939008659C1 /* InboxTableViewCell.swift in Sources */,
+				A1EB05921D95692A008659C1 /* MailObject.swift in Sources */,
 				A13526791D955BDF00D3BFE1 /* AppDelegate.swift in Sources */,
+				A1EB057C1D956838008659C1 /* MailHandler.swift in Sources */,
+				A1EB05881D956879008659C1 /* AddressHandler.swift in Sources */,
+				A1EB05901D956923008659C1 /* ReadViewController.swift in Sources */,
+				A1EB05861D956872008659C1 /* FrequentCell.swift in Sources */,
 			);
 			runOnlyForDeploymentPostprocessing = 0;
 		};
@@ -300,14 +719,6 @@
 /* End PBXTargetDependency section */
 
 /* Begin PBXVariantGroup section */
-		A135267C1D955BDF00D3BFE1 /* Main.storyboard */ = {
-			isa = PBXVariantGroup;
-			children = (
-				A135267D1D955BDF00D3BFE1 /* Base */,
-			);
-			name = Main.storyboard;
-			sourceTree = "<group>";
-		};
 		A13526841D955BDF00D3BFE1 /* LaunchScreen.storyboard */ = {
 			isa = PBXVariantGroup;
 			children = (
@@ -404,6 +815,7 @@
 		};
 		A13526A11D955BE000D3BFE1 /* Debug */ = {
 			isa = XCBuildConfiguration;
+			baseConfigurationReference = AE7C40F081DAC9A0A130BE21 /* Pods-enzevalos_iphone.debug.xcconfig */;
 			buildSettings = {
 				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
 				INFOPLIST_FILE = enzevalos_iphone/Info.plist;
@@ -415,6 +827,7 @@
 		};
 		A13526A21D955BE000D3BFE1 /* Release */ = {
 			isa = XCBuildConfiguration;
+			baseConfigurationReference = 9857108F0823A3919046C491 /* Pods-enzevalos_iphone.release.xcconfig */;
 			buildSettings = {
 				ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
 				INFOPLIST_FILE = enzevalos_iphone/Info.plist;
@@ -426,6 +839,7 @@
 		};
 		A13526A41D955BE000D3BFE1 /* Debug */ = {
 			isa = XCBuildConfiguration;
+			baseConfigurationReference = 411EB2B85F99B48FFD36F966 /* Pods-enzevalos_iphoneTests.debug.xcconfig */;
 			buildSettings = {
 				BUNDLE_LOADER = "$(TEST_HOST)";
 				INFOPLIST_FILE = enzevalos_iphoneTests/Info.plist;
@@ -438,6 +852,7 @@
 		};
 		A13526A51D955BE000D3BFE1 /* Release */ = {
 			isa = XCBuildConfiguration;
+			baseConfigurationReference = C7733DFEFB7E7CFF38EC1665 /* Pods-enzevalos_iphoneTests.release.xcconfig */;
 			buildSettings = {
 				BUNDLE_LOADER = "$(TEST_HOST)";
 				INFOPLIST_FILE = enzevalos_iphoneTests/Info.plist;
@@ -450,6 +865,7 @@
 		};
 		A13526A71D955BE000D3BFE1 /* Debug */ = {
 			isa = XCBuildConfiguration;
+			baseConfigurationReference = 9A132EDE8BCA06ACDB505C22 /* Pods-enzevalos_iphoneUITests.debug.xcconfig */;
 			buildSettings = {
 				INFOPLIST_FILE = enzevalos_iphoneUITests/Info.plist;
 				LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
@@ -461,6 +877,7 @@
 		};
 		A13526A81D955BE000D3BFE1 /* Release */ = {
 			isa = XCBuildConfiguration;
+			baseConfigurationReference = 796D16D79BED5D60B580E602 /* Pods-enzevalos_iphoneUITests.release.xcconfig */;
 			buildSettings = {
 				INFOPLIST_FILE = enzevalos_iphoneUITests/Info.plist;
 				LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
@@ -489,6 +906,7 @@
 				A13526A21D955BE000D3BFE1 /* Release */,
 			);
 			defaultConfigurationIsVisible = 0;
+			defaultConfigurationName = Release;
 		};
 		A13526A31D955BE000D3BFE1 /* Build configuration list for PBXNativeTarget "enzevalos_iphoneTests" */ = {
 			isa = XCConfigurationList;
@@ -497,6 +915,7 @@
 				A13526A51D955BE000D3BFE1 /* Release */,
 			);
 			defaultConfigurationIsVisible = 0;
+			defaultConfigurationName = Release;
 		};
 		A13526A61D955BE000D3BFE1 /* Build configuration list for PBXNativeTarget "enzevalos_iphoneUITests" */ = {
 			isa = XCConfigurationList;
@@ -505,6 +924,7 @@
 				A13526A81D955BE000D3BFE1 /* Release */,
 			);
 			defaultConfigurationIsVisible = 0;
+			defaultConfigurationName = Release;
 		};
 /* End XCConfigurationList section */
 
diff --git a/enzevalos_iphone/AddressHandler.swift b/enzevalos_iphone/AddressHandler.swift
new file mode 100644
index 0000000000000000000000000000000000000000..664c916fdcd8e80bf4f0de06f8d354301ebb38b7
--- /dev/null
+++ b/enzevalos_iphone/AddressHandler.swift
@@ -0,0 +1,124 @@
+//
+//  AddressHandler.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 14.07.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import Foundation
+import Contacts
+import UIKit.UIImage
+
+class AddressHandler {
+    
+    static var addresses : [String] = ["jakob.bode@fu-berlin.de", "oliver.wiese@fu-berlin.de", "jo.lausch@fu-berlin.de", "test"]
+    static var freqAlgorithm : [String] -> [(UIImage, String, String, UIImage?, UIColor)] = {
+        (inserted : [String]) -> [(UIImage, String, String, UIImage?, UIColor)] in
+            /*do{
+                var cont = try AppDelegate.getAppDelegate().contactStore.unifiedContactsMatchingPredicate(CNContact.predicateForContactsMatchingName("Jakob Bode"), keysToFetch: [/*CNContactGivenNameKey, CNContactFamilyNameKey, CNContactMiddleNameKey*/CNContactFormatter.descriptorForRequiredKeysForStyle(CNContactFormatterStyle.FullName), CNContactEmailAddressesKey, CNContactImageDataKey, CNContactThumbnailImageDataKey])
+                return [(cont[cont.startIndex].getImageOrDefault(),"Jakob", "jakob.bode@fu-berlin.de"), (cont[cont.startIndex].getImageOrDefault(),"Jakob Bode", "jakob.bode@fu-berlin.de"), (cont[cont.startIndex].getImageOrDefault(),"Jakob B.", "jakob.bode@fu-berlin.de"), (cont[cont.startIndex].getImageOrDefault(),"Jakob Simon Bode", "jakob.bode@fu-berlin.de"), (cont[cont.startIndex].getImageOrDefault(),"Jakob", "jakob.bode@fu-berlin.de"), (cont[cont.startIndex].getImageOrDefault(),"Jakob Bode", "jakob.bode@fu-berlin.de"), (cont[cont.startIndex].getImageOrDefault(),"Jakob B.", "jakob.bode@fu-berlin.de"), (cont[cont.startIndex].getImageOrDefault(),"Jakob Simon Bode", "jakob.bode@fu-berlin.de")]
+            }
+            catch {
+                return []
+            }*/
+        var cons : [(UIImage,String,String,UIImage?,UIColor)] = []
+            do{
+                try AppDelegate.getAppDelegate().contactStore.enumerateContactsWithFetchRequest(CNContactFetchRequest(keysToFetch: [CNContactFormatter.descriptorForRequiredKeysForStyle(CNContactFormatterStyle.FullName), CNContactEmailAddressesKey, CNContactImageDataKey, CNContactThumbnailImageDataKey]), usingBlock: {
+                    (let c : CNContact, let stop) -> Void in
+                    print(c)
+                    for email in c.emailAddresses {
+                        let addr = email.value as! String
+                        var type : UIImage? = nil
+                        if c.emailAddresses.count > 1 {
+                            if email.label == "_$!<Work>!$_"{
+                                type = UIImage(named: "work2_white.png")!
+                            }
+                            else if email.label == "_$!<Home>!$_"{
+                                type = UIImage(named: "home2_white.png")!
+                            }
+                            else if email.label == "_$!<iCloud>!$_"{
+                                //TODO: appleIcon hinzufügen
+                            }
+                        }
+                        var color = c.getColor()
+                        if c.thumbnailImageData != nil {
+                            color = UIColor.grayColor() //blackColor()
+                        }
+                        if addr == "" {
+                            continue
+                        }
+                        if !inserted.contains(addr.lowercaseString) {
+                            if let name = CNContactFormatter.stringFromContact(c, style: .FullName) {
+                                    cons.append((c.getImageOrDefault(), name, addr, type, color))
+                            }
+                            else {
+                                cons.append((c.getImageOrDefault(), "NO NAME", addr, type, color))
+                            }
+                        }
+                    }
+                    })
+            }
+            catch {}
+        var list : [(UIImage,String,String,UIImage?,UIColor)] = []
+        var entrys = 10
+        if cons.count < entrys {
+            entrys = cons.count
+        }
+        if entrys <= 0 {
+            return []
+        }
+        for i in 0...entrys-1 {
+            //let index = abs(Int(arc4random())) % cons.count
+            let index = i % cons.count
+            list.append(cons[index])
+            cons.removeAtIndex(index)
+        }
+        
+        return list
+    }
+    
+    static func proveAddress(s : NSString) -> Bool {
+        if addresses.contains((s as String).lowercaseString){
+            return true
+        }
+        return inContacts(s as String)
+        //return false
+    }
+    
+    static func inContacts( name : String) -> Bool{
+        AppDelegate.getAppDelegate().requestForAccess({access in
+            print(access)
+        })
+        let authorizationStatus = CNContactStore.authorizationStatusForEntityType(CNEntityType.Contacts)
+        if authorizationStatus == CNAuthorizationStatus.Authorized {
+            do {
+                let conList = try AppDelegate.getAppDelegate().contactStore.unifiedContactsMatchingPredicate(CNContact.predicateForContactsMatchingName(name), keysToFetch: [CNContactGivenNameKey, CNContactFamilyNameKey])
+                for con in conList {
+                    print(con.givenName)
+                    print(con.familyName)
+                    
+                    if (con.givenName+con.familyName).stringByReplacingOccurrencesOfString(" ", withString: "") == name.stringByReplacingOccurrencesOfString(" ", withString: ""){
+                        return true
+                    }
+                }
+            }
+            catch {
+                print("exception")
+            }
+            print("contacts done")
+        }
+        else {
+            print("no Access!")
+        }
+        return false
+    }
+    
+    static func frequentAddresses (inserted : [String]) -> [(UIImage, String, String, UIImage?, UIColor)] {
+                                    /*[insertedEmail]             -> [(contactImage, name, address, emailLabelImage, backgroundcolor)]*/
+        //(persistente) liste von Kontakten abfragen
+        return freqAlgorithm(inserted)
+    }
+    
+    
+}
diff --git a/enzevalos_iphone/AppDelegate.swift b/enzevalos_iphone/AppDelegate.swift
index 4693f0aa40086473a2114fc0a7cd940ad7f443a4..e2a2a98022255f59ce6bc8a6f1eee46527fcfe6e 100644
--- a/enzevalos_iphone/AppDelegate.swift
+++ b/enzevalos_iphone/AppDelegate.swift
@@ -7,105 +7,89 @@
 //
 
 import UIKit
-import CoreData
+import Contacts
 
 @UIApplicationMain
 class AppDelegate: UIResponder, UIApplicationDelegate {
-
+    
     var window: UIWindow?
-
-
+    var contactStore = CNContactStore()
+    
     func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
         // Override point for customization after application launch.
+        //UINavigationBar.appearance().backgroundColor = UIColor.blueColor()
         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 inactive 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:.
-        // Saves changes in the application's managed object context before the application terminates.
-        self.saveContext()
     }
-
-    // MARK: - Core Data stack
-
-    lazy var applicationDocumentsDirectory: NSURL = {
-        // The directory the application uses to store the Core Data store file. This code uses a directory named "fu-berlin.enzevalos_iphone" in the application's documents Application Support directory.
-        let urls = NSFileManager.defaultManager().URLsForDirectory(.DocumentDirectory, inDomains: .UserDomainMask)
-        return urls[urls.count-1]
-    }()
-
-    lazy var managedObjectModel: NSManagedObjectModel = {
-        // The managed object model for the application. This property is not optional. It is a fatal error for the application not to be able to find and load its model.
-        let modelURL = NSBundle.mainBundle().URLForResource("enzevalos_iphone", withExtension: "momd")!
-        return NSManagedObjectModel(contentsOfURL: modelURL)!
-    }()
-
-    lazy var persistentStoreCoordinator: NSPersistentStoreCoordinator = {
-        // The persistent store coordinator for the application. This implementation creates and returns a coordinator, having added the store for the application to it. This property is optional since there are legitimate error conditions that could cause the creation of the store to fail.
-        // Create the coordinator and store
-        let coordinator = NSPersistentStoreCoordinator(managedObjectModel: self.managedObjectModel)
-        let url = self.applicationDocumentsDirectory.URLByAppendingPathComponent("SingleViewCoreData.sqlite")
-        var failureReason = "There was an error creating or loading the application's saved data."
-        do {
-            try coordinator.addPersistentStoreWithType(NSSQLiteStoreType, configuration: nil, URL: url, options: nil)
-        } catch {
-            // Report any error we got.
-            var dict = [String: AnyObject]()
-            dict[NSLocalizedDescriptionKey] = "Failed to initialize the application's saved data"
-            dict[NSLocalizedFailureReasonErrorKey] = failureReason
-
-            dict[NSUnderlyingErrorKey] = error as NSError
-            let wrappedError = NSError(domain: "YOUR_ERROR_DOMAIN", code: 9999, userInfo: dict)
-            // Replace this with code to handle the error appropriately.
-            // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
-            NSLog("Unresolved error \(wrappedError), \(wrappedError.userInfo)")
-            abort()
+    
+    
+    class func getAppDelegate() -> AppDelegate {
+        return UIApplication.sharedApplication().delegate as! AppDelegate
+    }
+    
+    
+    func showMessage(message: String) {
+        let alertController = UIAlertController(title: "enzevalos-send", message: message, preferredStyle: UIAlertControllerStyle.Alert)
+        
+        let dismissAction = UIAlertAction(title: "OK", style: UIAlertActionStyle.Default) { (action) -> Void in
         }
         
-        return coordinator
-    }()
-
-    lazy var managedObjectContext: NSManagedObjectContext = {
-        // Returns the managed object context for the application (which is already bound to the persistent store coordinator for the application.) This property is optional since there are legitimate error conditions that could cause the creation of the context to fail.
-        let coordinator = self.persistentStoreCoordinator
-        var managedObjectContext = NSManagedObjectContext(concurrencyType: .MainQueueConcurrencyType)
-        managedObjectContext.persistentStoreCoordinator = coordinator
-        return managedObjectContext
-    }()
-
-    // MARK: - Core Data Saving support
-
-    func saveContext () {
-        if managedObjectContext.hasChanges {
-            do {
-                try managedObjectContext.save()
-            } catch {
-                // Replace this implementation with code to handle the error appropriately.
-                // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
-                let nserror = error as NSError
-                NSLog("Unresolved error \(nserror), \(nserror.userInfo)")
-                abort()
-            }
+        alertController.addAction(dismissAction)
+        
+        let pushedViewControllers = (self.window?.rootViewController as! UINavigationController).viewControllers
+        let presentedViewController = pushedViewControllers[pushedViewControllers.count - 1]
+        
+        presentedViewController.presentViewController(alertController, animated: true, completion: nil)
+    }
+    
+    
+    func requestForAccess(completionHandler: (accessGranted: Bool) -> Void) {
+        let authorizationStatus = CNContactStore.authorizationStatusForEntityType(CNEntityType.Contacts)
+        
+        switch authorizationStatus {
+        case .Authorized:
+            completionHandler(accessGranted: true)
+            
+        case .Denied, .NotDetermined:
+            self.contactStore.requestAccessForEntityType(CNEntityType.Contacts, completionHandler: { (access, accessError) -> Void in
+                if access {
+                    completionHandler(accessGranted: access)
+                }
+                else {
+                    if authorizationStatus == CNAuthorizationStatus.Denied {
+                        dispatch_async(dispatch_get_main_queue(), { () -> Void in
+                            let message = "\(accessError!.localizedDescription)\n\nPlease allow the app to access your contacts through the Settings."
+                            self.showMessage(message)
+                        })
+                    }
+                }
+            })
+            
+        default:
+            completionHandler(accessGranted: false)
         }
     }
-
+    
 }
 
diff --git a/enzevalos_iphone/Assets.xcassets/Contents.json b/enzevalos_iphone/Assets.xcassets/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..da4a164c918651cdd1e11dca5cc62c333f097601
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/Contents.json
@@ -0,0 +1,6 @@
+{
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/letter.imageset/Contents.json b/enzevalos_iphone/Assets.xcassets/letter.imageset/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..52d4faccdfaf4e85650c81b64e08c679b642c2bd
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/letter.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+  "images" : [
+    {
+      "idiom" : "universal",
+      "filename" : "letter.png",
+      "scale" : "1x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "letter@2x.png",
+      "scale" : "2x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "letter@3x.png",
+      "scale" : "3x"
+    }
+  ],
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/letter.imageset/letter.png b/enzevalos_iphone/Assets.xcassets/letter.imageset/letter.png
new file mode 100644
index 0000000000000000000000000000000000000000..c88a7069a2d8651f539140e2af00516f4baaeae8
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter.imageset/letter.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/letter.imageset/letter@2x.png b/enzevalos_iphone/Assets.xcassets/letter.imageset/letter@2x.png
new file mode 100644
index 0000000000000000000000000000000000000000..73ed578d1aecf47ee03985560e42df0f4bbec028
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter.imageset/letter@2x.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/letter.imageset/letter@3x.png b/enzevalos_iphone/Assets.xcassets/letter.imageset/letter@3x.png
new file mode 100644
index 0000000000000000000000000000000000000000..6d5c15bf37c5a093184176cff557f8e962f796f9
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter.imageset/letter@3x.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/letter_corrupted.imageset/Contents.json b/enzevalos_iphone/Assets.xcassets/letter_corrupted.imageset/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..9533c6fed379ce2e3548e6d3576d628ce6c1863c
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/letter_corrupted.imageset/Contents.json
@@ -0,0 +1,21 @@
+{
+  "images" : [
+    {
+      "idiom" : "universal",
+      "scale" : "1x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "letter_corrupted.png",
+      "scale" : "2x"
+    },
+    {
+      "idiom" : "universal",
+      "scale" : "3x"
+    }
+  ],
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/letter_corrupted.imageset/letter_corrupted.png b/enzevalos_iphone/Assets.xcassets/letter_corrupted.imageset/letter_corrupted.png
new file mode 100644
index 0000000000000000000000000000000000000000..5a4795f5c6b9118c51b6f4349a7e9d76c4144395
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter_corrupted.imageset/letter_corrupted.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/letter_open.imageset/Contents.json b/enzevalos_iphone/Assets.xcassets/letter_open.imageset/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..51d341cd0bec83072ae6b5db2fb703eb114369e5
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/letter_open.imageset/Contents.json
@@ -0,0 +1,21 @@
+{
+  "images" : [
+    {
+      "idiom" : "universal",
+      "scale" : "1x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "letter_open.png",
+      "scale" : "2x"
+    },
+    {
+      "idiom" : "universal",
+      "scale" : "3x"
+    }
+  ],
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/letter_open.imageset/letter_open.png b/enzevalos_iphone/Assets.xcassets/letter_open.imageset/letter_open.png
new file mode 100644
index 0000000000000000000000000000000000000000..3d23915e7ffcebb3e7a194038ef01fa5b6ff2edc
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter_open.imageset/letter_open.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/letter_small.imageset/Contents.json b/enzevalos_iphone/Assets.xcassets/letter_small.imageset/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..a1ea07a645b59dcf33401f63bce320fcbb8ca679
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/letter_small.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+  "images" : [
+    {
+      "idiom" : "universal",
+      "filename" : "letter_small.png",
+      "scale" : "1x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "letter_small@2x.png",
+      "scale" : "2x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "letter_small@3x.png",
+      "scale" : "3x"
+    }
+  ],
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small.png b/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small.png
new file mode 100644
index 0000000000000000000000000000000000000000..a7a85121c57f420dd2144ff77dacb38a8311ae74
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small@2x.png b/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small@2x.png
new file mode 100644
index 0000000000000000000000000000000000000000..3df22e621584f4ec360a1ac27863a3744b34e488
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small@2x.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small@3x.png b/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small@3x.png
new file mode 100644
index 0000000000000000000000000000000000000000..6632cc198957449d7d61d59b558f4b7d54b3f09a
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter_small.imageset/letter_small@3x.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/letter_small_2.imageset/Contents.json b/enzevalos_iphone/Assets.xcassets/letter_small_2.imageset/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..1847838f2f05bf518189d68ad6613aa1d5fb801e
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/letter_small_2.imageset/Contents.json
@@ -0,0 +1,21 @@
+{
+  "images" : [
+    {
+      "idiom" : "universal",
+      "scale" : "1x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "letter_small_2@2x.png",
+      "scale" : "2x"
+    },
+    {
+      "idiom" : "universal",
+      "scale" : "3x"
+    }
+  ],
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/letter_small_2.imageset/letter_small_2@2x.png b/enzevalos_iphone/Assets.xcassets/letter_small_2.imageset/letter_small_2@2x.png
new file mode 100644
index 0000000000000000000000000000000000000000..7a1a9cbf419db1344ea5818d4a7975962d55e82f
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/letter_small_2.imageset/letter_small_2@2x.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/Contents.json b/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..a21bdcdfe7f1c6ccfc6e488629422d83adfd61f5
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+  "images" : [
+    {
+      "idiom" : "universal",
+      "filename" : "postcard.png",
+      "scale" : "1x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "postcard@2x.png",
+      "scale" : "2x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "postcard@3x.png",
+      "scale" : "3x"
+    }
+  ],
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard.png b/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard.png
new file mode 100644
index 0000000000000000000000000000000000000000..ad1c989b0ead954814d8971a2a1e20adca89becb
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard@2x.png b/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard@2x.png
new file mode 100644
index 0000000000000000000000000000000000000000..8f4d7e27bfc26965840b533a8b6004d7e7145491
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard@2x.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard@3x.png b/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard@3x.png
new file mode 100644
index 0000000000000000000000000000000000000000..ac7ab3714d800f82d7eaf7862c9b74531c8d0a11
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/postcard-1.imageset/postcard@3x.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/postcard.imageset/Contents.json b/enzevalos_iphone/Assets.xcassets/postcard.imageset/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..8403248082798605ae83174cd952b34d7b8ed0c5
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/postcard.imageset/Contents.json
@@ -0,0 +1,21 @@
+{
+  "images" : [
+    {
+      "idiom" : "universal",
+      "scale" : "1x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "postcard.png",
+      "scale" : "2x"
+    },
+    {
+      "idiom" : "universal",
+      "scale" : "3x"
+    }
+  ],
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/postcard.imageset/postcard.png b/enzevalos_iphone/Assets.xcassets/postcard.imageset/postcard.png
new file mode 100644
index 0000000000000000000000000000000000000000..a3e5f2fc5ca8eeb7be9c629852588b3a253e552d
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/postcard.imageset/postcard.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/Contents.json b/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/Contents.json
new file mode 100644
index 0000000000000000000000000000000000000000..713a1e17b2b5fa1fb8562d4b5f678f1fd4a877b1
--- /dev/null
+++ b/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/Contents.json
@@ -0,0 +1,23 @@
+{
+  "images" : [
+    {
+      "idiom" : "universal",
+      "filename" : "postcard_small.png",
+      "scale" : "1x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "postcard_small@2x.png",
+      "scale" : "2x"
+    },
+    {
+      "idiom" : "universal",
+      "filename" : "postcard_small@3x.png",
+      "scale" : "3x"
+    }
+  ],
+  "info" : {
+    "version" : 1,
+    "author" : "xcode"
+  }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small.png b/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small.png
new file mode 100644
index 0000000000000000000000000000000000000000..f5ab5c31a914003a0f8c618fc3906ae58bd896c1
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small@2x.png b/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small@2x.png
new file mode 100644
index 0000000000000000000000000000000000000000..060008e8098da67c4dc50894d0037aab79781e04
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small@2x.png differ
diff --git a/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small@3x.png b/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small@3x.png
new file mode 100644
index 0000000000000000000000000000000000000000..6aef695ef4c1c0af143c2f121ad8eadb1c90220c
Binary files /dev/null and b/enzevalos_iphone/Assets.xcassets/postcard_small.imageset/postcard_small@3x.png differ
diff --git a/enzevalos_iphone/Base.lproj/Main.storyboard b/enzevalos_iphone/Base.lproj/Main.storyboard
deleted file mode 100644
index 3a2a49bad8c615d719f891998e537cd29a001ec0..0000000000000000000000000000000000000000
--- a/enzevalos_iphone/Base.lproj/Main.storyboard
+++ /dev/null
@@ -1,25 +0,0 @@
-<?xml version="1.0" encoding="UTF-8" standalone="no"?>
-<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="6211" systemVersion="14A298i" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" initialViewController="BYZ-38-t0r">
-    <dependencies>
-        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="6204"/>
-    </dependencies>
-    <scenes>
-        <!--View Controller-->
-        <scene sceneID="tne-QT-ifu">
-            <objects>
-                <viewController id="BYZ-38-t0r" customClass="ViewController" 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="600" height="600"/>
-                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
-                        <color key="backgroundColor" white="1" alpha="1" colorSpace="custom" customColorSpace="calibratedWhite"/>
-                    </view>
-                </viewController>
-                <placeholder placeholderIdentifier="IBFirstResponder" id="dkx-z0-nzr" sceneMemberID="firstResponder"/>
-            </objects>
-        </scene>
-    </scenes>
-</document>
diff --git a/enzevalos_iphone/CollectionDataDelegate.swift b/enzevalos_iphone/CollectionDataDelegate.swift
new file mode 100644
index 0000000000000000000000000000000000000000..1a37774818b9a5e76a911dd88e5be7172e578c30
--- /dev/null
+++ b/enzevalos_iphone/CollectionDataDelegate.swift
@@ -0,0 +1,50 @@
+//
+//  CollectionDataDelegate.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 16.09.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import UIKit
+
+class CollectionDataDelegate : NSObject, UICollectionViewDataSource, UICollectionViewDelegate {
+    
+    var suggestionFunc : ([String] -> [(UIImage, String, String, UIImage?, UIColor)])
+                    //[bereits eingetragene emailadresse] -> [(Kontaktbild, Name, Emailadresse, emailTypeImage)]
+    var alreadyInserted : [String] = []
+    var insertCallback : (String, String) -> Void = {(name : String, address : String) -> Void in return}
+    
+    init(suggestionFunc: [String] -> [(UIImage, String, String, UIImage?, UIColor)], insertCallback : (String, String) -> Void){
+        self.suggestionFunc = suggestionFunc
+        self.insertCallback = insertCallback
+        super.init()
+    }
+    
+    func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
+        return suggestionFunc(alreadyInserted).count
+    }
+    
+    func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
+        print(indexPath.row)
+        let cell = collectionView.dequeueReusableCellWithReuseIdentifier("frequent", forIndexPath: indexPath) as! FrequentCell
+        cell.img.layer.cornerRadius = cell.img.frame.height/2
+        cell.img.clipsToBounds = true
+        cell.img.image = suggestionFunc(alreadyInserted)[indexPath.row].0
+        cell.name.text = suggestionFunc(alreadyInserted)[indexPath.row].1
+        cell.address = suggestionFunc(alreadyInserted)[indexPath.row].2
+        if suggestionFunc(alreadyInserted)[indexPath.row].3 != nil {
+            cell.type.image = suggestionFunc(alreadyInserted)[indexPath.row].3
+            cell.drawBackgroud(suggestionFunc(alreadyInserted)[indexPath.row].4)
+        }
+        else {
+            cell.type.image = UIImage()
+            cell.background.image = UIImage()
+        }
+        return cell
+    }
+    
+    func collectionView(collectionView: UICollectionView, didSelectItemAtIndexPath indexPath: NSIndexPath) {
+        insertCallback(suggestionFunc(alreadyInserted)[indexPath.row].1, suggestionFunc(alreadyInserted)[indexPath.row].2)
+    }
+}
diff --git a/enzevalos_iphone/ContactCell.swift b/enzevalos_iphone/ContactCell.swift
new file mode 100644
index 0000000000000000000000000000000000000000..97ac0048189902922e4cbef8004141ad99e4b2ed
--- /dev/null
+++ b/enzevalos_iphone/ContactCell.swift
@@ -0,0 +1,27 @@
+//
+//  ContactCell.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 01.09.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import Foundation
+import UIKit
+
+class ContactCell : UITableViewCell {
+    
+    @IBOutlet weak var name: UILabel!
+    @IBOutlet weak var address: UILabel!
+    @IBOutlet weak var img: UIImageView!
+    
+    /*init(){
+        super.init()
+        //super.init(style: UITableViewCellStyle(rawValue: 1)!, reuseIdentifier: "contacts")
+    }*/
+    
+    /*required init?(coder aDecoder: NSCoder) {
+        super.init(coder: aDecoder)
+    }*/
+    
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/ContactCell.xib b/enzevalos_iphone/ContactCell.xib
new file mode 100644
index 0000000000000000000000000000000000000000..fa2165aae41823f6c6203bdf25294903ad1e7a58
--- /dev/null
+++ b/enzevalos_iphone/ContactCell.xib
@@ -0,0 +1,49 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="10117" systemVersion="15G1004" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES">
+    <dependencies>
+        <deployment identifier="iOS"/>
+        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="10085"/>
+        <capability name="Constraints to layout margins" minToolsVersion="6.0"/>
+    </dependencies>
+    <objects>
+        <placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
+        <placeholder placeholderIdentifier="IBFirstResponder" id="-2" customClass="UIResponder"/>
+        <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" selectionStyle="default" indentationWidth="10" reuseIdentifier="contacts" rowHeight="70" id="Xly-Kn-P4y" customClass="ContactCell" customModule="mail_dynamic_icon_001" customModuleProvider="target">
+            <rect key="frame" x="0.0" y="0.0" width="320" height="69"/>
+            <autoresizingMask key="autoresizingMask"/>
+            <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" tableViewCell="Xly-Kn-P4y" id="pxY-cN-hIw">
+                <rect key="frame" x="0.0" y="0.0" width="320" height="68"/>
+                <autoresizingMask key="autoresizingMask"/>
+                <subviews>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="adresse" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="63D-rq-tu0" userLabel="adresse">
+                        <rect key="frame" x="78" y="38" width="61" height="21"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                        <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="name" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="dA3-a3-Xug">
+                        <rect key="frame" x="78" y="8" width="43" height="21"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                        <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <imageView userInteractionEnabled="NO" contentMode="scaleToFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" fixedFrame="YES" translatesAutoresizingMaskIntoConstraints="NO" id="PhZ-Xe-rcO">
+                        <rect key="frame" x="5" y="5" width="60" height="60"/>
+                    </imageView>
+                </subviews>
+                <constraints>
+                    <constraint firstItem="63D-rq-tu0" firstAttribute="leading" secondItem="pxY-cN-hIw" secondAttribute="leadingMargin" constant="70" id="BHB-gN-DRV"/>
+                    <constraint firstItem="dA3-a3-Xug" firstAttribute="leading" secondItem="pxY-cN-hIw" secondAttribute="leadingMargin" constant="70" id="ClI-9o-aP2"/>
+                    <constraint firstAttribute="topMargin" secondItem="dA3-a3-Xug" secondAttribute="top" id="mFZ-y7-2G5"/>
+                    <constraint firstAttribute="bottomMargin" secondItem="63D-rq-tu0" secondAttribute="bottom" constant="1" id="yHC-En-yY9"/>
+                </constraints>
+            </tableViewCellContentView>
+            <connections>
+                <outlet property="address" destination="63D-rq-tu0" id="Zna-eA-HWh"/>
+                <outlet property="img" destination="PhZ-Xe-rcO" id="pAL-Xa-0ZL"/>
+                <outlet property="name" destination="dA3-a3-Xug" id="ny0-YB-pPn"/>
+            </connections>
+            <point key="canvasLocation" x="571" y="-5.5"/>
+        </tableViewCell>
+    </objects>
+</document>
diff --git a/enzevalos_iphone/EnzevalosContact.swift b/enzevalos_iphone/EnzevalosContact.swift
new file mode 100644
index 0000000000000000000000000000000000000000..932f500386fae5b5bdcc01d76abf1886136c9a76
--- /dev/null
+++ b/enzevalos_iphone/EnzevalosContact.swift
@@ -0,0 +1,35 @@
+//
+//  EnzevalosContact.swift
+//  readView
+//
+//  Created by Joscha on 12.09.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+import Foundation
+import Contacts
+
+class EnzevalosContact: Comparable {
+    let contact: CNContact
+    var mails: [Mail] {
+        didSet {
+            self.mails.sortInPlace()
+        }
+    }
+    
+    var isVerified: Bool
+    
+    init(contact: CNContact, mails: [Mail]) {
+        self.contact = contact
+        self.mails = mails.sort()
+        self.isVerified = false
+    }
+}
+
+func ==(lhs: EnzevalosContact, rhs: EnzevalosContact) -> Bool {
+    return lhs.mails.maxElement()!.time == rhs.mails.maxElement()!.time
+}
+
+func <(lhs: EnzevalosContact, rhs: EnzevalosContact) -> Bool {
+    return lhs.mails.maxElement()!.time > rhs.mails.maxElement()!.time
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/FillInbox.swift b/enzevalos_iphone/FillInbox.swift
new file mode 100644
index 0000000000000000000000000000000000000000..bec596fed58c948630bda5e8a954499b686d2b8e
--- /dev/null
+++ b/enzevalos_iphone/FillInbox.swift
@@ -0,0 +1,55 @@
+//
+//  FillInbox.swift
+//  readView
+//
+//  Created by Joscha on 12.09.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+import Foundation
+import Contacts
+
+func generateMail() -> [EnzevalosContact] {
+    let cons = ["Hans", "Tina", "Anna", "Martin", "Jakob", "Elisabet", "Susi", "Eva", "Joscha"]
+    let sur = ["Jürgen", "T.", "Lotte", "Schulzenheimer", "Bode", "Sue", "Koch", "Fuchs", "Lausch"]
+    let emails = ["hans@web.de", "tina@mail.com", "anni@hotmail.com", "martin.schulzenheimer@googlemail.com", "jakob.bode@fu-berlin.de", "eli.sue@mail.com", "susi92@gmail.com", "eva.fuchs@fu-berlin.de", "joscha.lausch@fu-berlin.de"]
+    let subjects = ["Good seing you!", "Nice meeting you", "Grüße aus Malle", "WTF happend?!", "You need to see this", "Hey!", "Fahrrad", "Umfrage", " ", "Einladung zur Verteidigung meiner Bachelorarbeit", "Had a great time!", "Reiseplanung", "How are you?", "Probleme...", "well...", "Re: (no subject)", "Grüße", "Yosemite Trip", "Paper Submission", "Backpacking through Europe"]
+    let lorem = "Lorem ipsum dolor sit amet, consectetur adipisici elit, sed eiusmod tempor incidunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquid ex ea commodi consequat. Quis aute iure reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint obcaecat cupiditat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum." + "\n\n" + "Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat." + "\n\n" + "Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat. Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent luptatum zzril delenit augue duis dolore te feugait nulla facilisi." + "/n/n" + "Nam liber tempor cum soluta nobis eleifend option congue nihil imperdiet doming id quod mazim placerat facer possim assum. Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat. Ut wisi enim ad minim veniam, quis nostrud exerci tation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat."
+    
+    var contacts: [EnzevalosContact] = []
+    
+    for c in (0..<cons.count) {
+        let con = CNMutableContact()
+        con.givenName = cons[c]
+        con.familyName = sur[c]
+        con.emailAddresses = [CNLabeledValue(label: CNLabelWork, value: emails[c])]
+        
+        let dateFormatter = NSDateFormatter()
+        dateFormatter.dateFormat = "dd-MM-yyyy HH:mm"
+        
+        var mails: [Mail] = []
+        
+        let encrypted = randBool()
+        
+        for _ in (0..<arc4random_uniform(3)+1) {
+            var date: NSDate?
+            repeat {
+            let d = "\(10 + arc4random_uniform(22))-0\(arc4random_uniform(9)+1)-201\(arc4random_uniform(7)) \(arc4random_uniform(3))\(arc4random_uniform(10)):\(arc4random_uniform(6))\(arc4random_uniform(10))"
+            date = dateFormatter.dateFromString(d)
+            } while(date == nil)
+            
+            let mail = Mail(sender: emails[c], receivers: ["bob@web.de", emails[Int(arc4random_uniform(UInt32(emails.count)))]], time: date, received: true, subject: subjects[Int(arc4random_uniform(UInt32(subjects.count)))], body: lorem, isEncrypted: encrypted, isVerified: false, trouble: false)
+            mail.isUnread = randBool()
+            
+            mails.append(mail)
+        }
+        
+        contacts.append(EnzevalosContact(contact: con, mails: mails))
+    }
+    
+    return contacts
+}
+
+func randBool() -> Bool {
+    return arc4random_uniform(2) == 0 ? true: false
+}
diff --git a/enzevalos_iphone/FrequentCell.swift b/enzevalos_iphone/FrequentCell.swift
new file mode 100644
index 0000000000000000000000000000000000000000..94a3222dc8d437d1dbafe8b2e516a24af4d51ca3
--- /dev/null
+++ b/enzevalos_iphone/FrequentCell.swift
@@ -0,0 +1,48 @@
+//
+//  FrequentCell.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 10.09.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import UIKit
+
+class FrequentCell : UICollectionViewCell {
+    @IBOutlet weak var img: UIImageView!
+    @IBOutlet weak var name: UILabel!
+    @IBOutlet weak var type: UIImageView!
+    @IBOutlet weak var background: UIImageView!
+    
+    var address = ""
+    var identifier = ""
+    
+    func drawBackgroud(color : UIColor){
+        var myBounds = CGRect()
+        myBounds.size.width = 70
+        myBounds.size.height = 70
+        UIGraphicsBeginImageContextWithOptions(myBounds.size, false, 2) //try 200 here
+        
+        let context = UIGraphicsGetCurrentContext()
+        
+        //
+        // Clip context to a circle
+        //
+        let path = CGPathCreateWithEllipseInRect(myBounds, nil);
+        CGContextAddPath(context, path);
+        CGContextClip(context);
+        
+        
+        //
+        // Fill background of context
+        //
+        CGContextSetFillColorWithColor(context, color.CGColor)
+        CGContextFillRect(context, CGRectMake(0, 0, myBounds.size.width, myBounds.size.height));
+        
+        let snapshot = UIGraphicsGetImageFromCurrentImageContext();
+        UIGraphicsEndImageContext();
+        
+        self.background.image = snapshot
+    }
+    
+}
diff --git a/enzevalos_iphone/FrequentCell.xib b/enzevalos_iphone/FrequentCell.xib
new file mode 100644
index 0000000000000000000000000000000000000000..2a68aebb4d86b30c6ba1ef7eb3830fb567e13988
--- /dev/null
+++ b/enzevalos_iphone/FrequentCell.xib
@@ -0,0 +1,58 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="10117" systemVersion="15G1004" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES">
+    <dependencies>
+        <deployment identifier="iOS"/>
+        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="10085"/>
+    </dependencies>
+    <objects>
+        <placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
+        <placeholder placeholderIdentifier="IBFirstResponder" id="-2" customClass="UIResponder"/>
+        <collectionViewCell opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" reuseIdentifier="frequent" id="w2v-x8-dyj" customClass="FrequentCell" customModule="mail_dynamic_icon_001" customModuleProvider="target">
+            <rect key="frame" x="0.0" y="0.0" width="90" height="90"/>
+            <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
+            <view key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center">
+                <rect key="frame" x="0.0" y="0.0" width="90" height="90"/>
+                <autoresizingMask key="autoresizingMask"/>
+                <subviews>
+                    <imageView userInteractionEnabled="NO" contentMode="scaleToFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="EAf-Ln-NIo">
+                        <rect key="frame" x="10" y="0.0" width="60" height="70"/>
+                        <constraints>
+                            <constraint firstAttribute="height" constant="70" id="QGM-0P-eJO"/>
+                        </constraints>
+                    </imageView>
+                    <imageView userInteractionEnabled="NO" contentMode="scaleToFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" fixedFrame="YES" translatesAutoresizingMaskIntoConstraints="NO" id="2IJ-xu-7fu" userLabel="background">
+                        <rect key="frame" x="60" y="41" width="28" height="29"/>
+                    </imageView>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" misplaced="YES" text="Label" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="PpF-WH-X3b">
+                        <rect key="frame" x="24" y="74" width="33" height="16"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="13"/>
+                        <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <imageView userInteractionEnabled="NO" contentMode="scaleToFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" fixedFrame="YES" translatesAutoresizingMaskIntoConstraints="NO" id="0Km-aB-hr6">
+                        <rect key="frame" x="64" y="45" width="20" height="20"/>
+                        <color key="tintColor" red="0.0" green="0.47843137250000001" blue="1" alpha="1" colorSpace="calibratedRGB"/>
+                    </imageView>
+                </subviews>
+                <color key="backgroundColor" white="0.0" alpha="0.0" colorSpace="calibratedWhite"/>
+            </view>
+            <constraints>
+                <constraint firstItem="PpF-WH-X3b" firstAttribute="leading" relation="greaterThanOrEqual" secondItem="w2v-x8-dyj" secondAttribute="leading" constant="5" id="3br-Vm-olJ"/>
+                <constraint firstAttribute="trailing" secondItem="EAf-Ln-NIo" secondAttribute="trailing" constant="10" id="7ga-yh-RtT"/>
+                <constraint firstAttribute="bottom" secondItem="PpF-WH-X3b" secondAttribute="bottom" id="FO3-Bu-Mfq" userLabel="bottom = Name.bottom"/>
+                <constraint firstItem="PpF-WH-X3b" firstAttribute="centerX" secondItem="w2v-x8-dyj" secondAttribute="centerX" id="J0p-Wn-JmD"/>
+                <constraint firstItem="PpF-WH-X3b" firstAttribute="top" secondItem="EAf-Ln-NIo" secondAttribute="bottom" constant="4" id="q6O-5t-WCb"/>
+                <constraint firstItem="EAf-Ln-NIo" firstAttribute="top" secondItem="w2v-x8-dyj" secondAttribute="top" id="tSd-gS-rCL"/>
+                <constraint firstItem="EAf-Ln-NIo" firstAttribute="leading" secondItem="w2v-x8-dyj" secondAttribute="leading" constant="10" id="wBg-8I-TqR" userLabel="Img.leading = leading + 5"/>
+            </constraints>
+            <size key="customSize" width="80" height="90"/>
+            <connections>
+                <outlet property="background" destination="2IJ-xu-7fu" id="Ahm-dc-bst"/>
+                <outlet property="img" destination="EAf-Ln-NIo" id="gE0-Xg-UZI"/>
+                <outlet property="name" destination="PpF-WH-X3b" id="6vF-Jw-RGP"/>
+                <outlet property="type" destination="0Km-aB-hr6" id="EAI-t3-kHM"/>
+            </connections>
+            <point key="canvasLocation" x="825" y="210"/>
+        </collectionViewCell>
+    </objects>
+</document>
diff --git a/enzevalos_iphone/Icon_animated001-001.png b/enzevalos_iphone/Icon_animated001-001.png
new file mode 100755
index 0000000000000000000000000000000000000000..80cec683413a0bb87da0ea3741fc9143403c8d72
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-001.png differ
diff --git a/enzevalos_iphone/Icon_animated001-001_alpha.png b/enzevalos_iphone/Icon_animated001-001_alpha.png
new file mode 100755
index 0000000000000000000000000000000000000000..5661191e07ed50af1a285b0c076f9616ab02abdf
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-001_alpha.png differ
diff --git a/enzevalos_iphone/Icon_animated001-001_alpha_breit.png b/enzevalos_iphone/Icon_animated001-001_alpha_breit.png
new file mode 100755
index 0000000000000000000000000000000000000000..41c5f7cacf07cbb91e9dd4f600da7e5b9a454647
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-001_alpha_breit.png differ
diff --git a/enzevalos_iphone/Icon_animated001-001_alpha_verschoben-90.png b/enzevalos_iphone/Icon_animated001-001_alpha_verschoben-90.png
new file mode 100755
index 0000000000000000000000000000000000000000..5f2c7eebe8aac675788da7aa80deefb87d65eeb7
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-001_alpha_verschoben-90.png differ
diff --git a/enzevalos_iphone/Icon_animated001-002.png b/enzevalos_iphone/Icon_animated001-002.png
new file mode 100755
index 0000000000000000000000000000000000000000..3378dd7dbbaecc590903f010c18d880c564a7ad6
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-002.png differ
diff --git a/enzevalos_iphone/Icon_animated001-002_alpha.png b/enzevalos_iphone/Icon_animated001-002_alpha.png
new file mode 100755
index 0000000000000000000000000000000000000000..9daec15e7b87f5471e76c297fe8b99bc3348a11e
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-002_alpha.png differ
diff --git a/enzevalos_iphone/Icon_animated001-002_alpha_verschoben-90.png b/enzevalos_iphone/Icon_animated001-002_alpha_verschoben-90.png
new file mode 100755
index 0000000000000000000000000000000000000000..564dd0c9c5d97d61483e8488277890eb92699cc5
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-002_alpha_verschoben-90.png differ
diff --git a/enzevalos_iphone/Icon_animated001-003.png b/enzevalos_iphone/Icon_animated001-003.png
new file mode 100755
index 0000000000000000000000000000000000000000..b146d0056ff10f5f0b45bedefbd7fe82454c8873
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-003.png differ
diff --git a/enzevalos_iphone/Icon_animated001-003_alpha.png b/enzevalos_iphone/Icon_animated001-003_alpha.png
new file mode 100755
index 0000000000000000000000000000000000000000..99d7d8a2f127f2cb8050146a5e3d6ff76a532176
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-003_alpha.png differ
diff --git a/enzevalos_iphone/Icon_animated001-003_alpha_verschoben-90.png b/enzevalos_iphone/Icon_animated001-003_alpha_verschoben-90.png
new file mode 100755
index 0000000000000000000000000000000000000000..3e29dccfbd88adaec07f459f63a543e5f7b6dc68
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-003_alpha_verschoben-90.png differ
diff --git a/enzevalos_iphone/Icon_animated001-004.png b/enzevalos_iphone/Icon_animated001-004.png
new file mode 100755
index 0000000000000000000000000000000000000000..b826bd4c65e2bcb2800dabf4843625953d870309
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-004.png differ
diff --git a/enzevalos_iphone/Icon_animated001-004_alpha.png b/enzevalos_iphone/Icon_animated001-004_alpha.png
new file mode 100755
index 0000000000000000000000000000000000000000..3fa46b42b146968028e6ba74b1fef7bc2ac4f14e
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-004_alpha.png differ
diff --git a/enzevalos_iphone/Icon_animated001-004_alpha_verschoben-90.png b/enzevalos_iphone/Icon_animated001-004_alpha_verschoben-90.png
new file mode 100755
index 0000000000000000000000000000000000000000..e1eb4dee906131e909d0a2306bbdf6081f88bde2
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-004_alpha_verschoben-90.png differ
diff --git a/enzevalos_iphone/Icon_animated001-005.png b/enzevalos_iphone/Icon_animated001-005.png
new file mode 100755
index 0000000000000000000000000000000000000000..c9d57b274a2f489f43619975a32b4dba3fd91ae5
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-005.png differ
diff --git a/enzevalos_iphone/Icon_animated001-005_alpha.png b/enzevalos_iphone/Icon_animated001-005_alpha.png
new file mode 100755
index 0000000000000000000000000000000000000000..38d203abae42e80fc7ea6165d784bc72370914c7
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-005_alpha.png differ
diff --git a/enzevalos_iphone/Icon_animated001-005_alpha_verschoben-90.png b/enzevalos_iphone/Icon_animated001-005_alpha_verschoben-90.png
new file mode 100755
index 0000000000000000000000000000000000000000..25d02d9b3fe81f930dd28f8e8e6db73bbe5b7bcf
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-005_alpha_verschoben-90.png differ
diff --git a/enzevalos_iphone/Icon_animated001-006.png b/enzevalos_iphone/Icon_animated001-006.png
new file mode 100755
index 0000000000000000000000000000000000000000..f73c760724a67c91e0f809550a7187205169f61a
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-006.png differ
diff --git a/enzevalos_iphone/Icon_animated001-006_alpha.png b/enzevalos_iphone/Icon_animated001-006_alpha.png
new file mode 100755
index 0000000000000000000000000000000000000000..22cd5df8a3a1148a6e931efdce77e21ec809ddf5
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-006_alpha.png differ
diff --git a/enzevalos_iphone/Icon_animated001-006_alpha_verschoben-90.png b/enzevalos_iphone/Icon_animated001-006_alpha_verschoben-90.png
new file mode 100755
index 0000000000000000000000000000000000000000..8295c5c72bb17fdf2a048b88ce6be537022a062d
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-006_alpha_verschoben-90.png differ
diff --git a/enzevalos_iphone/Icon_animated001-007.png b/enzevalos_iphone/Icon_animated001-007.png
new file mode 100755
index 0000000000000000000000000000000000000000..ddb43e438a7ce162f9a24bfb03de98793aa9d7d3
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-007.png differ
diff --git a/enzevalos_iphone/Icon_animated001-007_alpha.png b/enzevalos_iphone/Icon_animated001-007_alpha.png
new file mode 100755
index 0000000000000000000000000000000000000000..b763b9b5e0b276d2aa75f33bb15d684b55c56765
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-007_alpha.png differ
diff --git a/enzevalos_iphone/Icon_animated001-007_alpha_verschoben-90.png b/enzevalos_iphone/Icon_animated001-007_alpha_verschoben-90.png
new file mode 100755
index 0000000000000000000000000000000000000000..48355f4e3b6469fe66f9a6045f08ed6b56471597
Binary files /dev/null and b/enzevalos_iphone/Icon_animated001-007_alpha_verschoben-90.png differ
diff --git a/enzevalos_iphone/ImageExtension.swift b/enzevalos_iphone/ImageExtension.swift
new file mode 100644
index 0000000000000000000000000000000000000000..767b963842cf12031a81e2ae3446a7530d398f7d
--- /dev/null
+++ b/enzevalos_iphone/ImageExtension.swift
@@ -0,0 +1,72 @@
+//
+//  ImageExtension.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 09.09.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import UIKit
+import Contacts
+
+extension CNContact {
+    func getImageOrDefault() -> UIImage{
+        if (self.thumbnailImageData != nil) {
+            return UIImage(data : self.thumbnailImageData!)!
+        }
+        //let scale = UIScreen.mainScreen().scale
+        var text : NSAttributedString
+        if self.givenName.startIndex != self.givenName.endIndex && self.familyName.startIndex != self.familyName.endIndex {
+            text = NSAttributedString(string: self.givenName.substringToIndex(self.givenName.startIndex.successor())+""+self.familyName.substringToIndex(self.familyName.startIndex.successor()), attributes: [NSForegroundColorAttributeName : UIColor.whiteColor(), NSFontAttributeName : UIFont.systemFontOfSize(32.2 /*UIFont.systemFontSize()*2.3*/)]) //string: self.givenName.substringToIndex()+""+self.familyName.substringToIndex(self.familyName.startIndex.successor()))
+        }
+        else if self.givenName.startIndex != self.givenName.endIndex {
+            text = NSAttributedString(string: self.givenName.substringToIndex(self.givenName.startIndex.successor()), attributes: [NSForegroundColorAttributeName : UIColor.whiteColor(), NSFontAttributeName : UIFont.systemFontOfSize(32.2)])
+        }
+        else if self.familyName.startIndex != self.familyName.endIndex {
+            text = NSAttributedString(string: self.familyName.substringToIndex(self.familyName.startIndex.successor()), attributes: [NSForegroundColorAttributeName : UIColor.whiteColor(), NSFontAttributeName : UIFont.systemFontOfSize(32.2)])
+        }
+        else {
+            text = NSAttributedString(string: (self.emailAddresses.last?.value as! String).substringToIndex((self.emailAddresses.last?.value as! String).startIndex.successor()).capitalizedString, attributes: [NSForegroundColorAttributeName : UIColor.whiteColor(), NSFontAttributeName : UIFont.systemFontOfSize(32.2)])
+        }
+        //size.width = floorf(size.width * scale) / scale;
+        //size.height = floorf(size.height * scale) / scale;
+        
+        var myBounds = CGRect()
+        myBounds.size.width = 70
+        myBounds.size.height = 70
+        UIGraphicsBeginImageContextWithOptions(myBounds.size, false, 2) //try 200 here
+        
+        let context = UIGraphicsGetCurrentContext()
+        
+        //
+        // Clip context to a circle
+        //
+        let path = CGPathCreateWithEllipseInRect(myBounds, nil);
+        CGContextAddPath(context, path);
+        CGContextClip(context);
+        
+        
+        //
+        // Fill background of context
+        //
+        CGContextSetFillColorWithColor(context, self.getColor().CGColor)
+        CGContextFillRect(context, CGRectMake(0, 0, myBounds.size.width, myBounds.size.height));
+        
+        //
+        // Draw text in the context
+        //
+        let textSize = text.size()
+        
+        text.drawInRect(CGRectMake(myBounds.size.width/2 - textSize.width/2, myBounds.size.height/2 - textSize.height/2,textSize.width, textSize.height))
+        
+        let snapshot = UIGraphicsGetImageFromCurrentImageContext();
+        UIGraphicsEndImageContext();
+        return snapshot
+    }
+    
+    func getColor() -> UIColor{
+        
+        srand(UInt32(abs((self.emailAddresses.last!.value as! String).hash) % Int(UInt32.max)))
+        return UIColor(hue: CGFloat(rand()) / CGFloat(INT_MAX), saturation: 1, brightness: 0.75, alpha: 1)
+    }
+}
diff --git a/enzevalos_iphone/InboxCellDelegator.swift b/enzevalos_iphone/InboxCellDelegator.swift
new file mode 100644
index 0000000000000000000000000000000000000000..f2546a91d5ff5c29d71d4df31235345d7758744a
--- /dev/null
+++ b/enzevalos_iphone/InboxCellDelegator.swift
@@ -0,0 +1,11 @@
+//
+//  InboxCellDelegator.swift
+//  readView
+//
+//  Created by Joscha on 09.09.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+protocol InboxCellDelegator {
+    func callSegueFromCell(mail: Mail?)
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/InboxTableViewCell.swift b/enzevalos_iphone/InboxTableViewCell.swift
new file mode 100644
index 0000000000000000000000000000000000000000..baa49946592d758e14e1a9e426f9f598817f928a
--- /dev/null
+++ b/enzevalos_iphone/InboxTableViewCell.swift
@@ -0,0 +1,140 @@
+//
+//  InboxTableViewCell.swift
+//  readView
+//
+//  Created by Joscha on 29.08.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+import UIKit
+import Contacts
+
+class InboxTableViewCell: UITableViewCell {
+    var delegate: InboxCellDelegator?
+    
+    @IBOutlet weak var nameLabel: UILabel!
+    @IBOutlet weak var faceView: UIImageView!
+    @IBOutlet weak var iconView: UIImageView!
+    @IBOutlet weak var firstSubjectLabel: UILabel!
+    @IBOutlet weak var firstMessageLabel: UILabel!
+    @IBOutlet weak var firstDateLabel: UILabel!
+    @IBOutlet weak var firstButton: UIButton!
+    @IBOutlet weak var secondSubjectLabel: UILabel!
+    @IBOutlet weak var secondMessageLabel: UILabel!
+    @IBOutlet weak var secondDateLabel: UILabel!
+    @IBOutlet weak var secondButton: UIButton!
+    @IBOutlet weak var moreButton: UIButton!
+    
+    @IBAction func firstButtonPressed(sender: AnyObject) {
+        if let delegate = delegate where firstMail != nil {
+            enzContact?.mails.maxElement()?.isUnread = false
+            delegate.callSegueFromCell(firstMail)
+        }
+    }
+    
+    @IBAction func secondButtonPressed(sender: AnyObject) {
+        if let delegate = delegate where secondMail != nil{
+            secondMail!.isUnread = false
+            delegate.callSegueFromCell(secondMail)
+        }
+    }
+    
+    @IBAction func moreButtonPressed(sender: AnyObject) {
+    }
+    
+    var enzContact: EnzevalosContact? {
+        didSet {
+            if let con = enzContact {
+                self.firstMail = con.mails.last
+                if con.mails.count > 1 {
+                    self.secondMail = con.mails[con.mails.endIndex - 2]
+                }
+                self.contact = con.contact
+            }
+        }
+    }
+    
+    var firstMail: Mail? {
+        didSet {
+            if let mail = firstMail {
+                if mail.isUnread {
+                    firstSubjectLabel.font = UIFont.boldSystemFontOfSize(17.0)
+                } else {
+                    firstSubjectLabel.font = UIFont.systemFontOfSize(17.0)
+                }
+                
+                if let subj = mail.subject {
+                    if subj != "" && subj != " " {
+                        firstSubjectLabel.text = subj
+                    } else {
+                        firstSubjectLabel.text = "(Kein Betreff)"
+                    }
+                }
+                
+                // Reducing message to one line and truncating to 50
+                let message: String
+                if mail.body?.characters.count > 50 {
+                    message = mail.body!.substringToIndex(mail.body!.startIndex.advancedBy(50))
+                } else {
+                    message = mail.body!
+                }
+                let messageArray = message.componentsSeparatedByString("\n")
+                firstMessageLabel.text = messageArray.joinWithSeparator(" ")
+                
+                firstDateLabel.text = mail.timeString
+            }
+        }
+    }
+    
+    var secondMail: Mail? {
+        didSet {
+            if let mail = secondMail {
+                if mail.isUnread {
+                    secondSubjectLabel.font = UIFont.boldSystemFontOfSize(17.0)
+                } else {
+                    secondSubjectLabel.font = UIFont.systemFontOfSize(17.0)
+                }
+                
+                if let subj = mail.subject {
+                    if subj != "" && subj != " " {
+                        secondSubjectLabel.text = subj
+                    } else {
+                        secondSubjectLabel.text = "(Kein Betreff)"
+                    }
+                }
+                
+                // Reducing message to one line and truncating to 50
+                let message: String
+                if mail.body?.characters.count > 50 {
+                    message = mail.body!.substringToIndex(mail.body!.startIndex.advancedBy(50))
+                } else {
+                    message = mail.body!
+                }
+                let messageArray = message.componentsSeparatedByString("\n")
+                secondMessageLabel.text = messageArray.joinWithSeparator(" ")
+               
+                secondDateLabel.text = mail.timeString
+                
+                moreButton.enabled = true
+            }
+        }
+    }
+    
+    var contact: CNContact? {
+        didSet {
+            if let con = contact {
+                nameLabel.text = con.givenName + " " + con.familyName
+                faceView.image = con.getImageOrDefault()
+                faceView.layer.cornerRadius = faceView.frame.height / 2
+                faceView.clipsToBounds = true
+                if let m = firstMail {
+                    if m.isEncrypted {
+                        iconView.image = UIImage(named: "letter_small_2")!
+                    } else {
+                        iconView.image = UIImage(named: "postcard_small")!
+                    }
+                }
+            }
+        }
+    }
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/InboxTableViewCell.xib b/enzevalos_iphone/InboxTableViewCell.xib
new file mode 100644
index 0000000000000000000000000000000000000000..018a311946541c4f9929e45d0ab4e2db952785ac
--- /dev/null
+++ b/enzevalos_iphone/InboxTableViewCell.xib
@@ -0,0 +1,207 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<document type="com.apple.InterfaceBuilder3.CocoaTouch.XIB" version="3.0" toolsVersion="10117" systemVersion="15G1004" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES">
+    <dependencies>
+        <deployment identifier="iOS"/>
+        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="10085"/>
+        <capability name="Constraints to layout margins" minToolsVersion="6.0"/>
+    </dependencies>
+    <objects>
+        <placeholder placeholderIdentifier="IBFilesOwner" id="-1" userLabel="File's Owner"/>
+        <placeholder placeholderIdentifier="IBFirstResponder" id="-2" customClass="UIResponder"/>
+        <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" selectionStyle="default" indentationWidth="10" reuseIdentifier="inboxCell" rowHeight="130" id="CFu-ns-kay" userLabel="inboxCell" customClass="InboxTableViewCell" customModule="enzevalos_iphone" customModuleProvider="target">
+            <rect key="frame" x="0.0" y="0.0" width="400" height="130"/>
+            <autoresizingMask key="autoresizingMask"/>
+            <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" tableViewCell="CFu-ns-kay" id="iQP-01-jFC" userLabel="Container">
+                <rect key="frame" x="0.0" y="0.0" width="400" height="129"/>
+                <autoresizingMask key="autoresizingMask"/>
+                <subviews>
+                    <imageView userInteractionEnabled="NO" contentMode="scaleAspectFit" horizontalHuggingPriority="251" verticalHuggingPriority="251" translatesAutoresizingMaskIntoConstraints="NO" id="uDO-9h-a86" userLabel="Icon View">
+                        <rect key="frame" x="64" y="8" width="30" height="30"/>
+                        <constraints>
+                            <constraint firstAttribute="width" constant="30" id="Zf5-eH-DtF"/>
+                            <constraint firstAttribute="height" constant="30" id="n7I-Eu-a0k"/>
+                        </constraints>
+                    </imageView>
+                    <button opaque="NO" contentMode="scaleToFill" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="Woe-Z6-TzX" userLabel="First Row">
+                        <rect key="frame" x="102" y="8" width="298" height="37"/>
+                        <connections>
+                            <action selector="firstButtonPressed:" destination="CFu-ns-kay" eventType="touchUpInside" id="YFb-kT-nNt"/>
+                        </connections>
+                    </button>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Betreff" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="XJ6-AX-Txg">
+                        <rect key="frame" x="102" y="14" width="53" height="21"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                        <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalCompressionResistancePriority="749" verticalCompressionResistancePriority="749" misplaced="YES" text="Nachricht" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="TqY-sR-0LV">
+                        <rect key="frame" x="163" y="17" width="175" height="16"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="13"/>
+                        <color key="textColor" white="0.66666666666666663" alpha="1" colorSpace="calibratedWhite"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="252" verticalHuggingPriority="252" horizontalCompressionResistancePriority="751" verticalCompressionResistancePriority="751" misplaced="YES" text="Datum" textAlignment="right" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="Nu7-tF-hGe">
+                        <rect key="frame" x="346" y="15" width="46" height="18"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="15"/>
+                        <color key="textColor" red="0.43529411759999997" green="0.4431372549" blue="0.47450980390000003" alpha="1" colorSpace="calibratedRGB"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <view contentMode="scaleToFill" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="6Ac-fp-DaH" userLabel="Seperator">
+                        <rect key="frame" x="102" y="44" width="298" height="1"/>
+                        <color key="backgroundColor" white="0.66666666666666663" alpha="1" colorSpace="calibratedWhite"/>
+                        <constraints>
+                            <constraint firstAttribute="height" constant="0.5" id="4mk-1j-mQw"/>
+                        </constraints>
+                    </view>
+                    <button opaque="NO" contentMode="scaleToFill" verticalHuggingPriority="249" misplaced="YES" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="d9Z-AX-rvb" userLabel="Second Row">
+                        <rect key="frame" x="102" y="45" width="298" height="41"/>
+                        <connections>
+                            <action selector="secondButtonPressed:" destination="CFu-ns-kay" eventType="touchUpInside" id="bkj-Q4-ZwY"/>
+                        </connections>
+                    </button>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" misplaced="YES" text="" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="aNQ-sk-gux">
+                        <rect key="frame" x="102" y="55" width="0.0" height="21"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                        <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalCompressionResistancePriority="749" verticalCompressionResistancePriority="749" misplaced="YES" text="Keine weiteren Nachrichten..." textAlignment="center" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="5es-fE-2Ig">
+                        <rect key="frame" x="110" y="59" width="274" height="16"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="13"/>
+                        <color key="textColor" white="0.66666666666666663" alpha="1" colorSpace="calibratedWhite"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="252" horizontalCompressionResistancePriority="751" verticalCompressionResistancePriority="751" misplaced="YES" text="" textAlignment="right" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="p7w-rZ-MsF">
+                        <rect key="frame" x="392" y="75" width="0.0" height="0.0"/>
+                        <fontDescription key="fontDescription" type="system" pointSize="15"/>
+                        <color key="textColor" red="0.43529411759999997" green="0.4431372549" blue="0.47450980390000003" alpha="1" colorSpace="calibratedRGB"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <view contentMode="scaleToFill" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="KQh-Jo-J47" userLabel="Seperator">
+                        <rect key="frame" x="102" y="86" width="298" height="1"/>
+                        <color key="backgroundColor" white="0.66666666666666663" alpha="1" colorSpace="calibratedWhite"/>
+                        <constraints>
+                            <constraint firstAttribute="height" constant="0.5" id="iGw-4L-rQm"/>
+                        </constraints>
+                    </view>
+                    <button opaque="NO" contentMode="scaleToFill" verticalHuggingPriority="249" enabled="NO" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="fkg-yw-zDk" userLabel="More Button">
+                        <rect key="frame" x="104" y="93" width="288" height="28"/>
+                        <constraints>
+                            <constraint firstAttribute="height" priority="250" constant="38" id="PkY-uX-CRO"/>
+                        </constraints>
+                        <fontDescription key="fontDescription" type="system" pointSize="13"/>
+                        <state key="normal" title="Mehr E-Mails von diesem Kontakt">
+                            <color key="titleColor" red="0.43529411759999997" green="0.4431372549" blue="0.47450980390000003" alpha="1" colorSpace="calibratedRGB"/>
+                        </state>
+                        <connections>
+                            <action selector="moreButtonPressed:" destination="CFu-ns-kay" eventType="touchUpInside" id="twS-jf-JDL"/>
+                        </connections>
+                    </button>
+                    <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" misplaced="YES" text="Name" textAlignment="center" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsLetterSpacingToFitWidth="YES" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="ixt-EX-9TM">
+                        <rect key="frame" x="8" y="90" width="86" height="32"/>
+                        <constraints>
+                            <constraint firstAttribute="height" constant="32" id="r0W-bg-uj9"/>
+                        </constraints>
+                        <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                        <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                        <nil key="highlightedColor"/>
+                    </label>
+                    <imageView userInteractionEnabled="NO" contentMode="scaleToFill" horizontalHuggingPriority="251" verticalHuggingPriority="251" translatesAutoresizingMaskIntoConstraints="NO" id="WNp-Ty-Hv1">
+                        <rect key="frame" x="16" y="16" width="70" height="70"/>
+                        <constraints>
+                            <constraint firstAttribute="height" constant="70" id="Bei-PK-STi"/>
+                            <constraint firstAttribute="width" constant="70" id="Tid-sz-S35"/>
+                        </constraints>
+                    </imageView>
+                </subviews>
+                <constraints>
+                    <constraint firstItem="Woe-Z6-TzX" firstAttribute="leading" secondItem="6Ac-fp-DaH" secondAttribute="trailing" constant="-498" id="1Xo-Rd-5M9"/>
+                    <constraint firstAttribute="trailingMargin" secondItem="Woe-Z6-TzX" secondAttribute="trailing" constant="-8" id="24I-L1-Mzk"/>
+                    <constraint firstItem="fkg-yw-zDk" firstAttribute="baseline" secondItem="ixt-EX-9TM" secondAttribute="baseline" id="3V1-HQ-wBb"/>
+                    <constraint firstItem="aNQ-sk-gux" firstAttribute="leading" secondItem="XJ6-AX-Txg" secondAttribute="leading" id="3pz-w9-dLY"/>
+                    <constraint firstItem="Woe-Z6-TzX" firstAttribute="leading" secondItem="6Ac-fp-DaH" secondAttribute="trailing" constant="-498" id="4uw-Gk-HBI"/>
+                    <constraint firstItem="KQh-Jo-J47" firstAttribute="top" secondItem="aNQ-sk-gux" secondAttribute="bottom" constant="8" id="5Xa-ur-flk"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="top" secondItem="XJ6-AX-Txg" secondAttribute="bottom" constant="10" id="7Jc-Fa-yCt"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="leading" secondItem="KQh-Jo-J47" secondAttribute="leading" id="8Bu-SI-3wf"/>
+                    <constraint firstAttribute="leadingMargin" secondItem="WNp-Ty-Hv1" secondAttribute="leading" constant="-8" id="8Qz-qU-0pQ"/>
+                    <constraint firstItem="5es-fE-2Ig" firstAttribute="centerX" secondItem="6Ac-fp-DaH" secondAttribute="centerX" id="9S7-qb-FGm"/>
+                    <constraint firstItem="Nu7-tF-hGe" firstAttribute="centerY" secondItem="XJ6-AX-Txg" secondAttribute="centerY" id="9xe-VP-4Ml"/>
+                    <constraint firstItem="ixt-EX-9TM" firstAttribute="top" secondItem="aNQ-sk-gux" secondAttribute="bottom" constant="17" id="AhO-j2-beE"/>
+                    <constraint firstItem="ixt-EX-9TM" firstAttribute="centerX" secondItem="WNp-Ty-Hv1" secondAttribute="centerX" priority="750" id="AoH-YY-Rat"/>
+                    <constraint firstAttribute="trailingMargin" secondItem="fkg-yw-zDk" secondAttribute="trailing" id="BTc-bK-iUs"/>
+                    <constraint firstAttribute="trailingMargin" secondItem="KQh-Jo-J47" secondAttribute="trailing" constant="-8" id="CUy-27-K5C"/>
+                    <constraint firstItem="uDO-9h-a86" firstAttribute="leading" secondItem="WNp-Ty-Hv1" secondAttribute="trailing" constant="-22" id="Ep6-8a-mxu"/>
+                    <constraint firstAttribute="bottomMargin" secondItem="ixt-EX-9TM" secondAttribute="bottom" id="HJW-m3-xQf"/>
+                    <constraint firstAttribute="trailingMargin" secondItem="Nu7-tF-hGe" secondAttribute="trailing" id="Iun-11-1dU"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="leading" secondItem="iQP-01-jFC" secondAttribute="leadingMargin" constant="94" id="JmJ-3n-YQE"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="leading" secondItem="XJ6-AX-Txg" secondAttribute="leading" id="K4E-pM-i1g"/>
+                    <constraint firstAttribute="topMargin" secondItem="Woe-Z6-TzX" secondAttribute="top" id="M24-q2-8rU"/>
+                    <constraint firstItem="5es-fE-2Ig" firstAttribute="baseline" secondItem="aNQ-sk-gux" secondAttribute="baseline" priority="996" id="MIK-Lm-sHl"/>
+                    <constraint firstAttribute="trailingMargin" secondItem="p7w-rZ-MsF" secondAttribute="trailing" id="MU1-O9-owp"/>
+                    <constraint firstItem="p7w-rZ-MsF" firstAttribute="baseline" secondItem="aNQ-sk-gux" secondAttribute="baseline" id="PnO-9W-e9y"/>
+                    <constraint firstAttribute="topMargin" secondItem="WNp-Ty-Hv1" secondAttribute="top" constant="-8" id="Ssn-ty-fGT"/>
+                    <constraint firstItem="fkg-yw-zDk" firstAttribute="top" secondItem="KQh-Jo-J47" secondAttribute="bottom" priority="750" id="Uja-D9-x7G"/>
+                    <constraint firstAttribute="trailingMargin" secondItem="d9Z-AX-rvb" secondAttribute="trailing" constant="-8" id="Wi7-cb-bZM"/>
+                    <constraint firstAttribute="bottomMargin" secondItem="fkg-yw-zDk" secondAttribute="bottom" priority="750" id="Wpi-eN-8Jj"/>
+                    <constraint firstItem="5es-fE-2Ig" firstAttribute="top" secondItem="6Ac-fp-DaH" secondAttribute="bottom" priority="999" constant="14" id="XsK-mj-NRJ"/>
+                    <constraint firstItem="TqY-sR-0LV" firstAttribute="leading" secondItem="XJ6-AX-Txg" secondAttribute="trailing" constant="8" symbolic="YES" id="Y9Z-b9-Ca2"/>
+                    <constraint firstItem="fkg-yw-zDk" firstAttribute="leading" secondItem="ixt-EX-9TM" secondAttribute="trailing" constant="10" id="YJm-fA-Eel"/>
+                    <constraint firstItem="d9Z-AX-rvb" firstAttribute="leading" secondItem="XJ6-AX-Txg" secondAttribute="leading" id="Z7w-xf-juK"/>
+                    <constraint firstItem="5es-fE-2Ig" firstAttribute="leading" secondItem="aNQ-sk-gux" secondAttribute="trailing" priority="750" constant="8" symbolic="YES" id="Z9J-Kl-kAw"/>
+                    <constraint firstItem="p7w-rZ-MsF" firstAttribute="centerY" secondItem="aNQ-sk-gux" secondAttribute="centerY" id="eUr-AB-yat"/>
+                    <constraint firstItem="KQh-Jo-J47" firstAttribute="top" secondItem="d9Z-AX-rvb" secondAttribute="bottom" id="fax-Ug-Gtq"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="top" secondItem="Woe-Z6-TzX" secondAttribute="bottom" id="huP-C3-y9c"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="leading" secondItem="KQh-Jo-J47" secondAttribute="trailing" constant="-438" id="ide-90-fIG"/>
+                    <constraint firstItem="Nu7-tF-hGe" firstAttribute="baseline" secondItem="XJ6-AX-Txg" secondAttribute="baseline" id="lQy-MO-OWJ"/>
+                    <constraint firstItem="KQh-Jo-J47" firstAttribute="top" secondItem="aNQ-sk-gux" secondAttribute="bottom" constant="10" id="lmp-y0-nyw"/>
+                    <constraint firstItem="Nu7-tF-hGe" firstAttribute="leading" secondItem="TqY-sR-0LV" secondAttribute="trailing" constant="8" symbolic="YES" id="nQC-RK-V7a"/>
+                    <constraint firstItem="Woe-Z6-TzX" firstAttribute="leading" secondItem="XJ6-AX-Txg" secondAttribute="leading" id="nkk-hf-1Ge"/>
+                    <constraint firstItem="XJ6-AX-Txg" firstAttribute="top" secondItem="iQP-01-jFC" secondAttribute="topMargin" constant="6" id="nvi-xd-cL6"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="leading" secondItem="KQh-Jo-J47" secondAttribute="trailing" constant="-438" id="oKz-Cf-6UQ"/>
+                    <constraint firstItem="aNQ-sk-gux" firstAttribute="top" secondItem="6Ac-fp-DaH" secondAttribute="bottom" constant="10" id="qKv-R6-ynv"/>
+                    <constraint firstItem="fkg-yw-zDk" firstAttribute="leading" secondItem="XJ6-AX-Txg" secondAttribute="leading" id="qer-0w-0TL"/>
+                    <constraint firstItem="uDO-9h-a86" firstAttribute="top" secondItem="WNp-Ty-Hv1" secondAttribute="top" constant="-8" id="siS-Qd-beD"/>
+                    <constraint firstItem="d9Z-AX-rvb" firstAttribute="top" secondItem="6Ac-fp-DaH" secondAttribute="bottom" id="tsm-JK-Ujt"/>
+                    <constraint firstItem="ixt-EX-9TM" firstAttribute="leading" secondItem="iQP-01-jFC" secondAttribute="leadingMargin" id="u8S-bU-zXa"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="leading" secondItem="iQP-01-jFC" secondAttribute="leadingMargin" constant="89" id="vYu-LF-pbM"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="trailing" secondItem="iQP-01-jFC" secondAttribute="trailingMargin" constant="8" id="wHQ-Nz-VYd"/>
+                    <constraint firstItem="p7w-rZ-MsF" firstAttribute="leading" secondItem="5es-fE-2Ig" secondAttribute="trailing" constant="8" symbolic="YES" id="wYe-q1-WND"/>
+                    <constraint firstItem="TqY-sR-0LV" firstAttribute="baseline" secondItem="XJ6-AX-Txg" secondAttribute="baseline" id="wa5-el-UNS"/>
+                    <constraint firstItem="6Ac-fp-DaH" firstAttribute="leading" secondItem="aNQ-sk-gux" secondAttribute="leading" id="zSF-rV-CGG"/>
+                </constraints>
+                <variation key="default">
+                    <mask key="constraints">
+                        <exclude reference="AhO-j2-beE"/>
+                        <exclude reference="1Xo-Rd-5M9"/>
+                        <exclude reference="4uw-Gk-HBI"/>
+                        <exclude reference="ide-90-fIG"/>
+                        <exclude reference="oKz-Cf-6UQ"/>
+                        <exclude reference="vYu-LF-pbM"/>
+                        <exclude reference="3pz-w9-dLY"/>
+                        <exclude reference="9S7-qb-FGm"/>
+                        <exclude reference="5Xa-ur-flk"/>
+                        <exclude reference="Uja-D9-x7G"/>
+                        <exclude reference="qer-0w-0TL"/>
+                        <exclude reference="9xe-VP-4Ml"/>
+                        <exclude reference="eUr-AB-yat"/>
+                    </mask>
+                </variation>
+            </tableViewCellContentView>
+            <connections>
+                <outlet property="faceView" destination="WNp-Ty-Hv1" id="Ssc-6w-kf8"/>
+                <outlet property="firstButton" destination="Woe-Z6-TzX" id="Ahx-bF-jSu"/>
+                <outlet property="firstDateLabel" destination="Nu7-tF-hGe" id="VJA-Yx-I96"/>
+                <outlet property="firstMessageLabel" destination="TqY-sR-0LV" id="noH-8s-f28"/>
+                <outlet property="firstSubjectLabel" destination="XJ6-AX-Txg" id="3Xb-sI-UII"/>
+                <outlet property="iconView" destination="uDO-9h-a86" id="ttd-FW-t8t"/>
+                <outlet property="moreButton" destination="fkg-yw-zDk" id="AR8-zr-k0v"/>
+                <outlet property="nameLabel" destination="ixt-EX-9TM" id="V5h-q6-Ket"/>
+                <outlet property="secondButton" destination="d9Z-AX-rvb" id="xTR-2p-T3j"/>
+                <outlet property="secondDateLabel" destination="p7w-rZ-MsF" id="Jyc-1T-uMO"/>
+                <outlet property="secondMessageLabel" destination="5es-fE-2Ig" id="5Ll-tV-0ei"/>
+                <outlet property="secondSubjectLabel" destination="aNQ-sk-gux" id="UBN-6y-n4E"/>
+            </connections>
+            <point key="canvasLocation" x="-175" y="180"/>
+        </tableViewCell>
+    </objects>
+</document>
diff --git a/enzevalos_iphone/InboxViewController.swift b/enzevalos_iphone/InboxViewController.swift
new file mode 100644
index 0000000000000000000000000000000000000000..ee4c39b9001e5d3e94e707fbfc65d01a21b468d0
--- /dev/null
+++ b/enzevalos_iphone/InboxViewController.swift
@@ -0,0 +1,73 @@
+//
+//  InboxViewController.swift
+//  readView
+//
+//  Created by Joscha on 26.08.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+import UIKit
+import Foundation
+import Contacts
+
+class InboxViewController : UITableViewController, InboxCellDelegator {
+    var contacts: [EnzevalosContact] = []
+    
+    override func viewDidLoad() {
+        super.viewDidLoad()
+        
+        tableView.sectionHeaderHeight = 1
+        tableView.sectionFooterHeight = 0
+        
+        contacts = generateMail()
+        contacts.sortInPlace()
+        
+        tableView.registerNib(UINib(nibName: "InboxTableViewCell", bundle: nil), forCellReuseIdentifier: "inboxCell")
+    }
+    
+    override func viewWillAppear(animated: Bool) {
+        tableView.reloadData()
+    }
+    
+    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
+        return 1
+    }
+    
+    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
+        let cell = tableView.dequeueReusableCellWithIdentifier("inboxCell", forIndexPath: indexPath) as! InboxTableViewCell
+        
+        cell.delegate = self
+        cell.enzContact = contacts[indexPath.section]
+
+        return cell
+    }
+    
+    override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
+        return contacts.count
+    }
+    
+    // set top and bottom seperator height
+    override func tableView(tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {
+        if section == 0 {
+            return 0.01
+        }
+        return tableView.sectionHeaderHeight
+    }
+    
+    override func tableView(tableView: UITableView, heightForFooterInSection section: Int) -> CGFloat {
+        return 0.01
+    }
+    
+    func callSegueFromCell(mail: Mail?) {
+        performSegueWithIdentifier("readMailSegue", sender: mail)
+    }
+    
+    override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
+        if segue.identifier == "readMailSegue" {
+            if let mail = sender as? Mail {
+                let DestinationViewController: ReadViewController = segue.destinationViewController as! ReadViewController
+                DestinationViewController.mail = mail
+            }
+        }
+    }    
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/MailHandler.swift b/enzevalos_iphone/MailHandler.swift
new file mode 100644
index 0000000000000000000000000000000000000000..2b7527a8d52a72a4a8736b00e8c8b715d05f78b7
--- /dev/null
+++ b/enzevalos_iphone/MailHandler.swift
@@ -0,0 +1,67 @@
+//
+//  MailHandler.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 22.08.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import Foundation
+
+class MailHandler {
+    var user = "Alice"
+    var useraddr = "alice2005@web.de"
+    var pw = "WJ$CE:EtUo3E$"
+    
+    var hostname = "smtp.web.de"
+    var port : UInt32 = 587
+    
+    //TODO: signatur hinzufügen
+    
+    
+    //return if send successfully
+    func send(toEntrys : [String], ccEntrys : [String], bccEntrys : [String], subject : String, message : String, callback : (NSError?) -> Void){
+        //http://stackoverflow.com/questions/31485359/sending-mailcore2-plain-emails-in-swift
+        
+        /*let session =  MCOSMTPSession()
+        session.hostname = hostname
+        session.port = port
+        session.username = useraddr
+        session.password = pw
+        session.authType = MCOAuthType.SASLPlain
+        session.connectionType = MCOConnectionType.StartTLS
+        
+        let builder = MCOMessageBuilder()
+        
+        var toReady : [MCOAddress] = []
+        for addr in toEntrys {
+            toReady.append(MCOAddress(displayName: addr, mailbox: addr))
+        }
+        builder.header.to = toReady
+        
+        var ccReady : [MCOAddress] = []
+        for addr in ccEntrys {
+            ccReady.append(MCOAddress(displayName: addr, mailbox: addr))
+        }
+        builder.header.cc = ccReady
+        
+        var bccReady : [MCOAddress] = []
+        for addr in bccEntrys {
+            bccReady.append(MCOAddress(displayName: addr, mailbox: addr))
+        }
+        builder.header.bcc = bccReady
+        
+        builder.header.from = MCOAddress(displayName: user, mailbox:
+            useraddr)
+        
+        builder.header.subject = subject
+        
+        builder.htmlBody = message
+        
+        let rfc822Data = builder.data()
+        let sendOperation = session.sendOperationWithData(rfc822Data)
+        
+        sendOperation.start(callback)*/
+    }
+    
+}
diff --git a/enzevalos_iphone/MailObject.swift b/enzevalos_iphone/MailObject.swift
new file mode 100644
index 0000000000000000000000000000000000000000..bce4b850e9c94fa2063876ff8464fa2625cf0fda
--- /dev/null
+++ b/enzevalos_iphone/MailObject.swift
@@ -0,0 +1,80 @@
+//
+//  MailObject.swift
+//  readView
+//
+//  Created by Joscha on 22.07.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+import Foundation
+
+class Mail: Comparable {
+    var sender: String?
+    var receivers = [String]()
+    let time: NSDate?
+    let received: Bool
+    var subject: String?
+    var body: String?
+    var isUnread = true
+    var isVerified = false
+    var isEncrypted = false
+    var showMessage = true
+    var trouble = true {
+        didSet{
+            if trouble {
+                showMessage = false
+            } else {
+                showMessage = true
+            }
+        }
+    }
+    var timeString: String {
+        var returnString = ""
+        let dateFormatter = NSDateFormatter()
+        dateFormatter.locale = NSLocale(localeIdentifier: "de_DE")
+        if let mailTime = self.time {
+            switch mailTime.timeIntervalSinceNow {
+            case -1..<55:
+                returnString = "jetzt"
+            case 55..<120:
+                returnString = "vor 1 min"
+            case 120..<24*60*60:
+                dateFormatter.timeStyle = .ShortStyle
+                returnString = dateFormatter.stringFromDate(mailTime)
+            case 24*60*60..<48*60*60:
+                returnString = "Gestern"
+            case 48*60*60..<72*60*60:
+                returnString = "Vorgestern"
+            default:
+                dateFormatter.dateStyle = .ShortStyle
+                returnString = dateFormatter.stringFromDate(mailTime)
+            }
+        }
+        return returnString
+    }
+
+    init(sender: String?, receivers: [String], time: NSDate?, received: Bool, subject: String?, body: String?, isEncrypted: Bool, isVerified: Bool, trouble: Bool) {
+        self.sender = sender
+        self.subject = subject
+        self.receivers = receivers
+        self.time = time
+        self.received = received
+        self.subject = subject
+        self.body = body
+        self.isEncrypted = isEncrypted
+        self.isVerified = isVerified
+        setTrouble(trouble)
+    }
+    
+    func setTrouble(trouble: Bool) {
+        self.trouble = trouble
+    }
+}
+
+func ==(lhs: Mail, rhs: Mail) -> Bool {
+    return lhs.time == rhs.time
+}
+
+func <(lhs: Mail, rhs: Mail) -> Bool {
+    return lhs.time < rhs.time
+}
\ No newline at end of file
diff --git a/enzevalos_iphone/Main.storyboard b/enzevalos_iphone/Main.storyboard
new file mode 100644
index 0000000000000000000000000000000000000000..986583015059c90a051a9e6be3d9a3b334080dd8
--- /dev/null
+++ b/enzevalos_iphone/Main.storyboard
@@ -0,0 +1,364 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<document type="com.apple.InterfaceBuilder3.CocoaTouch.Storyboard.XIB" version="3.0" toolsVersion="10117" systemVersion="15G1004" targetRuntime="iOS.CocoaTouch" propertyAccessControl="none" useAutolayout="YES" useTraitCollections="YES" initialViewController="Amm-QN-vA7">
+    <dependencies>
+        <deployment identifier="iOS"/>
+        <plugIn identifier="com.apple.InterfaceBuilder.IBCocoaTouchPlugin" version="10085"/>
+        <capability name="Constraints to layout margins" minToolsVersion="6.0"/>
+    </dependencies>
+    <scenes>
+        <!--Read View Controller-->
+        <scene sceneID="JLe-qS-U0P">
+            <objects>
+                <tableViewController id="Ouw-WD-EV6" customClass="ReadViewController" customModule="readView" sceneMemberID="viewController">
+                    <tableView key="view" clipsSubviews="YES" contentMode="scaleToFill" alwaysBounceVertical="YES" dataMode="static" style="grouped" separatorStyle="default" allowsSelection="NO" rowHeight="44" sectionHeaderHeight="8" sectionFooterHeight="1" id="oZT-OA-Re5">
+                        <rect key="frame" x="0.0" y="0.0" width="600" height="600"/>
+                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
+                        <color key="backgroundColor" red="0.93725490199999995" green="0.93725490199999995" blue="0.95686274510000002" alpha="1" colorSpace="calibratedRGB"/>
+                        <sections>
+                            <tableViewSection id="2HO-mI-ZLL">
+                                <cells>
+                                    <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" selectionStyle="none" indentationWidth="10" id="lSe-Gv-7SL">
+                                        <rect key="frame" x="0.0" y="99" width="600" height="44"/>
+                                        <autoresizingMask key="autoresizingMask"/>
+                                        <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" tableViewCell="lSe-Gv-7SL" id="Zam-cw-cBg">
+                                            <rect key="frame" x="0.0" y="0.0" width="600" height="43"/>
+                                            <autoresizingMask key="autoresizingMask"/>
+                                            <subviews>
+                                                <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Von:" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="Yii-bz-1Cd">
+                                                    <rect key="frame" x="15" y="20" width="35" height="21"/>
+                                                    <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                                                    <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                                <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Absender" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="YIc-GU-Crs">
+                                                    <rect key="frame" x="58" y="13" width="534" height="29"/>
+                                                    <fontDescription key="fontDescription" type="system" pointSize="24"/>
+                                                    <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                            </subviews>
+                                            <constraints>
+                                                <constraint firstItem="YIc-GU-Crs" firstAttribute="width" secondItem="Zam-cw-cBg" secondAttribute="width" constant="-66" id="Dkd-fU-UBk"/>
+                                                <constraint firstItem="YIc-GU-Crs" firstAttribute="leading" secondItem="Zam-cw-cBg" secondAttribute="leadingMargin" constant="50" id="IV6-EH-9DA"/>
+                                                <constraint firstItem="Yii-bz-1Cd" firstAttribute="leading" secondItem="Zam-cw-cBg" secondAttribute="leadingMargin" constant="7" id="Lba-q3-xGX"/>
+                                                <constraint firstAttribute="topMargin" secondItem="Yii-bz-1Cd" secondAttribute="top" id="Wce-le-hJx"/>
+                                                <constraint firstAttribute="topMargin" secondItem="YIc-GU-Crs" secondAttribute="top" constant="7" id="kn0-V2-c1Y"/>
+                                            </constraints>
+                                            <edgeInsets key="layoutMargins" top="20" left="8" bottom="8" right="8"/>
+                                        </tableViewCellContentView>
+                                        <accessibility key="accessibilityConfiguration">
+                                            <accessibilityTraits key="traits" notEnabled="YES"/>
+                                        </accessibility>
+                                    </tableViewCell>
+                                    <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" selectionStyle="none" indentationWidth="10" textLabel="okf-3B-Nb6" detailTextLabel="Sdq-CE-2Do" style="IBUITableViewCellStyleValue1" id="ZjK-3s-N2G">
+                                        <rect key="frame" x="0.0" y="143" width="600" height="44"/>
+                                        <autoresizingMask key="autoresizingMask"/>
+                                        <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="center" tableViewCell="ZjK-3s-N2G" id="nTH-P7-ZD7">
+                                            <rect key="frame" x="0.0" y="0.0" width="600" height="43"/>
+                                            <autoresizingMask key="autoresizingMask"/>
+                                            <subviews>
+                                                <label opaque="NO" multipleTouchEnabled="YES" contentMode="left" horizontalCompressionResistancePriority="250" verticalCompressionResistancePriority="250" text="Title" textAlignment="natural" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" id="okf-3B-Nb6">
+                                                    <rect key="frame" x="15" y="12" width="32" height="20"/>
+                                                    <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
+                                                    <fontDescription key="fontDescription" type="system" pointSize="16"/>
+                                                    <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                                <label opaque="NO" multipleTouchEnabled="YES" contentMode="left" horizontalCompressionResistancePriority="751" verticalCompressionResistancePriority="751" text="Detail" textAlignment="right" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" id="Sdq-CE-2Do">
+                                                    <rect key="frame" x="543" y="12" width="42" height="20"/>
+                                                    <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
+                                                    <fontDescription key="fontDescription" type="system" pointSize="16"/>
+                                                    <color key="textColor" red="0.55686274509803924" green="0.55686274509803924" blue="0.57647058823529407" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                            </subviews>
+                                        </tableViewCellContentView>
+                                    </tableViewCell>
+                                    <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" selectionStyle="none" indentationWidth="10" id="HpI-HP-usd">
+                                        <rect key="frame" x="0.0" y="187" width="600" height="44"/>
+                                        <autoresizingMask key="autoresizingMask"/>
+                                        <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" userInteractionEnabled="NO" contentMode="center" tableViewCell="HpI-HP-usd" id="kAy-AZ-pKo">
+                                            <rect key="frame" x="0.0" y="0.0" width="600" height="43"/>
+                                            <autoresizingMask key="autoresizingMask"/>
+                                            <subviews>
+                                                <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Betreff" lineBreakMode="wordWrap" numberOfLines="0" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="Ywe-G2-0wJ">
+                                                    <rect key="frame" x="15" y="12" width="573" height="21"/>
+                                                    <accessibility key="accessibilityConfiguration">
+                                                        <accessibilityTraits key="traits" none="YES"/>
+                                                    </accessibility>
+                                                    <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                                                    <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                            </subviews>
+                                            <constraints>
+                                                <constraint firstItem="Ywe-G2-0wJ" firstAttribute="top" secondItem="kAy-AZ-pKo" secondAttribute="topMargin" constant="4" id="LTH-Nh-db6"/>
+                                                <constraint firstAttribute="trailingMargin" secondItem="Ywe-G2-0wJ" secondAttribute="trailing" constant="4" id="aFd-Ii-7v7"/>
+                                                <constraint firstItem="Ywe-G2-0wJ" firstAttribute="leading" secondItem="kAy-AZ-pKo" secondAttribute="leadingMargin" constant="7" id="kH7-Ta-mh5"/>
+                                                <constraint firstAttribute="bottomMargin" secondItem="Ywe-G2-0wJ" secondAttribute="bottom" constant="2.5" id="w5B-6h-ECY"/>
+                                            </constraints>
+                                        </tableViewCellContentView>
+                                    </tableViewCell>
+                                </cells>
+                            </tableViewSection>
+                            <tableViewSection id="VxN-4m-yDL">
+                                <cells>
+                                    <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" selectionStyle="none" indentationWidth="10" rowHeight="72" id="hiO-mC-dXs">
+                                        <rect key="frame" x="0.0" y="240" width="600" height="72"/>
+                                        <autoresizingMask key="autoresizingMask"/>
+                                        <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" tableViewCell="hiO-mC-dXs" id="gEu-X7-3M0">
+                                            <rect key="frame" x="0.0" y="0.0" width="600" height="71"/>
+                                            <autoresizingMask key="autoresizingMask"/>
+                                            <subviews>
+                                                <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Achtung!" textAlignment="center" lineBreakMode="tailTruncation" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="7LX-pr-0Pd">
+                                                    <rect key="frame" x="252" y="11" width="97" height="20"/>
+                                                    <constraints>
+                                                        <constraint firstAttribute="width" constant="97" id="0iB-La-r8H"/>
+                                                    </constraints>
+                                                    <fontDescription key="fontDescription" style="UICTFontTextStyleHeadline"/>
+                                                    <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                                <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="Diese E-Mail könnte verändert worden sein! Bitte misstrauen Sie dem Inhalt, falls Sie ihn trotzdem lesen möchten. " textAlignment="natural" lineBreakMode="wordWrap" numberOfLines="0" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="lYr-bv-gD0">
+                                                    <rect key="frame" x="64" y="35" width="528" height="21"/>
+                                                    <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                                                    <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                                <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" text="!" textAlignment="center" lineBreakMode="wordWrap" numberOfLines="0" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="4Fp-ob-0Ch">
+                                                    <rect key="frame" x="8" y="12" width="48" height="51"/>
+                                                    <constraints>
+                                                        <constraint firstAttribute="width" constant="48" id="LZf-Eq-e1R"/>
+                                                    </constraints>
+                                                    <fontDescription key="fontDescription" type="system" pointSize="72"/>
+                                                    <color key="textColor" red="1" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                            </subviews>
+                                            <constraints>
+                                                <constraint firstItem="lYr-bv-gD0" firstAttribute="trailing" secondItem="gEu-X7-3M0" secondAttribute="trailingMargin" id="6Wg-SV-LJX"/>
+                                                <constraint firstItem="7LX-pr-0Pd" firstAttribute="centerY" secondItem="gEu-X7-3M0" secondAttribute="centerY" id="Br2-cc-MD6"/>
+                                                <constraint firstItem="lYr-bv-gD0" firstAttribute="top" secondItem="gEu-X7-3M0" secondAttribute="topMargin" constant="15" id="GM6-xa-TxG"/>
+                                                <constraint firstAttribute="bottomMargin" secondItem="lYr-bv-gD0" secondAttribute="bottom" constant="7.5" id="JVz-q8-EaR"/>
+                                                <constraint firstAttribute="bottomMargin" secondItem="4Fp-ob-0Ch" secondAttribute="bottom" id="Kep-4f-TV6"/>
+                                                <constraint firstItem="4Fp-ob-0Ch" firstAttribute="top" secondItem="gEu-X7-3M0" secondAttribute="topMargin" constant="-8" id="W0W-hP-gfl"/>
+                                                <constraint firstItem="7LX-pr-0Pd" firstAttribute="centerX" secondItem="gEu-X7-3M0" secondAttribute="centerX" id="WXR-f5-ucD"/>
+                                                <constraint firstItem="4Fp-ob-0Ch" firstAttribute="leading" secondItem="gEu-X7-3M0" secondAttribute="leadingMargin" constant="8" id="aLG-DI-q6a"/>
+                                                <constraint firstItem="7LX-pr-0Pd" firstAttribute="centerX" secondItem="gEu-X7-3M0" secondAttribute="centerX" id="b6N-va-jl0"/>
+                                                <constraint firstItem="7LX-pr-0Pd" firstAttribute="top" secondItem="gEu-X7-3M0" secondAttribute="topMargin" constant="-9" id="dcd-zI-Npq"/>
+                                                <constraint firstItem="4Fp-ob-0Ch" firstAttribute="leading" secondItem="gEu-X7-3M0" secondAttribute="leadingMargin" constant="8" id="f8h-Cn-sBz"/>
+                                                <constraint firstItem="7LX-pr-0Pd" firstAttribute="top" secondItem="gEu-X7-3M0" secondAttribute="topMargin" constant="-9" id="pQe-20-M3q"/>
+                                                <constraint firstItem="lYr-bv-gD0" firstAttribute="leading" secondItem="gEu-X7-3M0" secondAttribute="leadingMargin" constant="64" id="pZj-Ez-94J"/>
+                                                <constraint firstItem="7LX-pr-0Pd" firstAttribute="top" secondItem="gEu-X7-3M0" secondAttribute="topMargin" constant="-9" id="sYj-CW-gbP"/>
+                                            </constraints>
+                                            <edgeInsets key="layoutMargins" top="20" left="0.0" bottom="8" right="8"/>
+                                            <variation key="default">
+                                                <mask key="constraints">
+                                                    <exclude reference="Br2-cc-MD6"/>
+                                                    <exclude reference="WXR-f5-ucD"/>
+                                                    <exclude reference="sYj-CW-gbP"/>
+                                                </mask>
+                                            </variation>
+                                        </tableViewCellContentView>
+                                        <inset key="separatorInset" minX="0.0" minY="0.0" maxX="0.0" maxY="0.0"/>
+                                    </tableViewCell>
+                                    <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" selectionStyle="none" indentationWidth="0.0" rowHeight="44" id="sfU-SD-QZO">
+                                        <rect key="frame" x="0.0" y="312" width="600" height="44"/>
+                                        <autoresizingMask key="autoresizingMask"/>
+                                        <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" tableViewCell="sfU-SD-QZO" id="yxQ-bD-mBC">
+                                            <rect key="frame" x="0.0" y="0.0" width="600" height="43"/>
+                                            <autoresizingMask key="autoresizingMask"/>
+                                            <subviews>
+                                                <stackView opaque="NO" tag="2" contentMode="scaleToFill" semanticContentAttribute="spatial" misplaced="YES" distribution="equalCentering" alignment="center" translatesAutoresizingMaskIntoConstraints="NO" id="3eI-t6-Pay">
+                                                    <rect key="frame" x="8" y="0.0" width="584" height="51"/>
+                                                    <subviews>
+                                                        <button opaque="NO" contentMode="scaleToFill" misplaced="YES" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="I7i-jf-aSX">
+                                                            <rect key="frame" x="0.0" y="3" width="292" height="45"/>
+                                                            <constraints>
+                                                                <constraint firstAttribute="height" constant="44" id="81H-Ed-3bH"/>
+                                                            </constraints>
+                                                            <state key="normal" title="Trotzdem anzeigen">
+                                                                <color key="titleColor" red="1" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                            </state>
+                                                            <connections>
+                                                                <action selector="showEmailButton:" destination="Ouw-WD-EV6" eventType="touchUpInside" id="mAB-ts-7mq"/>
+                                                            </connections>
+                                                        </button>
+                                                        <view contentMode="scaleToFill" misplaced="YES" translatesAutoresizingMaskIntoConstraints="NO" id="cap-Ul-t1I">
+                                                            <rect key="frame" x="292" y="0.0" width="0.0" height="51"/>
+                                                            <color key="backgroundColor" white="0.66666666666666663" alpha="1" colorSpace="calibratedWhite"/>
+                                                            <constraints>
+                                                                <constraint firstAttribute="width" id="AX9-BE-lhT"/>
+                                                            </constraints>
+                                                        </view>
+                                                        <button opaque="NO" contentMode="scaleToFill" misplaced="YES" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" translatesAutoresizingMaskIntoConstraints="NO" id="qTi-rO-CH3">
+                                                            <rect key="frame" x="292" y="11" width="292" height="30"/>
+                                                            <constraints>
+                                                                <constraint firstAttribute="height" constant="44" id="voC-CF-ncN"/>
+                                                            </constraints>
+                                                            <fontDescription key="fontDescription" type="boldSystem" pointSize="15"/>
+                                                            <state key="normal" title="Ignorieren"/>
+                                                            <connections>
+                                                                <action selector="ignoreEmailButton:" destination="Ouw-WD-EV6" eventType="touchUpInside" id="fSJ-67-PCH"/>
+                                                            </connections>
+                                                        </button>
+                                                    </subviews>
+                                                    <constraints>
+                                                        <constraint firstItem="qTi-rO-CH3" firstAttribute="leading" secondItem="cap-Ul-t1I" secondAttribute="trailing" id="NZx-k6-SWE"/>
+                                                        <constraint firstItem="cap-Ul-t1I" firstAttribute="top" secondItem="3eI-t6-Pay" secondAttribute="top" id="NxY-eD-ddP"/>
+                                                        <constraint firstItem="cap-Ul-t1I" firstAttribute="leading" secondItem="I7i-jf-aSX" secondAttribute="trailing" id="g0n-ew-GTy"/>
+                                                        <constraint firstAttribute="bottom" secondItem="cap-Ul-t1I" secondAttribute="bottom" id="gcr-oi-Fn7"/>
+                                                    </constraints>
+                                                </stackView>
+                                            </subviews>
+                                            <constraints>
+                                                <constraint firstItem="3eI-t6-Pay" firstAttribute="trailing" secondItem="yxQ-bD-mBC" secondAttribute="trailingMargin" id="Zw9-gp-SWD"/>
+                                                <constraint firstItem="3eI-t6-Pay" firstAttribute="top" secondItem="yxQ-bD-mBC" secondAttribute="topMargin" constant="-20" id="gzM-vw-YO5"/>
+                                                <constraint firstAttribute="bottomMargin" secondItem="3eI-t6-Pay" secondAttribute="bottom" constant="-8" id="otC-dE-2qD"/>
+                                                <constraint firstItem="3eI-t6-Pay" firstAttribute="leading" secondItem="yxQ-bD-mBC" secondAttribute="leadingMargin" id="x3A-3r-a80"/>
+                                            </constraints>
+                                            <edgeInsets key="layoutMargins" top="20" left="8" bottom="8" right="8"/>
+                                        </tableViewCellContentView>
+                                        <edgeInsets key="layoutMargins" top="8" left="0.0" bottom="8" right="8"/>
+                                    </tableViewCell>
+                                </cells>
+                            </tableViewSection>
+                            <tableViewSection id="Zfk-MV-bjc">
+                                <cells>
+                                    <tableViewCell clipsSubviews="YES" contentMode="scaleToFill" selectionStyle="none" indentationWidth="10" id="VrX-Dg-aLu" customClass="MessageBodyTableViewCell" customModule="enzevalos_iphone" customModuleProvider="target">
+                                        <rect key="frame" x="0.0" y="365" width="600" height="44"/>
+                                        <autoresizingMask key="autoresizingMask"/>
+                                        <tableViewCellContentView key="contentView" opaque="NO" clipsSubviews="YES" multipleTouchEnabled="YES" contentMode="center" tableViewCell="VrX-Dg-aLu" id="MwJ-Pq-fRD">
+                                            <rect key="frame" x="0.0" y="0.0" width="600" height="43"/>
+                                            <autoresizingMask key="autoresizingMask"/>
+                                            <subviews>
+                                                <label opaque="NO" userInteractionEnabled="NO" contentMode="left" horizontalHuggingPriority="251" verticalHuggingPriority="251" misplaced="YES" text="Message" textAlignment="natural" lineBreakMode="wordWrap" numberOfLines="0" baselineAdjustment="alignBaselines" adjustsFontSizeToFit="NO" translatesAutoresizingMaskIntoConstraints="NO" id="djb-A5-Dwe">
+                                                    <rect key="frame" x="8" y="12" width="584" height="24"/>
+                                                    <fontDescription key="fontDescription" type="system" pointSize="17"/>
+                                                    <color key="textColor" red="0.0" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                                                    <nil key="highlightedColor"/>
+                                                </label>
+                                            </subviews>
+                                            <constraints>
+                                                <constraint firstAttribute="bottomMargin" secondItem="djb-A5-Dwe" secondAttribute="bottom" id="6pO-xi-ovB"/>
+                                                <constraint firstAttribute="trailingMargin" secondItem="djb-A5-Dwe" secondAttribute="trailing" id="7AP-Yj-VvH"/>
+                                                <constraint firstAttribute="leadingMargin" secondItem="djb-A5-Dwe" secondAttribute="leading" id="92e-Kh-ibK"/>
+                                                <constraint firstAttribute="trailingMargin" secondItem="djb-A5-Dwe" secondAttribute="trailing" id="KIa-k5-lho"/>
+                                                <constraint firstItem="djb-A5-Dwe" firstAttribute="top" secondItem="MwJ-Pq-fRD" secondAttribute="topMargin" constant="-8" id="j1y-EV-9ca"/>
+                                            </constraints>
+                                            <edgeInsets key="layoutMargins" top="20" left="8" bottom="8" right="8"/>
+                                        </tableViewCellContentView>
+                                    </tableViewCell>
+                                </cells>
+                            </tableViewSection>
+                        </sections>
+                        <connections>
+                            <outlet property="dataSource" destination="Ouw-WD-EV6" id="hm4-gA-aUF"/>
+                            <outlet property="delegate" destination="Ouw-WD-EV6" id="RQX-yM-rQQ"/>
+                        </connections>
+                    </tableView>
+                    <toolbarItems>
+                        <barButtonItem title="Löschen" id="Mac-KZ-4YQ">
+                            <color key="tintColor" red="1" green="0.0" blue="0.0" alpha="1" colorSpace="calibratedRGB"/>
+                            <connections>
+                                <action selector="deleteButton:" destination="Ouw-WD-EV6" id="QYh-Ah-Evh"/>
+                            </connections>
+                        </barButtonItem>
+                        <barButtonItem style="plain" systemItem="flexibleSpace" id="BeF-Oq-zid"/>
+                        <barButtonItem title="Ungelesen" id="2JJ-ZX-lDs">
+                            <connections>
+                                <action selector="markUnreadButton:" destination="Ouw-WD-EV6" id="9Rd-Tt-nFT"/>
+                            </connections>
+                        </barButtonItem>
+                        <barButtonItem style="plain" systemItem="flexibleSpace" id="fWW-Bq-Eim"/>
+                        <barButtonItem title="Archivieren" id="tGx-Pm-eAc"/>
+                    </toolbarItems>
+                    <navigationItem key="navigationItem" id="JgT-PA-2op">
+                        <nil key="title"/>
+                        <button key="titleView" opaque="NO" contentMode="center" contentHorizontalAlignment="center" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" id="bcV-Tv-Mmh">
+                            <rect key="frame" x="285" y="3" width="30" height="38"/>
+                            <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
+                            <color key="tintColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
+                            <state key="normal">
+                                <color key="titleColor" white="1" alpha="1" colorSpace="calibratedWhite"/>
+                            </state>
+                            <connections>
+                                <action selector="iconButton:" destination="Ouw-WD-EV6" eventType="touchUpInside" id="EQb-rm-FA7"/>
+                            </connections>
+                        </button>
+                        <barButtonItem key="rightBarButtonItem" style="plain" id="bjU-OB-pru">
+                            <button key="customView" opaque="NO" contentMode="scaleToFill" contentHorizontalAlignment="right" contentVerticalAlignment="center" buttonType="roundedRect" lineBreakMode="middleTruncation" id="9Io-ch-Bl3">
+                                <rect key="frame" x="447" y="7" width="133" height="30"/>
+                                <autoresizingMask key="autoresizingMask" flexibleMaxX="YES" flexibleMaxY="YES"/>
+                                <state key="normal" title="Antworten"/>
+                            </button>
+                        </barButtonItem>
+                    </navigationItem>
+                    <connections>
+                        <outlet property="SeperatorConstraint" destination="AX9-BE-lhT" id="vUm-gH-8hO"/>
+                        <outlet property="iconButton" destination="bcV-Tv-Mmh" id="dF9-8X-MI7"/>
+                        <outlet property="infoButtonCell" destination="sfU-SD-QZO" id="D1b-xZ-hPj"/>
+                        <outlet property="infoCell" destination="hiO-mC-dXs" id="f6G-Lb-g8H"/>
+                        <outlet property="messageBody" destination="djb-A5-Dwe" id="Bmh-D7-tfV"/>
+                        <outlet property="messageCell" destination="VrX-Dg-aLu" id="YCC-3f-gVa"/>
+                        <outlet property="receivedTime" destination="Sdq-CE-2Do" id="Ter-Ry-ynd"/>
+                        <outlet property="receivers" destination="okf-3B-Nb6" id="eHD-K4-49t"/>
+                        <outlet property="receiversCell" destination="ZjK-3s-N2G" id="qUV-eW-NCM"/>
+                        <outlet property="sender" destination="YIc-GU-Crs" id="VLM-jt-w6f"/>
+                        <outlet property="senderCell" destination="lSe-Gv-7SL" id="Lnd-ID-fUk"/>
+                        <outlet property="subject" destination="Ywe-G2-0wJ" id="0Gj-YZ-PnF"/>
+                        <outlet property="subjectCell" destination="HpI-HP-usd" id="E0n-41-jUp"/>
+                    </connections>
+                </tableViewController>
+                <placeholder placeholderIdentifier="IBFirstResponder" id="A7Q-pa-bOY" userLabel="First Responder" sceneMemberID="firstResponder"/>
+            </objects>
+            <point key="canvasLocation" x="915" y="-296"/>
+        </scene>
+        <!--Navigation Controller-->
+        <scene sceneID="qoE-UA-ZLX">
+            <objects>
+                <navigationController automaticallyAdjustsScrollViewInsets="NO" toolbarHidden="NO" id="Amm-QN-vA7" sceneMemberID="viewController">
+                    <toolbarItems/>
+                    <navigationBar key="navigationBar" contentMode="scaleToFill" id="A4w-tO-f2v">
+                        <rect key="frame" x="0.0" y="0.0" width="320" height="44"/>
+                        <autoresizingMask key="autoresizingMask"/>
+                        <color key="barTintColor" red="0.93725490199999995" green="0.93725490199999995" blue="0.95686274510000002" alpha="1" colorSpace="calibratedRGB"/>
+                    </navigationBar>
+                    <nil name="viewControllers"/>
+                    <toolbar key="toolbar" opaque="NO" clearsContextBeforeDrawing="NO" contentMode="scaleToFill" id="eYs-O9-RqI">
+                        <rect key="frame" x="0.0" y="556" width="600" height="44"/>
+                        <autoresizingMask key="autoresizingMask"/>
+                    </toolbar>
+                    <connections>
+                        <segue destination="X5Y-Rf-Qzd" kind="relationship" relationship="rootViewController" id="ltb-vV-hAM"/>
+                    </connections>
+                </navigationController>
+                <placeholder placeholderIdentifier="IBFirstResponder" id="bg6-Th-yQH" userLabel="First Responder" sceneMemberID="firstResponder"/>
+            </objects>
+            <point key="canvasLocation" x="-483" y="-296"/>
+        </scene>
+        <!--Posteingang-->
+        <scene sceneID="ue1-yd-fJq">
+            <objects>
+                <tableViewController id="X5Y-Rf-Qzd" customClass="InboxViewController" customModule="enzevalos_iphone" customModuleProvider="target" sceneMemberID="viewController">
+                    <tableView key="view" clipsSubviews="YES" contentMode="scaleToFill" alwaysBounceVertical="YES" showsHorizontalScrollIndicator="NO" dataMode="prototypes" style="grouped" separatorStyle="default" allowsSelection="NO" rowHeight="130" sectionHeaderHeight="18" sectionFooterHeight="18" id="hiB-1s-b08">
+                        <rect key="frame" x="0.0" y="0.0" width="600" height="600"/>
+                        <autoresizingMask key="autoresizingMask" widthSizable="YES" heightSizable="YES"/>
+                        <color key="backgroundColor" red="0.93725490199999995" green="0.93725490199999995" blue="0.95686274510000002" alpha="1" colorSpace="calibratedRGB"/>
+                        <connections>
+                            <outlet property="dataSource" destination="X5Y-Rf-Qzd" id="Gu0-7Z-YNa"/>
+                            <outlet property="delegate" destination="X5Y-Rf-Qzd" id="6Tr-6R-YW0"/>
+                        </connections>
+                    </tableView>
+                    <navigationItem key="navigationItem" title="Posteingang" id="5GZ-GC-SZf"/>
+                    <simulatedOrientationMetrics key="simulatedOrientationMetrics"/>
+                    <connections>
+                        <segue destination="Ouw-WD-EV6" kind="show" identifier="readMailSegue" id="GWh-iO-bPb"/>
+                    </connections>
+                </tableViewController>
+                <placeholder placeholderIdentifier="IBFirstResponder" id="EUm-6R-021" userLabel="First Responder" sceneMemberID="firstResponder"/>
+            </objects>
+            <point key="canvasLocation" x="211" y="-296"/>
+        </scene>
+    </scenes>
+</document>
diff --git a/enzevalos_iphone/MessageBodyTableViewCell.swift b/enzevalos_iphone/MessageBodyTableViewCell.swift
new file mode 100644
index 0000000000000000000000000000000000000000..7baa7b5f84101ad30899c29092881bc7968ad81b
--- /dev/null
+++ b/enzevalos_iphone/MessageBodyTableViewCell.swift
@@ -0,0 +1,13 @@
+//
+//  MessageBodyTableViewCell.swift
+//  readView
+//
+//  Created by Joscha on 25.07.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+import UIKit
+
+class MessageBodyTableViewCell: UITableViewCell {
+    @IBOutlet var message: UILabel!
+}
diff --git a/enzevalos_iphone/NSDateCompare.swift b/enzevalos_iphone/NSDateCompare.swift
new file mode 100644
index 0000000000000000000000000000000000000000..66072e3c5ebd27fa3637d0433c5a22a347a0ff75
--- /dev/null
+++ b/enzevalos_iphone/NSDateCompare.swift
@@ -0,0 +1,19 @@
+//
+//  NSDateCompare.swift
+//  readView
+//
+//  Created by Joscha on 09.09.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+import Foundation
+
+public func ==(lhs: NSDate, rhs: NSDate) -> Bool {
+    return lhs === rhs || lhs.compare(rhs) == .OrderedSame
+}
+
+public func <(lhs: NSDate, rhs: NSDate) -> Bool {
+    return lhs.compare(rhs) == .OrderedAscending
+}
+
+extension NSDate: Comparable { }
\ No newline at end of file
diff --git a/enzevalos_iphone/ReadViewController.swift b/enzevalos_iphone/ReadViewController.swift
new file mode 100644
index 0000000000000000000000000000000000000000..b69a58d79a9bbafaa65b76b6c09332cd01eca11f
--- /dev/null
+++ b/enzevalos_iphone/ReadViewController.swift
@@ -0,0 +1,216 @@
+//
+//  ReadViewController.swift
+//  readView
+//
+//  Created by Joscha on 22.07.16.
+//  Copyright © 2016 Joscha. All rights reserved.
+//
+
+import UIKit
+import Foundation
+
+class ReadViewController : UITableViewController {
+    @IBOutlet weak var sender: UILabel!
+    @IBOutlet weak var receivers: UILabel!
+    @IBOutlet weak var receivedTime: UILabel!
+    @IBOutlet weak var subject: UILabel!
+    @IBOutlet weak var messageBody: UILabel!
+    
+    // Cells
+    @IBOutlet weak var senderCell: UITableViewCell!
+    @IBOutlet weak var receiversCell: UITableViewCell!
+    @IBOutlet weak var subjectCell: UITableViewCell!
+    @IBOutlet weak var infoCell: UITableViewCell!
+    @IBOutlet weak var infoButtonCell: UITableViewCell!
+    @IBOutlet weak var messageCell: MessageBodyTableViewCell!
+        
+    @IBOutlet weak var iconButton: UIButton!
+    
+    @IBOutlet weak var SeperatorConstraint: NSLayoutConstraint!
+    
+    var mail: Mail? = nil
+    let red = UIColor(red: 255/255, green: 99/255, blue: 99/255, alpha: 1.0)
+    let green = UIColor(red: 115/255, green: 229/255, blue: 105/255, alpha: 1.0)
+    let orange = UIColor(red: 247/255, green: 185/255, blue: 0/255, alpha: 1.0)
+    let defaultColor = UIColor.groupTableViewBackgroundColor() // UIColor(red: 242/255, green: 242/255, blue: 246/255, alpha: 1.0)
+
+    
+    
+    override func viewDidLoad() {
+        super.viewDidLoad()
+        
+        self.tableView.rowHeight = UITableViewAutomaticDimension
+        self.tableView.estimatedRowHeight = 44.0
+        
+        // not possible to set in IB
+        SeperatorConstraint.constant = 0.5
+        infoCell.layoutMargins = UIEdgeInsetsZero
+
+        setUItoMail()
+    }
+    
+    override func viewWillAppear(animated: Bool) {
+        // NavigationBar color
+        if let m = mail {
+            if m.trouble {
+                self.navigationController?.navigationBar.barTintColor = self.red
+            } else if m.isEncrypted {
+                self.navigationController?.navigationBar.barTintColor = self.green
+            } else {
+                self.navigationController?.navigationBar.barTintColor = self.orange
+            }
+        }
+    }
+    
+    override func willMoveToParentViewController(parent: UIViewController?) {
+        super.willMoveToParentViewController(parent)
+        
+        if parent == nil {
+            UIView.animateWithDuration(0.3, animations: {self.navigationController?.navigationBar.barTintColor = self.defaultColor})
+        }
+    }
+    
+    // set top seperator height
+    override func tableView(tableView: UITableView, heightForHeaderInSection section: Int) -> CGFloat {
+        if section == 0 {
+            return 8
+        }
+        return tableView.sectionHeaderHeight
+    }
+    
+    override func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat {
+        return UITableViewAutomaticDimension
+    }
+    
+    override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
+        if mail != nil {
+            if mail!.trouble && mail!.showMessage {
+                return 3
+            }
+        }
+        
+        return 2
+    }
+    
+    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
+        if section == 0 {
+            return 3
+        }
+        if mail != nil {
+            if mail!.trouble && section == 1 {
+                if mail!.showMessage {
+                    return 1
+                } else {
+                    return 2
+                }
+            }
+        }
+        
+        return 1
+    }
+    
+    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
+        if indexPath.section == 0 {
+            switch indexPath.row {
+            case 0:
+                return senderCell
+            case 1:
+                return receiversCell
+            default:
+                return subjectCell
+            }
+        }
+        if indexPath.section == 1 {
+            if mail != nil {
+                if mail!.trouble {
+                    if indexPath.row == 0 {
+                        return infoCell
+                    } else if indexPath.row == 1 {
+                        return infoButtonCell
+                    }
+                }
+            } else {
+                return messageCell
+            }
+        }
+        
+        return messageCell
+    }
+    
+    @IBAction func showEmailButton(sender: UIButton) {
+        mail!.showMessage = true
+        
+        self.tableView.beginUpdates()
+        let path = NSIndexPath(forRow: 1, inSection: 1)
+        self.tableView.deleteRowsAtIndexPaths([path], withRowAnimation: .Fade)
+        self.tableView.insertSections(NSIndexSet(index: 2), withRowAnimation: .Fade)
+        self.tableView.endUpdates()
+    }
+    
+    @IBAction func ignoreEmailButton(sender: AnyObject) {
+        navigationController?.popViewControllerAnimated(true)
+    }
+    
+    @IBAction func markUnreadButton(sender: AnyObject) {
+        mail?.isUnread = true
+        navigationController?.popViewControllerAnimated(true)
+    }
+    
+    @IBAction func deleteButton(sender: AnyObject) {
+        navigationController?.popViewControllerAnimated(true)
+    }
+    
+    @IBAction func iconButton(sender: AnyObject) {
+        if let m = mail {
+            let alert: UIAlertController
+            let url: String
+            if m.trouble {
+                alert = UIAlertController(title: "Angerissener Brief", message: "Mit dieser Nachricht stimmt was nicht. Der Inhalt könnte kompromitiert oder manipuliert sein.", preferredStyle: UIAlertControllerStyle.Alert)
+                url = "https://enzevalos.org/infos/corrupted"
+            } else if m.isEncrypted {
+                alert = UIAlertController(title: "Brief", message: "Diese Nachricht war ordnungsgemäß verschlossen. Er kann nicht von Dritten gelesen werden. Die Identität des Absenders wurde bestätigt", preferredStyle: UIAlertControllerStyle.Alert)
+                url = "https://enzevalos.org/infos/letter"
+            } else {
+                alert = UIAlertController(title: "Postkarte", message: "Diese Nachricht wurde unverschlüsselt gesendet und kann somit von Allen am Weg mitgelesen werden. Auch kann die Identität des Absenders nicht bestätigt werden.", preferredStyle: UIAlertControllerStyle.Alert)
+                url = "https://enzevalos.org/infos/postcard"
+            }
+            alert.addAction(UIAlertAction(title: "Mehr Informationen", style: UIAlertActionStyle.Default, handler: {(action:UIAlertAction!) -> Void in UIApplication.sharedApplication().openURL(NSURL(string: url)!)}))
+            alert.addAction(UIAlertAction(title: "OK", style: UIAlertActionStyle.Cancel, handler: nil))
+            dispatch_async(dispatch_get_main_queue(), {
+                self.presentViewController(alert, animated: true, completion: nil)
+            })
+        }
+    }
+    
+    func setUItoMail() {
+        if let m = mail {
+            sender.text = m.sender
+            receivers.text = "An: " + m.receivers.joinWithSeparator(", ")
+            receivedTime.text = m.timeString
+            
+            if let subj = m.subject {
+                if subj != "" && subj != " " {
+                    subject.text = subj
+                } else {
+                    subject.text = "(Kein Betreff)"
+                }
+            }
+            
+            messageBody.text = m.body
+            
+            // NavigationBar Icon
+            let iconView = UIImageView(frame: CGRect(x: 0, y: 0, width: 30, height: 38))
+            iconView.contentMode = .ScaleAspectFit
+            var icon: UIImage
+            if m.trouble {
+                icon = UIImage(named: "letter_corrupted")!
+            } else if m.isEncrypted {
+                icon = UIImage(named: "letter_open")!
+            } else {
+                icon = UIImage(named: "postcard")!
+            }
+            iconView.image = icon
+            iconButton.setImage(icon, forState: UIControlState.Normal)
+        }
+    }
+}
diff --git a/enzevalos_iphone/TableViewDataDelegate.swift b/enzevalos_iphone/TableViewDataDelegate.swift
new file mode 100644
index 0000000000000000000000000000000000000000..b66df0d8035209fadb3a6de6a36b2f57a4a56e66
--- /dev/null
+++ b/enzevalos_iphone/TableViewDataDelegate.swift
@@ -0,0 +1,64 @@
+//
+//  TableViewDataDelegate.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 01.09.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import VENTokenField
+//import UIKit
+
+class TableViewDataDelegate : NSObject, UITableViewDelegate, UITableViewDataSource {
+    
+    var contacts : [String] = []
+    var addresses : [String] = []
+    var pictures : [UIImage?] = []
+    //var count = 0
+    //weak var tokenField : VENTokenField?
+    var insertCallback : (String, String) -> Void = {(name : String, address : String) -> Void in return}
+    
+    init(insertCallback : (String, String) -> Void){
+        self.insertCallback = insertCallback
+        super.init()
+    }
+    
+    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
+        return contacts.count
+    }
+    
+    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
+        let cell = tableView.dequeueReusableCellWithIdentifier("contacts") as! ContactCell
+        cell.name.text = contacts[indexPath.row]
+        cell.address.text = addresses[indexPath.row]
+        cell.img.layer.cornerRadius = cell.img.frame.height/2
+        cell.img.clipsToBounds = true
+        cell.img.image = pictures[indexPath.row]
+        if let img = pictures[indexPath.row] {
+            cell.img.image = img
+        }
+        
+        if (!AddressHandler.proveAddress(cell.address.text!)){
+            //cell.backgroundColor = UIColor.orangeColor()
+            cell.name.textColor! = UIColor.orangeColor()
+            cell.address.textColor! = UIColor.orangeColor()
+        }
+        else {
+            //cell.backgroundColor = nil
+            cell.name.textColor! = UIColor.blackColor()
+            cell.address.textColor! = UIColor.blackColor()
+        }
+        return cell
+    }
+    
+    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
+        /*if (tokenField != nil) {
+            tokenField?.delegate?.tokenField!(tokenField!, didEnterText: contacts[indexPath.row], mail: addresses[indexPath.row])
+        }*/
+        self.insertCallback(contacts[indexPath.row], addresses[indexPath.row])
+    }
+    
+    /*func numberOfSectionsInTableView(tableView: UITableView) -> Int {
+        
+    }*/
+}
diff --git a/enzevalos_iphone/Unbenannt.gif b/enzevalos_iphone/Unbenannt.gif
new file mode 100755
index 0000000000000000000000000000000000000000..149c7bbd2e57cc47fc0549341514bae9f188b033
Binary files /dev/null and b/enzevalos_iphone/Unbenannt.gif differ
diff --git a/enzevalos_iphone/VCSend04.swift b/enzevalos_iphone/VCSend04.swift
new file mode 100644
index 0000000000000000000000000000000000000000..4bbcaf9c71b63eb87b0c73ef335d45a6ec833810
--- /dev/null
+++ b/enzevalos_iphone/VCSend04.swift
@@ -0,0 +1,423 @@
+//
+//  ViewController.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 01.07.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import UIKit
+import VENTokenField
+import Contacts
+
+class VCSend04: UIViewController, UITextViewDelegate{
+    
+    var imageView: UIImageView = UIImageView(frame: CGRect(x: 0, y: 5, width: 200, height: 45))
+    @IBOutlet weak var button: UIBarButtonItem!
+    @IBOutlet weak var textView: UITextView!
+    @IBOutlet weak var toText: VENTokenField!
+    @IBOutlet weak var toHeight: NSLayoutConstraint!
+    @IBOutlet weak var seperator1Height: NSLayoutConstraint!
+    @IBOutlet weak var ccText: VENTokenField!
+    @IBOutlet weak var ccHeight: NSLayoutConstraint!
+    @IBOutlet weak var seperator2Height: NSLayoutConstraint!
+    @IBOutlet weak var subjectText: VENTokenField!
+    @IBOutlet weak var seperator3Height: NSLayoutConstraint!
+    @IBOutlet weak var scrollview: UIScrollView!
+    @IBOutlet weak var tableview: UITableView!
+    @IBOutlet weak var tableviewBegin: NSLayoutConstraint!
+    @IBOutlet weak var tableviewHeight: NSLayoutConstraint!
+    @IBOutlet weak var toCollectionview: UICollectionView!
+    @IBOutlet weak var toCollectionviewHeight: NSLayoutConstraint!
+    @IBOutlet weak var ccCollectionview: UICollectionView!
+    @IBOutlet weak var ccCollectionviewHeight: NSLayoutConstraint!
+    
+    var keyboardOpened = false
+    var keyboardY : CGFloat = 0
+    var reducedSize : CGFloat = 0
+    var secureState = true
+    var toSecure = true
+    var ccSecure = true
+    var dataDelegate = VENDataDelegate()
+    var mailHandler = MailHandler()
+    var tableDataDelegate = TableViewDataDelegate(insertCallback: {(name : String, address : String) -> Void in return})
+    var collectionDataDelegate = CollectionDataDelegate(suggestionFunc: AddressHandler.frequentAddresses, insertCallback: {(name : String, address : String) -> Void in return})
+    
+    override func viewDidLoad() {
+        super.viewDidLoad()
+        dataDelegate = VENDataDelegate(changeFunc: self.editName)
+        tableDataDelegate = TableViewDataDelegate(insertCallback: self.insertName)
+        collectionDataDelegate = CollectionDataDelegate(suggestionFunc: AddressHandler.frequentAddresses, insertCallback: self.insertName)
+        imageView.contentMode = .ScaleAspectFit
+        imageView.image = UIImage(named: "Icon_animated001-001_alpha_verschoben-90.png")!
+        setAnimation(false)
+        self.navigationItem.titleView = imageView
+        
+        textView.delegate = self
+        
+        subjectText.toLabelText = "Subject: "
+        
+        toText.delegate = dataDelegate
+        toText.dataSource = dataDelegate
+        toText.inputTextFieldKeyboardType = UIKeyboardType.EmailAddress
+        toCollectionview.delegate = collectionDataDelegate
+        toCollectionview.dataSource = collectionDataDelegate
+        toCollectionview.registerNib(UINib(nibName: "FrequentCell", bundle: nil), forCellWithReuseIdentifier: "frequent")
+        toCollectionviewHeight.constant = 0
+        ccText.delegate = dataDelegate
+        ccText.dataSource = dataDelegate
+        ccText.toLabelText = "Cc:"
+        ccCollectionview.delegate = collectionDataDelegate
+        ccCollectionview.dataSource = collectionDataDelegate
+        ccCollectionview.registerNib(UINib(nibName: "FrequentCell", bundle: nil), forCellWithReuseIdentifier: "frequent")
+        ccCollectionviewHeight.constant = 0
+        
+        //will always be thrown, when a token was editied
+        toText.addTarget(self, action: #selector(self.newInput(_:)), forControlEvents: UIControlEvents.EditingDidEnd)
+        ccText.addTarget(self, action: #selector(self.newInput(_:)), forControlEvents: UIControlEvents.EditingDidEnd)
+        
+        toText.delegate?.tokenField!(toText, didEnterText: "jakob.bode@fu-berlin.de")
+        
+        seperator1Height.constant = 0.5
+        seperator2Height.constant = 0.5
+        seperator3Height.constant = 0.5
+        
+        //ccText.horizontalInset = 9
+    
+        ccText.inputTextFieldKeyboardType = UIKeyboardType.EmailAddress
+        scrollview.clipsToBounds = true
+        
+        tableview.delegate = tableDataDelegate
+        tableview.dataSource = tableDataDelegate
+        tableview.registerNib(UINib(nibName: "ContactCell", bundle: nil), forCellReuseIdentifier: "contacts")
+        
+        //tableview.registerClass(ContactCell.self, forCellReuseIdentifier: "contacts")
+        
+        let indexPath = NSIndexPath()
+        //tableview.registerNib(UINib(nibName: "nib", bundle: nil), forCellReuseIdentifier: "contacts")
+        
+        //tableview.cellForRowAtIndexPath(indexPath)?.textLabel?.text = "hallo2"
+        tableview.reloadRowsAtIndexPaths([indexPath], withRowAnimation: UITableViewRowAnimation.Automatic)
+        
+        //register KeyBoardevents
+        NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(self.keyboardOpen(_:)), name:UIKeyboardWillShowNotification, object: nil);
+        NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(self.keyboardClose(_:)), name:UIKeyboardWillHideNotification, object: nil);
+        
+        //        UIView.animateWithDuration(0.5, delay: 1, options: UIViewAnimationOptions() ,animations: {
+        //            self.button!.setImage(self.imageView.image!, forState: UIControlState.Normal)
+        //            //self.button!.frame = CGRectOffset(self.button!.frame, 0, 100)
+        //            }, completion: nil)
+        //showMessage("hallihallo")
+        
+        //doContact()
+    }
+    
+    override func viewDidAppear(animated: Bool){
+        
+    }
+    
+    override func didReceiveMemoryWarning() {
+        super.didReceiveMemoryWarning()
+        // Dispose of any resources that can be recreated.
+    }
+    
+    func editName(tokenField : VENTokenField){
+        if let inText = tokenField.inputText(){
+            if inText != "" {
+                scrollview.scrollEnabled = false
+                scrollview.contentOffset = CGPoint(x: 0, y: tokenField.frame.origin.y)
+                tableviewBegin.constant = tokenField.frame.maxY-tokenField.frame.origin.y
+                tableviewHeight.constant = keyboardY - tableviewBegin.constant - (self.navigationController?.navigationBar.frame.maxY)!
+                //tableDataDelegate.tokenField = tokenField
+                searchContacts(inText)
+                //tableview.frame.origin = CGPoint(x:0, y:tokenField.frame.origin.y+tokenField.frame.maxY)
+            }
+            else {
+                scrollview.scrollEnabled = true
+                tableviewHeight.constant = 0
+            }
+        }
+    }
+    
+    func insertName(name : String, address : String) {
+        if toText.isFirstResponder(){
+            toText.delegate?.tokenField!(toText, didEnterText: name, mail: address)
+        }
+        else if ccText.isFirstResponder(){
+            ccText.delegate?.tokenField!(ccText, didEnterText: name, mail: address)
+        }
+        //collectionDataDelegate.alreadyInserted = (toText.mailTokens as NSArray as! [String])+(ccText.mailTokens as NSArray as! [String])
+    }
+    
+    func searchContacts(prefix: String){
+        AppDelegate.getAppDelegate().requestForAccess({access in
+            print(access)
+        })
+        let authorizationStatus = CNContactStore.authorizationStatusForEntityType(CNEntityType.Contacts)
+        if authorizationStatus == CNAuthorizationStatus.Authorized {
+            do {
+                let contacts = try AppDelegate.getAppDelegate().contactStore.unifiedContactsMatchingPredicate(CNContact.predicateForContactsMatchingName(prefix), keysToFetch: [CNContactFormatter.descriptorForRequiredKeysForStyle(CNContactFormatterStyle.FullName), CNContactEmailAddressesKey, CNContactImageDataKey, CNContactThumbnailImageDataKey])
+                print(contacts)
+                var indexes : [NSIndexPath] = []
+                var i = 0
+                for (i=0; i<tableview.numberOfRowsInSection(0); i+=1) {
+                    indexes.append(NSIndexPath.init(forRow: i, inSection: 0))
+                }
+                indexes = []
+                tableDataDelegate.contacts = []
+                tableDataDelegate.addresses = []
+                tableDataDelegate.pictures = []
+                for c in contacts {
+                    for mail in c.emailAddresses {
+                        if let name = CNContactFormatter.stringFromContact(c, style: .FullName){
+                            self.tableDataDelegate.contacts.append(name)
+                        }
+                        else {
+                            self.tableDataDelegate.contacts.append(c.givenName+c.familyName)
+                        }
+                        self.tableDataDelegate.addresses.append(mail.value as! String)
+                        self.tableDataDelegate.pictures.append(c.getImageOrDefault())
+                    }
+                }
+                indexes = []
+                for (i=tableDataDelegate.contacts.count; i < tableview.numberOfRowsInSection(0); i+=1){
+                    indexes.append(NSIndexPath.init(forRow: i, inSection: 0))
+                    if i+1 == tableview.numberOfRowsInSection(0) {
+                            tableview.deleteRowsAtIndexPaths(indexes, withRowAnimation: UITableViewRowAnimation.None)
+                    }
+                }
+                for (i=tableview.numberOfRowsInSection(0); i < tableDataDelegate.contacts.count; i+=1){
+                    indexes.append(NSIndexPath.init(forRow: i, inSection: 0))
+                    if i+1 == tableDataDelegate.contacts.count {
+                        tableview.insertRowsAtIndexPaths(indexes, withRowAnimation: UITableViewRowAnimation.None)
+                    }
+                }
+                tableview.reloadData()
+            }
+            catch {
+                print("exception")
+            }
+            print("contacts done")
+        }
+        else {
+            print("no Access!")
+        }
+
+    }
+    
+    func doContact(){
+        AppDelegate.getAppDelegate().requestForAccess({access in
+            print(access)
+        })
+        let authorizationStatus = CNContactStore.authorizationStatusForEntityType(CNEntityType.Contacts)
+        if authorizationStatus == CNAuthorizationStatus.Authorized {
+            do {
+                print(try AppDelegate.getAppDelegate().contactStore.unifiedContactsMatchingPredicate(CNContact.predicateForContactsMatchingName("o"), keysToFetch: [CNContactGivenNameKey]) )
+            }
+            catch {
+                print("exception")
+            }
+            print("contacts done")
+        }
+        else {
+            print("no Access!")
+        }
+    }
+    
+    func newInput(tokenField: VENTokenField){
+        animateIfNeeded()
+        collectionDataDelegate.alreadyInserted = (toText.mailTokens as NSArray as! [String])+(ccText.mailTokens as NSArray as! [String])
+        toCollectionview.reloadData()
+        ccCollectionview.reloadData()
+    }
+   
+    
+    func keyboardOpen(notification: NSNotification) {
+        //if reducedSize == 0{
+            var info = notification.userInfo!
+            let keyboardFrame: CGRect = (info[UIKeyboardFrameEndUserInfoKey] as! NSValue).CGRectValue()
+            reducedSize = keyboardFrame.size.height
+        
+            keyboardY = keyboardFrame.origin.y
+            print("keyboard ", keyboardY)
+        
+        if toText.isFirstResponder() {
+            toCollectionview.reloadData()
+            UIView.animateWithDuration(2.5, delay: 0, options: UIViewAnimationOptions.CurveLinear, animations: {self.toCollectionviewHeight.constant = 100}, completion: nil)
+        }
+        if ccText.isFirstResponder() {
+            ccCollectionviewHeight.constant = 100
+            ccCollectionview.reloadData()
+        }
+        if !toText.isFirstResponder() {
+            UIView.animateWithDuration(2.5, animations: { () -> Void in self.toCollectionviewHeight.constant = 0})
+        }
+        if !ccText.isFirstResponder() {
+            ccCollectionviewHeight.constant = 0
+        }
+        
+            UIView.animateWithDuration(0.1, animations: { () -> Void in
+                //self.bottomConstraint.constant = keyboardFrame.size.height + 20 //gaaaaaanz alt
+                
+                //self.textViewHeight.constant -= self.reducedSize
+                //self.scrollview.heightAnchor -= self.reducedSize
+                
+                //self.bottomConstraint.constant = self.reducedSize
+                let contentInsets = UIEdgeInsetsMake(0.0, 0.0, self.reducedSize, 0.0)
+                self.scrollview!.contentInset = contentInsets
+                //self.scrollview!.scrollIndicatorInsets = contentInsets
+            })
+            //print(self.bottomConstraint.constant)
+        //}
+    }
+    
+    func keyboardClose(notification: NSNotification) {
+        if reducedSize != 0{
+            UIView.animateWithDuration(0.1, animations: { () -> Void in
+                //self.bottomConstraint.constant = keyboardFrame.size.height + 20 //auch ganz alt
+                //self.textViewHeight.constant += self.reducedSize
+                //self.scrollview.heightAnchor -= self.reducedSize
+                
+                //self.bottomConstraint.constant = 0
+                self.reducedSize = 0
+                let contentInsets = UIEdgeInsetsMake(0.0, 0.0, self.reducedSize, 0.0)
+                self.scrollview!.contentInset = contentInsets
+                //self.scrollview!.scrollIndicatorInsets = contentInsets
+            })
+            if !toText.isFirstResponder() {
+                toCollectionviewHeight.constant = 0
+            }
+            if !ccText.isFirstResponder() {
+                ccCollectionviewHeight.constant = 0
+            }
+        }
+    }
+    
+    @IBAction func pressSend(sender: AnyObject) {
+        let toEntrys = toText.mailTokens
+        let ccEntrys = ccText.mailTokens
+        let subject = subjectText.inputText()!
+        let message = textView.text!
+        
+        mailHandler.send(toEntrys as NSArray as! [String], ccEntrys: ccEntrys as NSArray as! [String], bccEntrys: [] , subject: subject , message: message, callback: self.mailSend)
+    }
+    
+    func mailSend(error : NSError?){
+        if (error != nil) {
+            NSLog("Error sending email: \(error)")
+            AppDelegate.getAppDelegate().showMessage("An error occured")
+        } else {
+            NSLog("Send!")
+            AppDelegate.getAppDelegate().showMessage("Send successfully")
+        }
+    }
+    
+    
+    func animateIfNeeded(secure : Bool){
+        if secure != self.secureState {
+            setAnimation(secure)
+            if secure {
+                imageView.image = UIImage(named: "Icon_animated001-001_alpha_verschoben-90.png")!
+            }
+            else {
+                imageView.image = UIImage(named: "Icon_animated001-007_alpha_verschoben-90.png")!
+            }
+            imageView.startAnimating()
+            self.secureState = secure
+        }
+    }
+    
+    func animateIfNeeded(){
+        toSecure = toText.dataSource!.isSecure!(toText)
+        ccSecure = ccText.dataSource!.isSecure!(ccText)
+        if (toSecure && ccSecure) != self.secureState {
+            setAnimation()
+            if toSecure && ccSecure {
+                imageView.image = UIImage(named: "Icon_animated001-001_alpha_verschoben-90.png")!
+                UIView.animateWithDuration(0.5, delay: 0, options: UIViewAnimationOptions.CurveEaseIn ,animations: {
+                    self.navigationController?.navigationBar.barTintColor = UIColor.groupTableViewBackgroundColor()
+                    }, completion: nil)
+            }
+            else {
+                imageView.image = UIImage(named: "Icon_animated001-007_alpha_verschoben-90.png")!
+                UIView.animateWithDuration(0.5, delay: 0, options: [UIViewAnimationOptions.CurveEaseIn/*, UIViewAnimationOptions.Autoreverse*/] ,animations: {
+                    self.navigationController?.navigationBar.barTintColor = UIColor.orangeColor()//UIColor.init(red: 1, green: 0.7, blue: 0.5, alpha: 1)
+                    }, completion: nil)
+                UIView.animateWithDuration(0.5, delay: 0.5, options: UIViewAnimationOptions.CurveEaseIn ,animations: {
+                    self.navigationController?.navigationBar.barTintColor = UIColor.groupTableViewBackgroundColor()
+                    }, completion: nil)
+            }
+            imageView.startAnimating()
+            self.secureState = toSecure && ccSecure
+        }
+    }
+    
+    func setAnimation(){
+        var images: [UIImage] = []
+        images = []
+        
+        //after animation the letter will be shown
+        if toSecure && ccSecure{
+            //set animation images in the right order here
+            images.append(UIImage(named: "Icon_animated001-007_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-006_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-005_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-004_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-003_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-002_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-001_alpha_verschoben-90.png")!)
+        }
+            
+            //Postcard will be shown after the animation
+        else{
+            //set animation images here
+            images.append(UIImage(named: "Icon_animated001-001_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-002_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-003_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-004_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-005_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-006_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-007_alpha_verschoben-90.png")!)
+        }
+        
+        imageView.animationImages = images
+        imageView.animationDuration = 0.75
+        imageView.animationRepeatCount = 1
+    }
+    
+    //secure - state after animation
+    func setAnimation(secure : Bool){
+        var images: [UIImage] = []
+        images = []
+        
+        //after animation the letter will be shown
+        if secure{
+            //set animation images in the right order here
+            images.append(UIImage(named: "Icon_animated001-007_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-006_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-005_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-004_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-003_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-002_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-001_alpha_verschoben-90.png")!)
+        }
+            
+            //Postcard will be shown after the animation
+        else{
+            //set animation images here
+            images.append(UIImage(named: "Icon_animated001-001_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-002_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-003_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-004_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-005_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-006_alpha_verschoben-90.png")!)
+            images.append(UIImage(named: "Icon_animated001-007_alpha_verschoben-90.png")!)
+        }
+        
+        imageView.animationImages = images
+        imageView.animationDuration = 0.75
+        imageView.animationRepeatCount = 1
+    }
+    
+}
+
diff --git a/enzevalos_iphone/VENDataDelegate.swift b/enzevalos_iphone/VENDataDelegate.swift
new file mode 100644
index 0000000000000000000000000000000000000000..43a39afb5c0573e469270d90735f3ca72debe5d4
--- /dev/null
+++ b/enzevalos_iphone/VENDataDelegate.swift
@@ -0,0 +1,120 @@
+//
+//  VENDataDelegate.swift
+//  mail_dynamic_icon_001
+//
+//  Created by jakobsbode on 29.07.16.
+//  Copyright © 2016 jakobsbode. All rights reserved.
+//
+
+import VENTokenField
+
+class VENDataDelegate : NSObject, VENTokenFieldDataSource , VENTokenFieldDelegate {
+    
+    var changeFunc : (VENTokenField -> Void) = {(_ : VENTokenField) -> Void in
+        print ("hallo")
+    }
+    
+    override init() {
+        super.init()
+    }
+    
+    init(changeFunc: (VENTokenField -> Void)){
+        self.changeFunc = changeFunc
+        super.init()
+    }
+    
+    func tokenField(tokenField: VENTokenField, didChangeText text: String?) {
+        print(tokenField.inputText())
+        print(text)
+        changeFunc(tokenField)
+    }
+   
+    func tokenField(tokenField: VENTokenField, colorSchemeForTokenAtIndex index: UInt) -> UIColor {
+        //if AddressHandler.proveAddress(tokenField.textTokens[Int(index)] as! NSString) {
+        if AddressHandler.proveAddress(tokenField.mailTokens[Int(index)] as! NSString) {
+            return UIColor.init(red: 0, green: 122.0/255.0, blue: 1, alpha: 1)
+        }
+        return UIColor.orangeColor()
+    }
+    
+    func tokenFieldDidBeginEditing(tokenField: VENTokenField) {
+        print("begin")
+        print(numberOfTokensInTokenField(tokenField))
+    }
+    
+    func tokenField(tokenField: VENTokenField, didEnterText text: String) {
+        tokenField.textTokens.addObject(text.lowercaseString)
+        if AddressHandler.inContacts(text) {
+            //TODO Mailadresse aus Kontakt holen
+        }
+        else {
+            tokenField.mailTokens.addObject(text)
+        }
+        tokenField.reloadData()
+        changeFunc(tokenField)
+        tokenField.sendActionsForControlEvents(UIControlEvents.EditingDidEnd)
+    }
+    
+    func tokenField(tokenField: VENTokenField, didEnterText text: String, mail email: String) {
+        tokenField.textTokens.addObject(text)
+        tokenField.mailTokens.addObject(email)
+        tokenField.reloadData()
+        changeFunc(tokenField)
+        tokenField.sendActionsForControlEvents(UIControlEvents.EditingDidEnd)
+    }
+    
+    func tokenField(tokenField: VENTokenField, didDeleteTokenAtIndex index: UInt) {
+        tokenField.textTokens.removeObjectAtIndex(Int(index))
+        tokenField.mailTokens.removeObjectAtIndex(Int(index))
+        tokenField.reloadData()
+        tokenField.sendActionsForControlEvents(UIControlEvents.EditingDidEnd)
+    }
+    
+    func tokenField(tokenField: VENTokenField, titleForTokenAtIndex index: UInt) -> String {
+        return tokenField.textTokens[Int(index)] as! String
+    }
+    
+    func numberOfTokensInTokenField(tokenField: VENTokenField) -> UInt {
+        return UInt((tokenField.textTokens.count))
+    }
+    
+    func tokenFieldCollapsedText(tokenField: VENTokenField) -> String {
+        var text : String = "names: "
+        text.appendContentsOf(String(tokenField.dataSource?.numberOfTokensInTokenField!(tokenField)))
+        return text
+    }
+    
+    func tokenField(tokenField: VENTokenField, didChangeContentHeight height: CGFloat) {
+        print("height: ",height)
+        for c in tokenField.constraints {
+            if (c.identifier == "tokenFieldHeight"){
+                c.constant = height
+                print("set height")
+            }
+        }
+    }
+    
+    //eigene Methoden
+    
+    func tokenFieldDidEndEditing(tokenF: VENTokenField){
+        print("end")
+        if let last = tokenF.inputText() {
+            if last.stringByReplacingOccurrencesOfString(" ", withString: "") != "" {
+                tokenField(tokenF, didEnterText: last)
+            }
+        }
+        
+    }
+    
+    /*func tokenStrings(tokenField: VENTokenField) -> [String]{
+        return tokenField.textTokens
+    }*/
+    
+    func isSecure(tokenField: VENTokenField) -> Bool {
+        var secure = true
+        for entry in tokenField.mailTokens{
+            secure = secure && AddressHandler.proveAddress(entry as! NSString)
+        }
+        return secure
+    }
+}
diff --git a/enzevalos_iphone/ViewController.swift b/enzevalos_iphone/ViewController.swift
deleted file mode 100644
index e66d82bad97d94fdb5e5902f222d6569214ce67c..0000000000000000000000000000000000000000
--- a/enzevalos_iphone/ViewController.swift
+++ /dev/null
@@ -1,25 +0,0 @@
-//
-//  ViewController.swift
-//  enzevalos_iphone
-//
-//  Created by jakobsbode on 23.09.16.
-//  Copyright © 2016 fu-berlin. All rights reserved.
-//
-
-import UIKit
-
-class ViewController: UIViewController {
-
-    override func viewDidLoad() {
-        super.viewDidLoad()
-        // Do any additional setup after loading the view, typically from a nib.
-    }
-
-    override func didReceiveMemoryWarning() {
-        super.didReceiveMemoryWarning()
-        // Dispose of any resources that can be recreated.
-    }
-
-
-}
-
diff --git a/enzevalos_iphone/gruen.gif b/enzevalos_iphone/gruen.gif
new file mode 100755
index 0000000000000000000000000000000000000000..c19153074a8818b885b83c25a5208003e03de91d
Binary files /dev/null and b/enzevalos_iphone/gruen.gif differ
diff --git a/enzevalos_iphone/home2.png b/enzevalos_iphone/home2.png
new file mode 100644
index 0000000000000000000000000000000000000000..23b1ca84f95f79b2f64f966ee7aaab0c8e179700
Binary files /dev/null and b/enzevalos_iphone/home2.png differ
diff --git a/enzevalos_iphone/home2@2x.png b/enzevalos_iphone/home2@2x.png
new file mode 100644
index 0000000000000000000000000000000000000000..a72e6c0ffaa34ec30b712eab3d2554192a193254
Binary files /dev/null and b/enzevalos_iphone/home2@2x.png differ
diff --git a/enzevalos_iphone/home2@3x.png b/enzevalos_iphone/home2@3x.png
new file mode 100644
index 0000000000000000000000000000000000000000..7881271ee2ea270553fed6d1d585bc30bac621f8
Binary files /dev/null and b/enzevalos_iphone/home2@3x.png differ
diff --git a/enzevalos_iphone/home2_white.png b/enzevalos_iphone/home2_white.png
new file mode 100755
index 0000000000000000000000000000000000000000..cc68545db9cde7d902815399e304cd5115001f9c
Binary files /dev/null and b/enzevalos_iphone/home2_white.png differ
diff --git a/enzevalos_iphone/home2_white@2x.png b/enzevalos_iphone/home2_white@2x.png
new file mode 100755
index 0000000000000000000000000000000000000000..4081b67b990c0324710f4821a8d26babc4f987f3
Binary files /dev/null and b/enzevalos_iphone/home2_white@2x.png differ
diff --git a/enzevalos_iphone/home2_white@3x.png b/enzevalos_iphone/home2_white@3x.png
new file mode 100755
index 0000000000000000000000000000000000000000..eabca5a970aa1f49620ccd27076cbea0b725fd49
Binary files /dev/null and b/enzevalos_iphone/home2_white@3x.png differ
diff --git a/enzevalos_iphone/work.png b/enzevalos_iphone/work.png
new file mode 100644
index 0000000000000000000000000000000000000000..f14e932e45d72107b24829fdd11c73de0321d2a0
Binary files /dev/null and b/enzevalos_iphone/work.png differ
diff --git a/enzevalos_iphone/work2_white.png b/enzevalos_iphone/work2_white.png
new file mode 100755
index 0000000000000000000000000000000000000000..5a236c655be0061de628c4df6098da7cd7390d20
Binary files /dev/null and b/enzevalos_iphone/work2_white.png differ
diff --git a/enzevalos_iphone/work2_white@2x.png b/enzevalos_iphone/work2_white@2x.png
new file mode 100755
index 0000000000000000000000000000000000000000..717ce5d5b752b8dc5271281234db52006a120573
Binary files /dev/null and b/enzevalos_iphone/work2_white@2x.png differ
diff --git a/enzevalos_iphone/work2_white@3x.png b/enzevalos_iphone/work2_white@3x.png
new file mode 100755
index 0000000000000000000000000000000000000000..67fde8efd130b24d3650c3a761d1f2b58fd5863b
Binary files /dev/null and b/enzevalos_iphone/work2_white@3x.png differ
diff --git a/enzevalos_iphone/work@2x.png b/enzevalos_iphone/work@2x.png
new file mode 100644
index 0000000000000000000000000000000000000000..672c7a73c02a516513ee5c763e6fe553cfa26be4
Binary files /dev/null and b/enzevalos_iphone/work@2x.png differ
diff --git a/enzevalos_iphone/work@3x.png b/enzevalos_iphone/work@3x.png
new file mode 100644
index 0000000000000000000000000000000000000000..bd8922446f3feac30b83999af8e03c7a9887b706
Binary files /dev/null and b/enzevalos_iphone/work@3x.png differ