From 51de86c81a4fc5d5a57685dfd93d59a45d46eee6 Mon Sep 17 00:00:00 2001
From: Max Sokolov
Date: Sat, 11 Jun 2016 00:51:10 +0300
Subject: [PATCH] rename to TableKit
Thanks a lot to my greatest friend, Alexander Nikishin
---
.travis.yml | 2 +-
README.md | 179 +------
Tablet.podspec => TableKit.podspec | 14 +-
.../contents.xcworkspacedata | 4 +-
{Tablet => TableKit}/ConfigurableCell.swift | 0
{Tablet => TableKit}/HeightStrategy.swift | 0
{Tablet => TableKit}/Info.plist | 0
{Tablet => TableKit}/Operators.swift | 0
{Tablet => TableKit}/TableDirector.swift | 0
TableKit/TableKit.h | 19 +
TableKit/TableKit.xcodeproj/project.pbxproj | 335 +++++++++++++
{Tablet => TableKit}/TableRow.swift | 0
{Tablet => TableKit}/TableRowAction.swift | 0
{Tablet => TableKit}/TableRowBuilder.swift | 0
{Tablet => TableKit}/TableSection.swift | 0
{Tablet => TableKit}/Tablet.swift | 0
.../Classes/Application/AppDelegate.swift | 0
.../Controllers/HeaderFooterController.swift | 2 +-
.../Controllers/MainController.swift | 2 +-
.../Views/StoryboardImageTableViewCell.swift | 2 +-
.../Views/StoryboardTableViewCell.swift | 2 +-
.../AppIcon.appiconset/Contents.json | 0
.../Resources/Info.plist | 0
.../Storyboards/LaunchScreen.storyboard | 0
.../Resources/Storyboards/Main.storyboard | 0
.../TableKitDemo.xcodeproj/project.pbxproj | 362 ++++++++++++++
.../contents.xcworkspacedata | 0
.../UserInterfaceState.xcuserstate | Bin 21675 -> 0 bytes
Tablet/Tablet.h | 24 -
Tablet/Tablet.xcodeproj/project.pbxproj | 443 ------------------
.../UserInterfaceState.xcuserstate | Bin 19773 -> 0 bytes
.../xcshareddata/xcschemes/Tablet.xcscheme | 99 ----
.../xcschemes/xcschememanagement.plist | 19 -
.../xcdebugger/Breakpoints_v2.xcbkptlist | 5 -
.../xcschemes/xcschememanagement.plist | 27 --
.../project.pbxproj | 6 +-
.../contents.xcworkspacedata | 2 +-
.../UserInterfaceState.xcuserstate | Bin 17117 -> 0 bytes
.../UserInterfaceState.xcuserstate | Bin 35030 -> 0 bytes
.../xcdebugger/Breakpoints_v2.xcbkptlist | 5 -
.../xcschemes/TabletDemo.xcscheme | 91 ----
.../xcschemes/xcschememanagement.plist | 22 -
.../xcdebugger/Breakpoints_v2.xcbkptlist | 5 -
.../xcschemes/TabletDemo.xcscheme | 101 ----
.../xcschemes/xcschememanagement.plist | 27 --
45 files changed, 738 insertions(+), 1061 deletions(-)
rename Tablet.podspec => TableKit.podspec (54%)
rename {Tablet.xcworkspace => TableKit.xcworkspace}/contents.xcworkspacedata (53%)
rename {Tablet => TableKit}/ConfigurableCell.swift (100%)
rename {Tablet => TableKit}/HeightStrategy.swift (100%)
rename {Tablet => TableKit}/Info.plist (100%)
rename {Tablet => TableKit}/Operators.swift (100%)
rename {Tablet => TableKit}/TableDirector.swift (100%)
create mode 100644 TableKit/TableKit.h
create mode 100644 TableKit/TableKit.xcodeproj/project.pbxproj
rename {Tablet => TableKit}/TableRow.swift (100%)
rename {Tablet => TableKit}/TableRowAction.swift (100%)
rename {Tablet => TableKit}/TableRowBuilder.swift (100%)
rename {Tablet => TableKit}/TableSection.swift (100%)
rename {Tablet => TableKit}/Tablet.swift (100%)
rename {TabletDemo => TableKitDemo}/Classes/Application/AppDelegate.swift (100%)
rename {TabletDemo => TableKitDemo}/Classes/Presentation/Controllers/HeaderFooterController.swift (98%)
rename {TabletDemo => TableKitDemo}/Classes/Presentation/Controllers/MainController.swift (99%)
rename {TabletDemo => TableKitDemo}/Classes/Presentation/Views/StoryboardImageTableViewCell.swift (98%)
rename {TabletDemo => TableKitDemo}/Classes/Presentation/Views/StoryboardTableViewCell.swift (95%)
rename {TabletDemo => TableKitDemo}/Resources/Assets/Assets.xcassets/AppIcon.appiconset/Contents.json (100%)
rename {TabletDemo => TableKitDemo}/Resources/Info.plist (100%)
rename {TabletDemo => TableKitDemo}/Resources/Storyboards/LaunchScreen.storyboard (100%)
rename {TabletDemo => TableKitDemo}/Resources/Storyboards/Main.storyboard (100%)
create mode 100644 TableKitDemo/TableKitDemo.xcodeproj/project.pbxproj
rename {TabletDemo/TabletDemo.xcodeproj => TableKitDemo/TableKitDemo.xcodeproj}/project.xcworkspace/contents.xcworkspacedata (100%)
delete mode 100644 Tablet.xcworkspace/xcuserdata/max.xcuserdatad/UserInterfaceState.xcuserstate
delete mode 100644 Tablet/Tablet.h
delete mode 100644 Tablet/Tablet.xcodeproj/project.pbxproj
delete mode 100644 Tablet/Tablet.xcodeproj/project.xcworkspace/xcuserdata/maxsokolov.xcuserdatad/UserInterfaceState.xcuserstate
delete mode 100644 Tablet/Tablet.xcodeproj/xcshareddata/xcschemes/Tablet.xcscheme
delete mode 100644 Tablet/Tablet.xcodeproj/xcuserdata/max.xcuserdatad/xcschemes/xcschememanagement.plist
delete mode 100644 Tablet/Tablet.xcodeproj/xcuserdata/maxsokolov.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist
delete mode 100644 Tablet/Tablet.xcodeproj/xcuserdata/maxsokolov.xcuserdatad/xcschemes/xcschememanagement.plist
rename TabletDemo/{TabletDemo.xcodeproj => TableKitDemo.xcodeproj}/project.pbxproj (95%)
rename {Tablet/Tablet.xcodeproj => TabletDemo/TableKitDemo.xcodeproj}/project.xcworkspace/contents.xcworkspacedata (70%)
delete mode 100644 TabletDemo/TabletDemo.xcodeproj/project.xcworkspace/xcuserdata/max.xcuserdatad/UserInterfaceState.xcuserstate
delete mode 100644 TabletDemo/TabletDemo.xcodeproj/project.xcworkspace/xcuserdata/maxsokolov.xcuserdatad/UserInterfaceState.xcuserstate
delete mode 100644 TabletDemo/TabletDemo.xcodeproj/xcuserdata/max.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist
delete mode 100644 TabletDemo/TabletDemo.xcodeproj/xcuserdata/max.xcuserdatad/xcschemes/TabletDemo.xcscheme
delete mode 100644 TabletDemo/TabletDemo.xcodeproj/xcuserdata/max.xcuserdatad/xcschemes/xcschememanagement.plist
delete mode 100644 TabletDemo/TabletDemo.xcodeproj/xcuserdata/maxsokolov.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist
delete mode 100644 TabletDemo/TabletDemo.xcodeproj/xcuserdata/maxsokolov.xcuserdatad/xcschemes/TabletDemo.xcscheme
delete mode 100644 TabletDemo/TabletDemo.xcodeproj/xcuserdata/maxsokolov.xcuserdatad/xcschemes/xcschememanagement.plist
diff --git a/.travis.yml b/.travis.yml
index 99f321d..f57eb70 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -8,4 +8,4 @@ before_install:
- brew reinstall --HEAD xctool
- cd Tablet
script:
- - xctool clean build test -project Tablet.xcodeproj -scheme Tablet -sdk iphonesimulator
\ No newline at end of file
+ - xctool clean build test -project TableKit.xcodeproj -scheme TableKit -sdk iphonesimulator
\ No newline at end of file
diff --git a/README.md b/README.md
index c543553..c9c36fd 100644
--- a/README.md
+++ b/README.md
@@ -1,6 +1,6 @@
-
+
-#Tablet.swift
+#TableKit
@@ -10,7 +10,7 @@
-Tablet is a super lightweight yet powerful generic library that handles a complexity of UITableView's datasource and delegate methods in a Swift environment. Tablet's goal is to provide an easiest way to create complex table views. With Tablet you don't have to write a messy code of `switch` or `if` statements when you deal with bunch of different cells in different sections.
+TableKit is a super lightweight yet powerful generic library that handles a complexity of UITableView's datasource and delegate methods in a Swift environment. Tablet's goal is to provide an easiest way to create complex table views. With Tablet you don't have to write a messy code of `switch` or `if` statements when you deal with bunch of different cells in different sections.
## Features
@@ -24,179 +24,6 @@ Tablet is a super lightweight yet powerful generic library that handles a comple
- [x] Extensibility
- [x] Tests
-That's almost all you need to build a bunch of cells in a section:
-```swift
-let builder = TableRowBuilder(items: ["1", "2", "3", "4", "5"])
-```
-Tablet relies on self-sizing table view cells, respects cells reusability feature and also built with performace in mind. You don't have to worry about anything, just create your cells, setup autolayout constraints and be happy. See the Usage section to learn more.
-
-## Requirements
-
-- iOS 8.0+
-- Xcode 7.0+
-- Swift 2.2
-
-## Installation
-
-### CocoaPods
-To integrate Tablet into your Xcode project using CocoaPods, specify it in your `Podfile`:
-
-```ruby
-source 'https://github.com/CocoaPods/Specs.git'
-platform :ios, '8.0'
-use_frameworks!
-
-pod 'Tablet'
-```
-
-Then, run the following command:
-
-```bash
-$ pod install
-```
-
-## Usage
-
-### Type-safe configurable cells
-
-Let's say you want to put your cell configuration logic into cell itself. Say you want to pass your view model (or even model) to your cell.
-You could easily do this using the `TableRowBuilder`. Your cell should conforms to `ConfigurableCell` protocol as you may see in example below:
-
-```swift
-import Tablet
-
-class MyTableViewCell : UITableViewCell, ConfigurableCell {
-
- typealias T = User
-
- // this method is not required to be implemented if your cell's id equals to class name
- static func reusableIdentifier() -> String {
- return "reusable_id"
- }
-
- static func estimatedHeight() -> Float {
- return 255
- }
-
- func configure(item: T) { // item is user here
-
- textLabel?.text = item.username
- detailTextLabel?.text = item.isActive ? "Active" : "Inactive"
- }
-}
-```
-Once you've implemented the protocol, simply use the `TableRowBuilder` to build cells:
-
-```swift
-import Tablet
-
-let rowBuilder = TableRowBuilder()
-rowBuilder += users
-
-director = TableDirector(tableView: tableView)
-tableDirector += TableSectionBuilder(rows: [rowBuilder])
-```
-
-### Very basic table view
-
-You may want to setup a very basic table view, without any custom cells. In that case simply use the `TableBaseRowBuilder`.
-
-```swift
-import Tablet
-
-let rowBuilder = TableBaseRowBuilder(items: [user1, user2, user3], id: "reusable_id")
- .action(.configure) { (data) in
-
- data.cell?.textLabel?.text = data.item.username
- data.cell?.detailTextLabel?.text = data.item.isActive ? "Active" : "Inactive"
- }
-
-let sectionBuilder = TableSectionBuilder(headerTitle: "Users", footerTitle: nil, rows: [rowBuilder])
-
-director = TableDirector(tableView: tableView)
-director += sectionBuilder
-```
-
-### Cell actions
-
-Tablet provides a chaining approach to handle actions from your cells:
-
-```swift
-import Tablet
-
-let rowBuilder = TableRowBuilder(items: [user1, user2, user3], id: "reusable_id")
- .action(.configure) { (data) in
-
- }
- .action(.click) { (data) in
-
- }
- .valueAction(.shouldHighlight) { (data) in
-
- return false
- }
-```
-
-### Custom cell actions
-```swift
-import Tablet
-
-struct MyCellActions {
- static let ButtonClicked = "ButtonClicked"
-}
-
-class MyTableViewCell : UITableViewCell {
-
- @IBAction func buttonClicked(sender: UIButton) {
-
- Action(key: MyCellActions.ButtonClicked, sender: self, userInfo: nil).invoke()
- }
-}
-```
-And receive this actions with your row builder:
-```swift
-import Tablet
-
-let rowBuilder = TableRowBuilder(items: users)
- .action(.click) { (data) in
-
- }
- .action(.willDisplay) { (data) in
-
- }
- .action(MyCellActions.ButtonClicked) { (data) in
-
- }
-```
-
-## Extensibility
-
-If you find that Tablet is not provide an action you need, for example you need UITableViewDelegate's `didEndDisplayingCell` method and it's not out of the box,
-simply provide an extension for `TableDirector`:
-```swift
-import Tablet
-
-struct MyTableActions {
- static let DidEndDisplayingCell = "DidEndDisplayingCell"
-}
-
-extension TableDirector {
-
- public func tableView(tableView: UITableView, didEndDisplayingCell cell: UITableViewCell, forRowAtIndexPath indexPath: NSIndexPath) {
-
- invoke(action: .custom(MyTableActions.DidEndDisplayingCell), cell: cell, indexPath: indexPath)
- }
-}
-```
-Catch your action with row builder:
-```swift
-let rowBuilder = TableRowBuilder(items: users)
- .action(MyTableActions.DidEndDisplayingCell) { (data) -> Void in
-
- }
-```
-You could also invoke an action that returns a value.
-
## License
Tablet is available under the MIT license. See LICENSE for details.
\ No newline at end of file
diff --git a/Tablet.podspec b/TableKit.podspec
similarity index 54%
rename from Tablet.podspec
rename to TableKit.podspec
index c5be448..cdabc6c 100644
--- a/Tablet.podspec
+++ b/TableKit.podspec
@@ -1,17 +1,17 @@
Pod::Spec.new do |s|
- s.name = 'Tablet'
- s.module_name = 'Tablet'
+ s.name = 'TableKit'
+ s.module_name = 'TableKit'
- s.version = '0.5.0'
+ s.version = '0.6.0'
- s.homepage = 'https://github.com/maxsokolov/Tablet.swift'
- s.summary = 'Powerful type-safe tool for UITableView. Swift 2.2 is required.'
+ s.homepage = 'https://github.com/maxsokolov/TableKit'
+ s.summary = 'Type-safe declarative table views. Swift 2.2 is required.'
s.author = { 'Max Sokolov' => 'i@maxsokolov.net' }
s.license = { :type => 'MIT', :file => 'LICENSE' }
s.platforms = { :ios => '8.0' }
s.ios.deployment_target = '8.0'
- s.source_files = 'Tablet/*.swift'
- s.source = { :git => 'https://github.com/maxsokolov/Tablet.swift.git', :tag => s.version }
+ s.source_files = 'TableKit/*.swift'
+ s.source = { :git => 'https://github.com/maxsokolov/TableKit.git', :tag => s.version }
end
\ No newline at end of file
diff --git a/Tablet.xcworkspace/contents.xcworkspacedata b/TableKit.xcworkspace/contents.xcworkspacedata
similarity index 53%
rename from Tablet.xcworkspace/contents.xcworkspacedata
rename to TableKit.xcworkspace/contents.xcworkspacedata
index 8a2fad4..134624f 100644
--- a/Tablet.xcworkspace/contents.xcworkspacedata
+++ b/TableKit.xcworkspace/contents.xcworkspacedata
@@ -2,9 +2,9 @@
+ location = "group:TableKit/TableKit.xcodeproj">
+ location = "group:TableKitDemo/TableKitDemo.xcodeproj">
diff --git a/Tablet/ConfigurableCell.swift b/TableKit/ConfigurableCell.swift
similarity index 100%
rename from Tablet/ConfigurableCell.swift
rename to TableKit/ConfigurableCell.swift
diff --git a/Tablet/HeightStrategy.swift b/TableKit/HeightStrategy.swift
similarity index 100%
rename from Tablet/HeightStrategy.swift
rename to TableKit/HeightStrategy.swift
diff --git a/Tablet/Info.plist b/TableKit/Info.plist
similarity index 100%
rename from Tablet/Info.plist
rename to TableKit/Info.plist
diff --git a/Tablet/Operators.swift b/TableKit/Operators.swift
similarity index 100%
rename from Tablet/Operators.swift
rename to TableKit/Operators.swift
diff --git a/Tablet/TableDirector.swift b/TableKit/TableDirector.swift
similarity index 100%
rename from Tablet/TableDirector.swift
rename to TableKit/TableDirector.swift
diff --git a/TableKit/TableKit.h b/TableKit/TableKit.h
new file mode 100644
index 0000000..c63484c
--- /dev/null
+++ b/TableKit/TableKit.h
@@ -0,0 +1,19 @@
+//
+// TableKit.h
+// TableKit
+//
+// Created by Max Sokolov on 11/06/16.
+// Copyright © 2016 Max Sokolov. All rights reserved.
+//
+
+#import
+
+//! Project version number for TableKit.
+FOUNDATION_EXPORT double TableKitVersionNumber;
+
+//! Project version string for TableKit.
+FOUNDATION_EXPORT const unsigned char TableKitVersionString[];
+
+// In this header, you should import all the public headers of your framework using statements like #import
+
+
diff --git a/TableKit/TableKit.xcodeproj/project.pbxproj b/TableKit/TableKit.xcodeproj/project.pbxproj
new file mode 100644
index 0000000..bf9dc87
--- /dev/null
+++ b/TableKit/TableKit.xcodeproj/project.pbxproj
@@ -0,0 +1,335 @@
+// !$*UTF8*$!
+{
+ archiveVersion = 1;
+ classes = {
+ };
+ objectVersion = 46;
+ objects = {
+
+/* Begin PBXBuildFile section */
+ DA9EA7711D0B68460021F650 /* ConfigurableCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA7681D0B68460021F650 /* ConfigurableCell.swift */; };
+ DA9EA7721D0B68460021F650 /* HeightStrategy.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA7691D0B68460021F650 /* HeightStrategy.swift */; };
+ DA9EA7731D0B68460021F650 /* Operators.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA76A1D0B68460021F650 /* Operators.swift */; };
+ DA9EA7741D0B68460021F650 /* TableDirector.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA76B1D0B68460021F650 /* TableDirector.swift */; };
+ DA9EA7751D0B68460021F650 /* TableRow.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA76C1D0B68460021F650 /* TableRow.swift */; };
+ DA9EA7761D0B68460021F650 /* TableRowAction.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA76D1D0B68460021F650 /* TableRowAction.swift */; };
+ DA9EA7771D0B68460021F650 /* TableRowBuilder.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA76E1D0B68460021F650 /* TableRowBuilder.swift */; };
+ DA9EA7781D0B68460021F650 /* TableSection.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA76F1D0B68460021F650 /* TableSection.swift */; };
+ DA9EA7791D0B68460021F650 /* Tablet.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA9EA7701D0B68460021F650 /* Tablet.swift */; };
+ DA9EA7801D0B689C0021F650 /* TableKit.h in Headers */ = {isa = PBXBuildFile; fileRef = DA9EA77E1D0B689C0021F650 /* TableKit.h */; settings = {ATTRIBUTES = (Public, ); }; };
+/* End PBXBuildFile section */
+
+/* Begin PBXFileReference section */
+ DA9EA7561D0B679A0021F650 /* TableKit.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = TableKit.framework; sourceTree = BUILT_PRODUCTS_DIR; };
+ DA9EA7681D0B68460021F650 /* ConfigurableCell.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = ConfigurableCell.swift; sourceTree = ""; };
+ DA9EA7691D0B68460021F650 /* HeightStrategy.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = HeightStrategy.swift; sourceTree = ""; };
+ DA9EA76A1D0B68460021F650 /* Operators.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Operators.swift; sourceTree = ""; };
+ DA9EA76B1D0B68460021F650 /* TableDirector.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TableDirector.swift; sourceTree = ""; };
+ DA9EA76C1D0B68460021F650 /* TableRow.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TableRow.swift; sourceTree = ""; };
+ DA9EA76D1D0B68460021F650 /* TableRowAction.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TableRowAction.swift; sourceTree = ""; };
+ DA9EA76E1D0B68460021F650 /* TableRowBuilder.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TableRowBuilder.swift; sourceTree = ""; };
+ DA9EA76F1D0B68460021F650 /* TableSection.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = TableSection.swift; sourceTree = ""; };
+ DA9EA7701D0B68460021F650 /* Tablet.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = Tablet.swift; sourceTree = ""; };
+ DA9EA77D1D0B689C0021F650 /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
+ DA9EA77E1D0B689C0021F650 /* TableKit.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TableKit.h; sourceTree = ""; };
+/* End PBXFileReference section */
+
+/* Begin PBXFrameworksBuildPhase section */
+ DA9EA7521D0B679A0021F650 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXFrameworksBuildPhase section */
+
+/* Begin PBXGroup section */
+ DA9EA74C1D0B679A0021F650 = {
+ isa = PBXGroup;
+ children = (
+ DA9EA7671D0B68340021F650 /* Classes */,
+ DA9EA7571D0B679A0021F650 /* Products */,
+ DA9EA77C1D0B68860021F650 /* Supporting Files */,
+ );
+ sourceTree = "";
+ };
+ DA9EA7571D0B679A0021F650 /* Products */ = {
+ isa = PBXGroup;
+ children = (
+ DA9EA7561D0B679A0021F650 /* TableKit.framework */,
+ );
+ name = Products;
+ sourceTree = "";
+ };
+ DA9EA7671D0B68340021F650 /* Classes */ = {
+ isa = PBXGroup;
+ children = (
+ DA9EA7681D0B68460021F650 /* ConfigurableCell.swift */,
+ DA9EA7691D0B68460021F650 /* HeightStrategy.swift */,
+ DA9EA76A1D0B68460021F650 /* Operators.swift */,
+ DA9EA76B1D0B68460021F650 /* TableDirector.swift */,
+ DA9EA76C1D0B68460021F650 /* TableRow.swift */,
+ DA9EA76D1D0B68460021F650 /* TableRowAction.swift */,
+ DA9EA76E1D0B68460021F650 /* TableRowBuilder.swift */,
+ DA9EA76F1D0B68460021F650 /* TableSection.swift */,
+ DA9EA7701D0B68460021F650 /* Tablet.swift */,
+ );
+ name = Classes;
+ sourceTree = "";
+ };
+ DA9EA77C1D0B68860021F650 /* Supporting Files */ = {
+ isa = PBXGroup;
+ children = (
+ DA9EA77D1D0B689C0021F650 /* Info.plist */,
+ DA9EA77E1D0B689C0021F650 /* TableKit.h */,
+ );
+ name = "Supporting Files";
+ sourceTree = "";
+ };
+/* End PBXGroup section */
+
+/* Begin PBXHeadersBuildPhase section */
+ DA9EA7531D0B679A0021F650 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ DA9EA7801D0B689C0021F650 /* TableKit.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXHeadersBuildPhase section */
+
+/* Begin PBXNativeTarget section */
+ DA9EA7551D0B679A0021F650 /* TableKit */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = DA9EA75E1D0B679A0021F650 /* Build configuration list for PBXNativeTarget "TableKit" */;
+ buildPhases = (
+ DA9EA7511D0B679A0021F650 /* Sources */,
+ DA9EA7521D0B679A0021F650 /* Frameworks */,
+ DA9EA7531D0B679A0021F650 /* Headers */,
+ DA9EA7541D0B679A0021F650 /* Resources */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ );
+ name = TableKit;
+ productName = TableKit;
+ productReference = DA9EA7561D0B679A0021F650 /* TableKit.framework */;
+ productType = "com.apple.product-type.framework";
+ };
+/* End PBXNativeTarget section */
+
+/* Begin PBXProject section */
+ DA9EA74D1D0B679A0021F650 /* Project object */ = {
+ isa = PBXProject;
+ attributes = {
+ LastUpgradeCheck = 0730;
+ ORGANIZATIONNAME = "Max Sokolov";
+ TargetAttributes = {
+ DA9EA7551D0B679A0021F650 = {
+ CreatedOnToolsVersion = 7.3;
+ };
+ };
+ };
+ buildConfigurationList = DA9EA7501D0B679A0021F650 /* Build configuration list for PBXProject "TableKit" */;
+ compatibilityVersion = "Xcode 3.2";
+ developmentRegion = English;
+ hasScannedForEncodings = 0;
+ knownRegions = (
+ en,
+ );
+ mainGroup = DA9EA74C1D0B679A0021F650;
+ productRefGroup = DA9EA7571D0B679A0021F650 /* Products */;
+ projectDirPath = "";
+ projectRoot = "";
+ targets = (
+ DA9EA7551D0B679A0021F650 /* TableKit */,
+ );
+ };
+/* End PBXProject section */
+
+/* Begin PBXResourcesBuildPhase section */
+ DA9EA7541D0B679A0021F650 /* Resources */ = {
+ isa = PBXResourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXResourcesBuildPhase section */
+
+/* Begin PBXSourcesBuildPhase section */
+ DA9EA7511D0B679A0021F650 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ DA9EA7711D0B68460021F650 /* ConfigurableCell.swift in Sources */,
+ DA9EA7721D0B68460021F650 /* HeightStrategy.swift in Sources */,
+ DA9EA7781D0B68460021F650 /* TableSection.swift in Sources */,
+ DA9EA7751D0B68460021F650 /* TableRow.swift in Sources */,
+ DA9EA7761D0B68460021F650 /* TableRowAction.swift in Sources */,
+ DA9EA7741D0B68460021F650 /* TableDirector.swift in Sources */,
+ DA9EA7771D0B68460021F650 /* TableRowBuilder.swift in Sources */,
+ DA9EA7791D0B68460021F650 /* Tablet.swift in Sources */,
+ DA9EA7731D0B68460021F650 /* Operators.swift in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXSourcesBuildPhase section */
+
+/* Begin XCBuildConfiguration section */
+ DA9EA75C1D0B679A0021F650 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ALWAYS_SEARCH_USER_PATHS = NO;
+ CLANG_ANALYZER_NONNULL = YES;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
+ CLANG_CXX_LIBRARY = "libc++";
+ CLANG_ENABLE_MODULES = YES;
+ CLANG_ENABLE_OBJC_ARC = YES;
+ CLANG_WARN_BOOL_CONVERSION = YES;
+ CLANG_WARN_CONSTANT_CONVERSION = YES;
+ CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
+ CLANG_WARN_EMPTY_BODY = YES;
+ CLANG_WARN_ENUM_CONVERSION = YES;
+ CLANG_WARN_INT_CONVERSION = YES;
+ CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
+ CLANG_WARN_UNREACHABLE_CODE = YES;
+ CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
+ "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
+ COPY_PHASE_STRIP = NO;
+ CURRENT_PROJECT_VERSION = 1;
+ DEBUG_INFORMATION_FORMAT = dwarf;
+ ENABLE_STRICT_OBJC_MSGSEND = YES;
+ ENABLE_TESTABILITY = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu99;
+ GCC_DYNAMIC_NO_PIC = NO;
+ GCC_NO_COMMON_BLOCKS = YES;
+ GCC_OPTIMIZATION_LEVEL = 0;
+ GCC_PREPROCESSOR_DEFINITIONS = (
+ "DEBUG=1",
+ "$(inherited)",
+ );
+ GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
+ GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
+ GCC_WARN_UNDECLARED_SELECTOR = YES;
+ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
+ GCC_WARN_UNUSED_FUNCTION = YES;
+ GCC_WARN_UNUSED_VARIABLE = YES;
+ IPHONEOS_DEPLOYMENT_TARGET = 9.3;
+ MTL_ENABLE_DEBUG_INFO = YES;
+ ONLY_ACTIVE_ARCH = YES;
+ SDKROOT = iphoneos;
+ SWIFT_OPTIMIZATION_LEVEL = "-Onone";
+ TARGETED_DEVICE_FAMILY = "1,2";
+ VERSIONING_SYSTEM = "apple-generic";
+ VERSION_INFO_PREFIX = "";
+ };
+ name = Debug;
+ };
+ DA9EA75D1D0B679A0021F650 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ALWAYS_SEARCH_USER_PATHS = NO;
+ CLANG_ANALYZER_NONNULL = YES;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
+ CLANG_CXX_LIBRARY = "libc++";
+ CLANG_ENABLE_MODULES = YES;
+ CLANG_ENABLE_OBJC_ARC = YES;
+ CLANG_WARN_BOOL_CONVERSION = YES;
+ CLANG_WARN_CONSTANT_CONVERSION = YES;
+ CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
+ CLANG_WARN_EMPTY_BODY = YES;
+ CLANG_WARN_ENUM_CONVERSION = YES;
+ CLANG_WARN_INT_CONVERSION = YES;
+ CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
+ CLANG_WARN_UNREACHABLE_CODE = YES;
+ CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
+ "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
+ COPY_PHASE_STRIP = NO;
+ CURRENT_PROJECT_VERSION = 1;
+ DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
+ ENABLE_NS_ASSERTIONS = NO;
+ ENABLE_STRICT_OBJC_MSGSEND = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu99;
+ GCC_NO_COMMON_BLOCKS = YES;
+ GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
+ GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
+ GCC_WARN_UNDECLARED_SELECTOR = YES;
+ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
+ GCC_WARN_UNUSED_FUNCTION = YES;
+ GCC_WARN_UNUSED_VARIABLE = YES;
+ IPHONEOS_DEPLOYMENT_TARGET = 9.3;
+ MTL_ENABLE_DEBUG_INFO = NO;
+ SDKROOT = iphoneos;
+ TARGETED_DEVICE_FAMILY = "1,2";
+ VALIDATE_PRODUCT = YES;
+ VERSIONING_SYSTEM = "apple-generic";
+ VERSION_INFO_PREFIX = "";
+ };
+ name = Release;
+ };
+ DA9EA75F1D0B679A0021F650 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CLANG_ENABLE_MODULES = YES;
+ DEFINES_MODULE = YES;
+ DYLIB_COMPATIBILITY_VERSION = 1;
+ DYLIB_CURRENT_VERSION = 1;
+ DYLIB_INSTALL_NAME_BASE = "@rpath";
+ INFOPLIST_FILE = "$(SRCROOT)/Info.plist";
+ INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks";
+ IPHONEOS_DEPLOYMENT_TARGET = 8.0;
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
+ PRODUCT_BUNDLE_IDENTIFIER = com.tablekit.TableKit;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SKIP_INSTALL = YES;
+ SWIFT_OPTIMIZATION_LEVEL = "-Onone";
+ };
+ name = Debug;
+ };
+ DA9EA7601D0B679A0021F650 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CLANG_ENABLE_MODULES = YES;
+ DEFINES_MODULE = YES;
+ DYLIB_COMPATIBILITY_VERSION = 1;
+ DYLIB_CURRENT_VERSION = 1;
+ DYLIB_INSTALL_NAME_BASE = "@rpath";
+ INFOPLIST_FILE = "$(SRCROOT)/Info.plist";
+ INSTALL_PATH = "$(LOCAL_LIBRARY_DIR)/Frameworks";
+ IPHONEOS_DEPLOYMENT_TARGET = 8.0;
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
+ PRODUCT_BUNDLE_IDENTIFIER = com.tablekit.TableKit;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SKIP_INSTALL = YES;
+ };
+ name = Release;
+ };
+/* End XCBuildConfiguration section */
+
+/* Begin XCConfigurationList section */
+ DA9EA7501D0B679A0021F650 /* Build configuration list for PBXProject "TableKit" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ DA9EA75C1D0B679A0021F650 /* Debug */,
+ DA9EA75D1D0B679A0021F650 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ DA9EA75E1D0B679A0021F650 /* Build configuration list for PBXNativeTarget "TableKit" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ DA9EA75F1D0B679A0021F650 /* Debug */,
+ DA9EA7601D0B679A0021F650 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+/* End XCConfigurationList section */
+ };
+ rootObject = DA9EA74D1D0B679A0021F650 /* Project object */;
+}
diff --git a/Tablet/TableRow.swift b/TableKit/TableRow.swift
similarity index 100%
rename from Tablet/TableRow.swift
rename to TableKit/TableRow.swift
diff --git a/Tablet/TableRowAction.swift b/TableKit/TableRowAction.swift
similarity index 100%
rename from Tablet/TableRowAction.swift
rename to TableKit/TableRowAction.swift
diff --git a/Tablet/TableRowBuilder.swift b/TableKit/TableRowBuilder.swift
similarity index 100%
rename from Tablet/TableRowBuilder.swift
rename to TableKit/TableRowBuilder.swift
diff --git a/Tablet/TableSection.swift b/TableKit/TableSection.swift
similarity index 100%
rename from Tablet/TableSection.swift
rename to TableKit/TableSection.swift
diff --git a/Tablet/Tablet.swift b/TableKit/Tablet.swift
similarity index 100%
rename from Tablet/Tablet.swift
rename to TableKit/Tablet.swift
diff --git a/TabletDemo/Classes/Application/AppDelegate.swift b/TableKitDemo/Classes/Application/AppDelegate.swift
similarity index 100%
rename from TabletDemo/Classes/Application/AppDelegate.swift
rename to TableKitDemo/Classes/Application/AppDelegate.swift
diff --git a/TabletDemo/Classes/Presentation/Controllers/HeaderFooterController.swift b/TableKitDemo/Classes/Presentation/Controllers/HeaderFooterController.swift
similarity index 98%
rename from TabletDemo/Classes/Presentation/Controllers/HeaderFooterController.swift
rename to TableKitDemo/Classes/Presentation/Controllers/HeaderFooterController.swift
index 47c030d..6c8d62f 100644
--- a/TabletDemo/Classes/Presentation/Controllers/HeaderFooterController.swift
+++ b/TableKitDemo/Classes/Presentation/Controllers/HeaderFooterController.swift
@@ -7,7 +7,7 @@
//
import UIKit
-import Tablet
+import TableKit
class HeaderFooterController: UIViewController {
diff --git a/TabletDemo/Classes/Presentation/Controllers/MainController.swift b/TableKitDemo/Classes/Presentation/Controllers/MainController.swift
similarity index 99%
rename from TabletDemo/Classes/Presentation/Controllers/MainController.swift
rename to TableKitDemo/Classes/Presentation/Controllers/MainController.swift
index 0a803a5..9a2f174 100644
--- a/TabletDemo/Classes/Presentation/Controllers/MainController.swift
+++ b/TableKitDemo/Classes/Presentation/Controllers/MainController.swift
@@ -7,7 +7,7 @@
//
import UIKit
-import Tablet
+import TableKit
class MainController: UIViewController {
diff --git a/TabletDemo/Classes/Presentation/Views/StoryboardImageTableViewCell.swift b/TableKitDemo/Classes/Presentation/Views/StoryboardImageTableViewCell.swift
similarity index 98%
rename from TabletDemo/Classes/Presentation/Views/StoryboardImageTableViewCell.swift
rename to TableKitDemo/Classes/Presentation/Views/StoryboardImageTableViewCell.swift
index 45bf5b6..c809967 100644
--- a/TabletDemo/Classes/Presentation/Views/StoryboardImageTableViewCell.swift
+++ b/TableKitDemo/Classes/Presentation/Views/StoryboardImageTableViewCell.swift
@@ -7,7 +7,7 @@
//
import UIKit
-import Tablet
+import TableKit
class StoryboardImageTableViewCell: UITableViewCell, ConfigurableCell {
diff --git a/TabletDemo/Classes/Presentation/Views/StoryboardTableViewCell.swift b/TableKitDemo/Classes/Presentation/Views/StoryboardTableViewCell.swift
similarity index 95%
rename from TabletDemo/Classes/Presentation/Views/StoryboardTableViewCell.swift
rename to TableKitDemo/Classes/Presentation/Views/StoryboardTableViewCell.swift
index 1f06499..8180860 100644
--- a/TabletDemo/Classes/Presentation/Views/StoryboardTableViewCell.swift
+++ b/TableKitDemo/Classes/Presentation/Views/StoryboardTableViewCell.swift
@@ -7,7 +7,7 @@
//
import UIKit
-import Tablet
+import TableKit
class StoryboardTableViewCell: UITableViewCell, ConfigurableCell {
diff --git a/TabletDemo/Resources/Assets/Assets.xcassets/AppIcon.appiconset/Contents.json b/TableKitDemo/Resources/Assets/Assets.xcassets/AppIcon.appiconset/Contents.json
similarity index 100%
rename from TabletDemo/Resources/Assets/Assets.xcassets/AppIcon.appiconset/Contents.json
rename to TableKitDemo/Resources/Assets/Assets.xcassets/AppIcon.appiconset/Contents.json
diff --git a/TabletDemo/Resources/Info.plist b/TableKitDemo/Resources/Info.plist
similarity index 100%
rename from TabletDemo/Resources/Info.plist
rename to TableKitDemo/Resources/Info.plist
diff --git a/TabletDemo/Resources/Storyboards/LaunchScreen.storyboard b/TableKitDemo/Resources/Storyboards/LaunchScreen.storyboard
similarity index 100%
rename from TabletDemo/Resources/Storyboards/LaunchScreen.storyboard
rename to TableKitDemo/Resources/Storyboards/LaunchScreen.storyboard
diff --git a/TabletDemo/Resources/Storyboards/Main.storyboard b/TableKitDemo/Resources/Storyboards/Main.storyboard
similarity index 100%
rename from TabletDemo/Resources/Storyboards/Main.storyboard
rename to TableKitDemo/Resources/Storyboards/Main.storyboard
diff --git a/TableKitDemo/TableKitDemo.xcodeproj/project.pbxproj b/TableKitDemo/TableKitDemo.xcodeproj/project.pbxproj
new file mode 100644
index 0000000..9175ff7
--- /dev/null
+++ b/TableKitDemo/TableKitDemo.xcodeproj/project.pbxproj
@@ -0,0 +1,362 @@
+// !$*UTF8*$!
+{
+ archiveVersion = 1;
+ classes = {
+ };
+ objectVersion = 46;
+ objects = {
+
+/* Begin PBXBuildFile section */
+ DA08A0531CF4E9B500BBF1F8 /* StoryboardImageTableViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = DA08A0521CF4E9B500BBF1F8 /* StoryboardImageTableViewCell.swift */; };
+ DA9EA7821D0B6B070021F650 /* TableKit.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = DA9EA7811D0B6B070021F650 /* TableKit.framework */; };
+ DAC2D5CA1C9D303E009E9C19 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = DAC2D5C91C9D303E009E9C19 /* AppDelegate.swift */; };
+ DAC2D5CF1C9D30A7009E9C19 /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = DAC2D5CD1C9D30A7009E9C19 /* Main.storyboard */; };
+ DAC2D5D01C9D30A7009E9C19 /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = DAC2D5CE1C9D30A7009E9C19 /* LaunchScreen.storyboard */; };
+ DAC2D69C1C9E75E3009E9C19 /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = DAC2D69B1C9E75E3009E9C19 /* Assets.xcassets */; };
+ DACB71761CC2D63D00432BD3 /* MainController.swift in Sources */ = {isa = PBXBuildFile; fileRef = DACB71751CC2D63D00432BD3 /* MainController.swift */; };
+ DACB71781CC2D6ED00432BD3 /* StoryboardTableViewCell.swift in Sources */ = {isa = PBXBuildFile; fileRef = DACB71771CC2D6ED00432BD3 /* StoryboardTableViewCell.swift */; };
+ DACB717A1CC2D89D00432BD3 /* HeaderFooterController.swift in Sources */ = {isa = PBXBuildFile; fileRef = DACB71791CC2D89D00432BD3 /* HeaderFooterController.swift */; };
+/* End PBXBuildFile section */
+
+/* Begin PBXFileReference section */
+ DA08A0521CF4E9B500BBF1F8 /* StoryboardImageTableViewCell.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = StoryboardImageTableViewCell.swift; sourceTree = ""; };
+ DA9EA7811D0B6B070021F650 /* TableKit.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = TableKit.framework; path = "../../../../../Library/Developer/Xcode/DerivedData/TableKit-blgxvmkyvpocltgadmpliruugomo/Build/Products/Debug-iphonesimulator/TableKit.framework"; sourceTree = ""; };
+ DAB7EB271BEF787300D2AD5E /* TableKitDemo.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = TableKitDemo.app; sourceTree = BUILT_PRODUCTS_DIR; };
+ DAC2D5C91C9D303E009E9C19 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; };
+ DAC2D5CD1C9D30A7009E9C19 /* Main.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; path = Main.storyboard; sourceTree = ""; };
+ DAC2D5CE1C9D30A7009E9C19 /* LaunchScreen.storyboard */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = file.storyboard; path = LaunchScreen.storyboard; sourceTree = ""; };
+ DAC2D69B1C9E75E3009E9C19 /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; };
+ DAC2D69D1C9E78B5009E9C19 /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; };
+ DACB71751CC2D63D00432BD3 /* MainController.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = MainController.swift; sourceTree = ""; };
+ DACB71771CC2D6ED00432BD3 /* StoryboardTableViewCell.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = StoryboardTableViewCell.swift; sourceTree = ""; };
+ DACB71791CC2D89D00432BD3 /* HeaderFooterController.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = HeaderFooterController.swift; sourceTree = ""; };
+/* End PBXFileReference section */
+
+/* Begin PBXFrameworksBuildPhase section */
+ DAB7EB241BEF787300D2AD5E /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ DA9EA7821D0B6B070021F650 /* TableKit.framework in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXFrameworksBuildPhase section */
+
+/* Begin PBXGroup section */
+ DA539C871CF50B1800368ACB /* Frameworks */ = {
+ isa = PBXGroup;
+ children = (
+ DA9EA7811D0B6B070021F650 /* TableKit.framework */,
+ );
+ name = Frameworks;
+ sourceTree = "";
+ };
+ DAB7EB1E1BEF787300D2AD5E = {
+ isa = PBXGroup;
+ children = (
+ DAC2D5C61C9D2FE5009E9C19 /* Classes */,
+ DAC2D5CB1C9D3058009E9C19 /* Resources */,
+ DA539C871CF50B1800368ACB /* Frameworks */,
+ DAB7EB281BEF787300D2AD5E /* Products */,
+ );
+ sourceTree = "";
+ };
+ DAB7EB281BEF787300D2AD5E /* Products */ = {
+ isa = PBXGroup;
+ children = (
+ DAB7EB271BEF787300D2AD5E /* TableKitDemo.app */,
+ );
+ name = Products;
+ sourceTree = "";
+ };
+ DAC2D5C61C9D2FE5009E9C19 /* Classes */ = {
+ isa = PBXGroup;
+ children = (
+ DAC2D5C81C9D3014009E9C19 /* Application */,
+ DAC2D5C71C9D3005009E9C19 /* Presentation */,
+ );
+ path = Classes;
+ sourceTree = "";
+ };
+ DAC2D5C71C9D3005009E9C19 /* Presentation */ = {
+ isa = PBXGroup;
+ children = (
+ DACB71731CC2D5ED00432BD3 /* Controllers */,
+ DACB71741CC2D5FD00432BD3 /* Views */,
+ );
+ path = Presentation;
+ sourceTree = "";
+ };
+ DAC2D5C81C9D3014009E9C19 /* Application */ = {
+ isa = PBXGroup;
+ children = (
+ DAC2D5C91C9D303E009E9C19 /* AppDelegate.swift */,
+ );
+ path = Application;
+ sourceTree = "";
+ };
+ DAC2D5CB1C9D3058009E9C19 /* Resources */ = {
+ isa = PBXGroup;
+ children = (
+ DAC2D69D1C9E78B5009E9C19 /* Info.plist */,
+ DAC2D69A1C9E75BE009E9C19 /* Assets */,
+ DAC2D5CC1C9D306C009E9C19 /* Storyboards */,
+ );
+ path = Resources;
+ sourceTree = "";
+ };
+ DAC2D5CC1C9D306C009E9C19 /* Storyboards */ = {
+ isa = PBXGroup;
+ children = (
+ DAC2D5CD1C9D30A7009E9C19 /* Main.storyboard */,
+ DAC2D5CE1C9D30A7009E9C19 /* LaunchScreen.storyboard */,
+ );
+ path = Storyboards;
+ sourceTree = "";
+ };
+ DAC2D69A1C9E75BE009E9C19 /* Assets */ = {
+ isa = PBXGroup;
+ children = (
+ DAC2D69B1C9E75E3009E9C19 /* Assets.xcassets */,
+ );
+ path = Assets;
+ sourceTree = "";
+ };
+ DACB71731CC2D5ED00432BD3 /* Controllers */ = {
+ isa = PBXGroup;
+ children = (
+ DACB71751CC2D63D00432BD3 /* MainController.swift */,
+ DACB71791CC2D89D00432BD3 /* HeaderFooterController.swift */,
+ );
+ path = Controllers;
+ sourceTree = "";
+ };
+ DACB71741CC2D5FD00432BD3 /* Views */ = {
+ isa = PBXGroup;
+ children = (
+ DACB71771CC2D6ED00432BD3 /* StoryboardTableViewCell.swift */,
+ DA08A0521CF4E9B500BBF1F8 /* StoryboardImageTableViewCell.swift */,
+ );
+ path = Views;
+ sourceTree = "";
+ };
+/* End PBXGroup section */
+
+/* Begin PBXNativeTarget section */
+ DAB7EB261BEF787300D2AD5E /* TableKitDemo */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = DAB7EB391BEF787300D2AD5E /* Build configuration list for PBXNativeTarget "TableKitDemo" */;
+ buildPhases = (
+ DAB7EB231BEF787300D2AD5E /* Sources */,
+ DAB7EB241BEF787300D2AD5E /* Frameworks */,
+ DAB7EB251BEF787300D2AD5E /* Resources */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ );
+ name = TableKitDemo;
+ productName = TabletDemo;
+ productReference = DAB7EB271BEF787300D2AD5E /* TableKitDemo.app */;
+ productType = "com.apple.product-type.application";
+ };
+/* End PBXNativeTarget section */
+
+/* Begin PBXProject section */
+ DAB7EB1F1BEF787300D2AD5E /* Project object */ = {
+ isa = PBXProject;
+ attributes = {
+ LastSwiftUpdateCheck = 0720;
+ LastUpgradeCheck = 0700;
+ ORGANIZATIONNAME = Tablet;
+ TargetAttributes = {
+ DAB7EB261BEF787300D2AD5E = {
+ CreatedOnToolsVersion = 7.0.1;
+ DevelopmentTeam = Z48R734SJX;
+ };
+ };
+ };
+ buildConfigurationList = DAB7EB221BEF787300D2AD5E /* Build configuration list for PBXProject "TableKitDemo" */;
+ compatibilityVersion = "Xcode 3.2";
+ developmentRegion = English;
+ hasScannedForEncodings = 0;
+ knownRegions = (
+ en,
+ Base,
+ );
+ mainGroup = DAB7EB1E1BEF787300D2AD5E;
+ productRefGroup = DAB7EB281BEF787300D2AD5E /* Products */;
+ projectDirPath = "";
+ projectRoot = "";
+ targets = (
+ DAB7EB261BEF787300D2AD5E /* TableKitDemo */,
+ );
+ };
+/* End PBXProject section */
+
+/* Begin PBXResourcesBuildPhase section */
+ DAB7EB251BEF787300D2AD5E /* Resources */ = {
+ isa = PBXResourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ DAC2D5CF1C9D30A7009E9C19 /* Main.storyboard in Resources */,
+ DAC2D5D01C9D30A7009E9C19 /* LaunchScreen.storyboard in Resources */,
+ DAC2D69C1C9E75E3009E9C19 /* Assets.xcassets in Resources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXResourcesBuildPhase section */
+
+/* Begin PBXSourcesBuildPhase section */
+ DAB7EB231BEF787300D2AD5E /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ DACB71781CC2D6ED00432BD3 /* StoryboardTableViewCell.swift in Sources */,
+ DACB71761CC2D63D00432BD3 /* MainController.swift in Sources */,
+ DAC2D5CA1C9D303E009E9C19 /* AppDelegate.swift in Sources */,
+ DACB717A1CC2D89D00432BD3 /* HeaderFooterController.swift in Sources */,
+ DA08A0531CF4E9B500BBF1F8 /* StoryboardImageTableViewCell.swift in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXSourcesBuildPhase section */
+
+/* Begin XCBuildConfiguration section */
+ DAB7EB371BEF787300D2AD5E /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ALWAYS_SEARCH_USER_PATHS = NO;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
+ CLANG_CXX_LIBRARY = "libc++";
+ CLANG_ENABLE_MODULES = YES;
+ CLANG_ENABLE_OBJC_ARC = YES;
+ CLANG_WARN_BOOL_CONVERSION = YES;
+ CLANG_WARN_CONSTANT_CONVERSION = YES;
+ CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
+ CLANG_WARN_EMPTY_BODY = YES;
+ CLANG_WARN_ENUM_CONVERSION = YES;
+ CLANG_WARN_INT_CONVERSION = YES;
+ CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
+ CLANG_WARN_UNREACHABLE_CODE = YES;
+ CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
+ "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
+ COPY_PHASE_STRIP = NO;
+ DEBUG_INFORMATION_FORMAT = dwarf;
+ ENABLE_STRICT_OBJC_MSGSEND = YES;
+ ENABLE_TESTABILITY = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu99;
+ GCC_DYNAMIC_NO_PIC = NO;
+ GCC_NO_COMMON_BLOCKS = YES;
+ GCC_OPTIMIZATION_LEVEL = 0;
+ GCC_PREPROCESSOR_DEFINITIONS = (
+ "DEBUG=1",
+ "$(inherited)",
+ );
+ GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
+ GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
+ GCC_WARN_UNDECLARED_SELECTOR = YES;
+ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
+ GCC_WARN_UNUSED_FUNCTION = YES;
+ GCC_WARN_UNUSED_VARIABLE = YES;
+ IPHONEOS_DEPLOYMENT_TARGET = 8.0;
+ MTL_ENABLE_DEBUG_INFO = YES;
+ ONLY_ACTIVE_ARCH = YES;
+ SDKROOT = iphoneos;
+ SWIFT_OPTIMIZATION_LEVEL = "-Onone";
+ };
+ name = Debug;
+ };
+ DAB7EB381BEF787300D2AD5E /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ALWAYS_SEARCH_USER_PATHS = NO;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x";
+ CLANG_CXX_LIBRARY = "libc++";
+ CLANG_ENABLE_MODULES = YES;
+ CLANG_ENABLE_OBJC_ARC = YES;
+ CLANG_WARN_BOOL_CONVERSION = YES;
+ CLANG_WARN_CONSTANT_CONVERSION = YES;
+ CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
+ CLANG_WARN_EMPTY_BODY = YES;
+ CLANG_WARN_ENUM_CONVERSION = YES;
+ CLANG_WARN_INT_CONVERSION = YES;
+ CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
+ CLANG_WARN_UNREACHABLE_CODE = YES;
+ CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
+ "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
+ COPY_PHASE_STRIP = NO;
+ DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
+ ENABLE_NS_ASSERTIONS = NO;
+ ENABLE_STRICT_OBJC_MSGSEND = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu99;
+ GCC_NO_COMMON_BLOCKS = YES;
+ GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
+ GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
+ GCC_WARN_UNDECLARED_SELECTOR = YES;
+ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
+ GCC_WARN_UNUSED_FUNCTION = YES;
+ GCC_WARN_UNUSED_VARIABLE = YES;
+ IPHONEOS_DEPLOYMENT_TARGET = 8.0;
+ MTL_ENABLE_DEBUG_INFO = NO;
+ SDKROOT = iphoneos;
+ VALIDATE_PRODUCT = YES;
+ };
+ name = Release;
+ };
+ DAB7EB3A1BEF787300D2AD5E /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ CODE_SIGN_IDENTITY = "iPhone Developer";
+ "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
+ INFOPLIST_FILE = Resources/Info.plist;
+ IPHONEOS_DEPLOYMENT_TARGET = 8.0;
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
+ PRODUCT_BUNDLE_IDENTIFIER = com.tablekit.demo;
+ PRODUCT_NAME = TableKitDemo;
+ PROVISIONING_PROFILE = "";
+ };
+ name = Debug;
+ };
+ DAB7EB3B1BEF787300D2AD5E /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
+ CODE_SIGN_IDENTITY = "iPhone Developer";
+ "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer";
+ INFOPLIST_FILE = Resources/Info.plist;
+ IPHONEOS_DEPLOYMENT_TARGET = 8.0;
+ LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
+ PRODUCT_BUNDLE_IDENTIFIER = com.tablekit.demo;
+ PRODUCT_NAME = TableKitDemo;
+ PROVISIONING_PROFILE = "";
+ };
+ name = Release;
+ };
+/* End XCBuildConfiguration section */
+
+/* Begin XCConfigurationList section */
+ DAB7EB221BEF787300D2AD5E /* Build configuration list for PBXProject "TableKitDemo" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ DAB7EB371BEF787300D2AD5E /* Debug */,
+ DAB7EB381BEF787300D2AD5E /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ DAB7EB391BEF787300D2AD5E /* Build configuration list for PBXNativeTarget "TableKitDemo" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ DAB7EB3A1BEF787300D2AD5E /* Debug */,
+ DAB7EB3B1BEF787300D2AD5E /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+/* End XCConfigurationList section */
+ };
+ rootObject = DAB7EB1F1BEF787300D2AD5E /* Project object */;
+}
diff --git a/TabletDemo/TabletDemo.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/TableKitDemo/TableKitDemo.xcodeproj/project.xcworkspace/contents.xcworkspacedata
similarity index 100%
rename from TabletDemo/TabletDemo.xcodeproj/project.xcworkspace/contents.xcworkspacedata
rename to TableKitDemo/TableKitDemo.xcodeproj/project.xcworkspace/contents.xcworkspacedata
diff --git a/Tablet.xcworkspace/xcuserdata/max.xcuserdatad/UserInterfaceState.xcuserstate b/Tablet.xcworkspace/xcuserdata/max.xcuserdatad/UserInterfaceState.xcuserstate
deleted file mode 100644
index b905fecdb7205bfdb2d2572bb0247f4217646129..0000000000000000000000000000000000000000
GIT binary patch
literal 0
HcmV?d00001
literal 21675
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