Classes
The following classes are available globally.
-
See moreRSDCrosshatchView
is a UI element for displaying a background that is two colors where the split is diagonal.Declaration
Swift
@IBDesignable open class RSDCrosshatchView: UIView
-
See moreRSDShadowGradient
is a UI element for adding a shadow gradient to a view.Declaration
Swift
@IBDesignable open class RSDShadowGradient : UIView
-
See moreRSDStepChoiceCell
is the base implementation for a selection table view cell of a form step.Declaration
Swift
public class RSDStepChoiceCell: UITableViewCell
-
See moreRSDStepTextFieldCell
is the base implementation of a text field used to enter answers in a form step table view.Declaration
Swift
open class RSDStepTextFieldCell: UITableViewCell
-
See moreRSDStepTextFieldFeaturedCell
is an implementation of the text field form step entry cell for use when there is a single input field on for the step.Declaration
Swift
open class RSDStepTextFieldFeaturedCell: RSDStepTextFieldCell
-
See moreRSDStepTextField
is a subclass ofUITextField
that keeps a reference to the index path associated with this text field.Declaration
Swift
public class RSDStepTextField: UITextField
-
See moreRSDTextLabelCell
can be used to display a text element such as a footnote in a table.Declaration
Swift
@IBDesignable open class RSDTextLabelCell : UITableViewCell
-
See moreRSDImageViewCell
can be used to display images amongst the table cells.Declaration
Swift
@IBDesignable open class RSDImageViewCell : UITableViewCell
-
See moreRSDLoadingView
is a simple loading view for displaying a loading indicator in a view.Declaration
Swift
open class RSDLoadingView: UIView
-
See moreRSDDatePicker
is a date picker that stores a pointer to the index path with which it is associated.Declaration
Swift
public class RSDDatePicker : UIDatePicker, RSDPickerViewProtocol
-
See moreRSDChoicePickerView
is aUIPickerView
that can be used to represent a picker with an associated index path. This picker has aRSDChoicePickerDataSource
as it’s source. This implementation only supports text choices.Declaration
Swift
open class RSDChoicePickerView : UIPickerView, RSDPickerViewProtocol, UIPickerViewDataSource, UIPickerViewDelegate
-
See moreRSDNumberPickerView
is aUIPickerView
that can be used to represent a picker with an associated index path. This picker has aRSDNumberPickerDataSource
as it’s source.Declaration
Swift
open class RSDNumberPickerView : UIPickerView, RSDPickerViewProtocol, UIPickerViewDataSource, UIPickerViewDelegate
-
RSDTableStepViewController
is a custom instance ofRSDStepViewController
. Its subviews include aUITableView
, aRSDNavigationFooterView
, which may or may not be embedded in the tableView as its footerView, and aRSDNavigationHeaderView
, which is embedded in the tableView as its headerView.This class populates the contents and properties of the headerView and navigationView based on the associated
RSDStep
, which is expected to be set before presenting the view controller.An instance of
RSDFormStepDataSource
is created bysetupModel()
and assigned to propertytableData
. This method is called byviewWillAppear()
and serves as theUITableViewDataSource
. ThetableData
also keeps track of answers that are derived from the user’s input and it provides theRSDResult
that is appended to theRSDTaskPath
associated with this task.This class is responsible for acquiring input from the user, validating it, and supplying it as an answer to to the model (tableData). This is typically done in delegate callbacks from various input views, such as UITableView (didSelectRow) or UITextField (valueDidChange or shouldChangeCharactersInRange).
Some RSDSteps, such as
See moreRSDFactory.StepType.instruction
, require no user input (and have no input fields). These steps will result in atableData
that has no sections and, therefore, no rows. So the tableView will simply have a headerView, no rows, and a footerView.Declaration
Swift
open class RSDTableStepViewController: RSDStepViewController, UITableViewDataSource, UITableViewDelegate, UITextFieldDelegate, RSDFormStepDataSourceDelegate, RSDPickerObserver
-
See moreRSDTableStepUIConfig
is a configuration class. All the methods are defined as@objc open class func
methods which can be overriden by an application to return different shared implementations. This allows the generic step to override the UI consistently for all step views that use eitherRSDTableStepViewController
or a subclass implementation.Declaration
Swift
public class RSDTableStepUIConfig: NSObject
-
See moreRSDStepNavigationView
is a customUIView
to be included in aRSDStepViewController
. It optionally contains references to standard step navigation UI including a next button, back button, skip button, learn more button, and cancel button.Declaration
Swift
open class RSDStepNavigationView: UIView
-
See moreRSDNavigationHeaderView
is a general purpose navigation header view that can be used by the step view controller to include UI elements that may typically be shown at the top of the step view.Declaration
Swift
open class RSDNavigationHeaderView: RSDStepNavigationView
-
See moreRSDStepHeaderView
is a customUIView
designed for use as a header view in a table view, such as anRSDTableStepViewController
.Declaration
Swift
open class RSDStepHeaderView: RSDNavigationHeaderView
-
RSDTableStepHeaderView
is a concrete implementation ofRSDStepHeaderView
that will automatically lay out the UI elements in this order, from top to bottom of the view:- cancelButton: UIButton - allows for cancelling the task
- progressView: RSDStepProgressView - show progress thru the current flow
- imageView: UIImageView - shows an image associated with the current step
- titleLabel: UILabel - generally the Title of the current step
- textLabel: UILabel - generally the Text of the current step
- learnMoreButton: UIButton - a button to call the learnMoreAction
- detailLabel: UILabel - a label intended to prompt the user to enter data or make a selection
Several public properties are provided to configure the view, such has hiding or showing the learnMoreButton or progressView, and providing a minimumHeight or customView.
See moreDeclaration
Swift
open class RSDTableStepHeaderView: RSDStepHeaderView
-
See moreRSDNavigationFooterView
is an abstract implementation for theRSDStepNavigationView
which can be added to a Nib, Storyboard or instantiated using theRSDTableStepUIConfig.instantiatNavigationView()
method.Declaration
Swift
open class RSDNavigationFooterView: RSDStepNavigationView
-
RSDGenericNavigationFooterView
is a concrete implementation ofRSDNavigationFooterView
that will automatically lay out the UI elements included in the navigation footer:- nextButton: UIButton - for navigating to the next step
- backButton: UIButton - for navigating to the previous step
- skipButton: UIButton - for skipping the step or task
- shadowView: RSDShadowGradient - shows a shadow to indicate that there is content below the fold
Declaration
Swift
open class RSDGenericNavigationFooterView: RSDNavigationFooterView
-
RSDTaskInfoStepViewController
is designed to be used to display aRSDTaskInfoStep
either to give the user feedback when a task or survey is being fetched or else to provide a consistent UI for the introduction of all tasks.This view controller includes a default nib implementation that is included in this framework. It includes various UI elements that can indicate to the user how much time is remaining in a longer-running step. For example, this could be used during a walk step to indicate to the user how long they have been walking as well as how much longer they have to walk before the step is complete.
See moreDeclaration
Swift
open class RSDTaskInfoStepViewController: RSDStepViewController, UITextViewDelegate
-
RSDStepProgressView
is a UI element that displays a progress bar drawn horizontally from left to right.This view includes an optional pointer to
stepCountLabel
which is not a subview of this view but can be used to display current step and number of steps.The view controller must set
See morecurrentStep
andtotalSteps
to cause progress to be displayed.Declaration
Swift
open class RSDStepProgressView: UIView
-
RSDCountdownStepViewController
is a simple countdown timer for displaying a short duration (5-4-3-2-1) countdown.This view controller includes a default nib implementation that is included in this framework. It includes a
See morecountdownLabel
that can be used to show a numeric countdown (5-4-3-2-1) and apauseButton
that can be used to pause the countdown timer.Declaration
Swift
open class RSDCountdownStepViewController: RSDStepViewController
-
RSDNavigationController
extendsUINavigationController
with a pass-through implementation ofRSDStepController
. This allows step controllers to be wrapped in a navigation controller for UI implementations that use the features of a navigation controller, while passing control of the step to the step controller.Note
For applications that customize the navigation controller with their own subclass implementation, this implementation can be copy/pasted and used to extend that custom implementation. This framework does not force using this implementation by extendingUINavigationController
directly.Declaration
Swift
open class RSDNavigationController : UINavigationController, RSDStepController
-
See moreRSDButton
is a base-class implementation ofRSDButtonProtocol
that handles overriding default accessibility behavior for a button in transition.Declaration
Swift
@IBDesignable open class RSDButton : UIButton
-
See moreRSDStepViewController
is the default base class implementation for the steps presented using this UI architecture.Declaration
Swift
open class RSDStepViewController : UIViewController, RSDStepViewControllerProtocol
-
RSDActiveStepViewController
is a simple timer for displaying a longer activity where the user is doing an action while the countdown timer is running.This view controller includes a default nib implementation that is included in this framework. It includes various UI elements that can indicate to the user how much time is remaining in a longer-running step. For example, this could be used during a walk step to indicate to the user how long they have been walking as well as how much longer they have to walk before the step is complete.
See moreDeclaration
Swift
open class RSDActiveStepViewController: RSDStepViewController
-
See moreRSDTaskViewController
is the default implementation of task view controller that is suitable to the iPhone or iPad. The default implementation will display a series of steps using aUIPageViewController
. This controller will also handle starting and stoping async actions and vending the appropriate step view controller for each step.Declaration
Swift
open class RSDTaskViewController: UIViewController, RSDTaskController, UIPageViewControllerDelegate, UIPageViewControllerDataSource, RSDAsyncActionControllerDelegate, RSDLoadingViewControllerProtocol
-
See moreRSDAudioSoundPlayer
is a concrete implementation of theRSDSoundPlayer
protocol that can be used to play system sounds usingAudioServicesCreateSystemSoundID()
.Declaration
Swift
open class RSDAudioSoundPlayer : NSObject, RSDSoundPlayer
-
See moreRSDWebViewController
is a simple view controller for showing a webview. The base-class implementation supports loading a web view from a URL, HTML string, orRSDResourceTransformer
. It is assumed that the property will be set for one of these values.Declaration
Swift
open class RSDWebViewController: UIViewController, UIWebViewDelegate
-
See moreRSDSpeechSynthesizer
is a concrete implementation of theRSDVoiceBox
protocol that uses theAVSpeechSynthesizer
to synthesize text to sound.Declaration
Swift
open class RSDSpeechSynthesizer : NSObject, RSDVoiceBox, AVSpeechSynthesizerDelegate
-
See moreRSDProgressIndicator
is an animatable abstract view that marks progress. Override theprogressLayer
property to show progress using a shape layer. SeeRSDCountdownDial
for an example implementation.Declaration
Swift
open class RSDProgressIndicator: UIView
-
Declaration
Swift
public final class RSDCountdownDial: RSDProgressIndicator