Skip to main content

Drafts guide

Configuration

Drafts are enabled by default, asks the user to save a draft before leave any VideoEditor screen. If you need to change drafts configuration you should add the code below in the VideoEditorModule:

var config = VideoEditorConfig()

config.featureConfiguration.draftsConfig = .enabled

You can choose one of these options:

  • .enabled - drafts enabled, asks the user to save a draft
  • .enabledSaveToDraftsByDefault - drafts enabled, saved by default without asking the user
  • .enabledAskIfSaveNotExport - drafts enabled, asks the user to save a draft without export
  • .disabled - disabled drafts

The default value is .enabled

Draft Service

The DraftsService class is used for managing drafts:

/// External Draft of video session
typealias ExternalDraft = VideoSequence

/// Allows you to manage drafts
class DraftsService {

/// Get drafted video sequences
func getDrafts() -> [ExternalDraft]

/// Remove specific video sequence
/// - parameters:
/// - externalDraft: Drafted video sequence
func removeExternalDraft(_ externalDraft: ExternalDraft) -> Bool

/// Get preview for specific drafted video sequence
/// - parameters:
/// - externalDraft: Drafted video sequence
/// - thumbnailHeight: Preview height
/// - completion: Completion when preview UIImage generated
func getPreviewForVideoSequence(
_ externalDraft: ExternalDraft,
thumbnailHeight: CGFloat,
completion: ((_ preview: UIImage?) -> Void)?
)
}

To get the instance of DraftsService use the BanubaVideoEditor instance.

Example of usage:

let videoEditorSDK = BanubaVideoEditor(...) // Initialization of main entity
let drafts = videoEditorSDK?.draftsService.getDrafts() // Get drafts list

let draft = drafts.first!

// Get draft preview
videoEditorSDK?.draftsService.getPreviewForVideoSequence(
// Choosen draft from list of drafts
draft,
// Default config, where config is VideoEditorConfig instance
thumbnailHeight: config.videoResolutionConfiguration.currentThumbnailHeight,
completion: { preview in
// Preview usage
}
)

// Remove draft and use returned value to your own condition usage if needed
let _ = videoEditorSDK?.draftsService.removeVideoSequence(videoSequence)

// Open Video Editor with preselected draft
let draftedConfig = VideoEditorLaunchConfig.DraftedLaunchConfig(
// Choosen draft from list of drafts
externalDraft: draft,
// Any case from DraftsFeatureConfig entity
draftsConfig: .enabled
)

let config = VideoEditorLaunchConfig(
entryPoint: .editor,
hostController: self,
draftedLaunchConfig: draftedConfig,
animated: true
)

// Present Video Editor
self.videoEditorSDK?.presentVideoEditor(
withLaunchConfiguration: config,
completion: nil
)

Transferring drafts

BanubaVideoEditor supports archiving drafts into a zip file. It may help you with backing up user data to the server or sharing video content across the devices.

For exporting and importing BanubaVideoEditor has the following methods:

  /// Archive and compress external draft into zip file.
/// Returns URL to archive
/// Discussion: After performing all actions with zip file your are responsible to remove archive file.
func exportExternalDraft(_ externalDraft: ExternalDraft) throws -> URL

/// Unarchive ExternalDraft from zip file
func importExternalDraft(fromZipUrl url: URL) throws -> ExternalDraft

Example of usage:

let videoEditorSDK = BanubaVideoEditor(...) // Initialization of main entity
let drafts = videoEditorSDK?.draftsService.getDrafts() // Get drafts list

let draft = drafts.first!

// Make archive from draft
let archiveURL = try? videoEditorSDK?.exportExternalDraft(draft)

// Import draft from archive
let importedDraft = try! videoEditorSDK?.importExternalDraft(fromZipUrl: archiveURL)

// Open Video Editor with unarchived draft
let draftedConfig = VideoEditorLaunchConfig.DraftedLaunchConfig(
externalDraft: importedDraft,
draftsConfig: .enabled
)

let config = VideoEditorLaunchConfig(
entryPoint: .editor,
hostController: self,
draftedLaunchConfig: draftedConfig,
animated: true
)

self.videoEditorSDK?.presentVideoEditor(
withLaunchConfiguration: config,
completion: nil
)