Introducing ClassKit
Introducing ClassKit
WWDC 2018
Apple School Manager
- Create managed Apple IDs
- Create rosters
- Manage content and devices
- Opt in for progress reporting
- Purchase apps in bulk
data:image/s3,"s3://crabby-images/2fcac/2fcace1039dc33700728cc9e1397c9e909f0f457" alt=""
Schoolwork
- A new education app for students and teachers
- View assigned handouts
- Create new handouts
- View progress reports
data:image/s3,"s3://crabby-images/4f62a/4f62a3c72f64d0a02f2db7c74314298918acc8b5" alt=""
data:image/s3,"s3://crabby-images/243e2/243e2c75c6ad88b6b4eca296ebb829d0fad79f35" alt=""
data:image/s3,"s3://crabby-images/7b7b5/7b7b5afca59a491b1095d2e404096786d9d23bde" alt=""
LifeCycle of a Handout
- Content is represented via CLSContext
- One main app context (root context)
- App content is added to the app context
- Define content as early as possible
data:image/s3,"s3://crabby-images/7ea08/7ea08b42089a82c554f0de992688256919dd7ff9" alt=""
data:image/s3,"s3://crabby-images/6f964/6f96409523c2377c2829a89db41d58070dabc7bc" alt=""
Developer Mode
- Settings > Developer > ClassKit API
data:image/s3,"s3://crabby-images/3a228/3a228571b506517ada98ad76a9c6f774ec1ca717" alt=""
Framework Classes
CLSDataStore
- Maintains the context tree
- Exposes the mainAppContext as a property
- Keeps track of modified objects
- Objects saved by calling CLSDataStore.save(completion: ) - One shared instance
CLSContext
data:image/s3,"s3://crabby-images/c1b0a/c1b0a39b599f3d87b79192a611b76f845995b608" alt=""
Context Identity
- identifier property
- Context identifier Path
- Identifies a context within a context tree
- Array of context identifiers
Context Identifier Path
data:image/s3,"s3://crabby-images/1f708/1f708a346c1faa24f11fab6f7e52b1f1d48447da" alt=""
Context Lookup
data:image/s3,"s3://crabby-images/7f4de/7f4de6de20c673921ff1601ea1e2470edd0e1ab3" alt=""
data:image/s3,"s3://crabby-images/47145/4714519d015707108bc1615789a3ab45daf3fde4" alt=""
data:image/s3,"s3://crabby-images/929a7/929a7117f4bf8ab3479022913b323bc7976b2d6e" alt=""
CLSDataStore Delegate
- Works in conjunction with path query methods
- Used to create missing contexts on demand
- Useful for apps with dynamic content
data:image/s3,"s3://crabby-images/7a0f4/7a0f4cb14f313605a2a23301aa2f8b94e2427695" alt=""
data:image/s3,"s3://crabby-images/8422b/8422b27405b867c9e7194a76c19ce02e06852b11" alt=""
CLSActivity
- Always associated with contexts
- Created by calling CLSContext.createNewActivity() → CLSActivity
- Access current using CLSContext.currentActivity: CLSActivity?
- Creating a new activity is akin to a new attempt
data:image/s3,"s3://crabby-images/76623/766237f5e6b31154b3f9d366978d28a3e3133f39" alt=""
data:image/s3,"s3://crabby-images/cff74/cff7476450dcdf908c31be76fcfe38ad65b56176" alt=""
CLSActivityItem
- Abstract class with three subclasses
- Always set the same subclass for primary activity items
- Provide clear and concise titles
- Make use of additional activity items
data:image/s3,"s3://crabby-images/0c038/0c0381d57a071978d61a7b316421b40b288e5d83" alt=""
data:image/s3,"s3://crabby-images/22a8f/22a8f0efdb18acdb3d5a9d9fddbf1d32d323e912" alt=""
data:image/s3,"s3://crabby-images/ee7aa/ee7aacd452abc469919e9b384dda62e17018d63b" alt=""
Steps for Adopting ClassKit
- Define CLSContext structure
- Add CLSActivity and CLSActivityItems
- Support deep linking
- Test with Developer Mode and Schoolwork
Defining CLSContext Tree
data:image/s3,"s3://crabby-images/be02f/be02fd2c8e7d02d02b75831a091069b460077123" alt=""
CLSContext
- Use clear titles !!!
- Define contexts early
- Take advantage of displayOrder
data:image/s3,"s3://crabby-images/c249d/c249d2eee4e95bec28622c3ae961b166c413f8cb" alt=""
CLSActivity
data:image/s3,"s3://crabby-images/2cb82/2cb82da4550deea97800c8cdbbf7aa4f17eab18a" alt=""
data:image/s3,"s3://crabby-images/ac08c/ac08c38cae6022c4431aad5531c3c2b2ae1808fe" alt=""
data:image/s3,"s3://crabby-images/bcc97/bcc97d3283a2f88393d9b104e1d7826c1e582a1e" alt=""
Demo
[ Sample App Link ]