Basic integration with SwiftUI
iOS Classic - Basic integration with SwiftUI
This page describes how to integrate Taboola iOS Classic when using SwiftUI.
While reading the documentation, take a look at our Sample App.
Initialize Taboola
In your SwiftUI app's main struct, create a TBLPublisherInfo object and initialize Taboola:
import SwiftUI
import TaboolaSDK
@main
struct YourApp: App {
    init() {
        // Initialize a TBLPublisherInfo instance with your unique 'publisherName' and 'appStoreId':
        let publisherInfo = TBLPublisherInfo(publisherName: "<publisherName>", appStoreId: <appStoreId>)
        
        // Initialize Taboola for your application:
        Taboola.initWith(publisherInfo)
        
        // (Optional) Set *global* feature flags:
        Taboola.setGlobalExtraProperties(["<feature flag key>":"<value>"])
        
        // (Optional) Set the desired log level:
        Taboola.setLogLevel(.LogLevelDebug)
    }
    
    var body: some Scene {
        WindowGroup {
            ContentView()
        }
    }
}
Params
publisherName- An alphanumeric string, provided by Taboola - e.g."sdk-tester-demo".This field is also referred to as the Publisher ID.
appStoreId- Your App Store ID, obtained via the App Store Connect dashboard.See below.
appStoreIdYour App Store ID - aka Apple ID or iTunes ID - is a unique, numeric identifier that allows Apple to distinguish your app from others.
Passing the
appStoreIdparam allows for improved tracking and attribution and is strongly recommended.
Obtaining your App Store ID
- Log in to the App Store Connect dashboard.
- Under
My Apps, select the relevant app.- Under
General, selectApp Information(left).- Copy your Apple ID (right).
Initialize Taboola in your app's
init()method - or as early as possible within the app lifecycle.
Build Taboola content instances
- Import the required modules:
import SwiftUI
import TaboolaSDK
import TaboolaSDK_SwiftUI_Umbrella- Create a page wrapper to manage Taboola content:
class ClassicPageWrapper: NSObject, TBLClassicPageDelegate, Π‘lassicPageWrappable {    
    var page: TBLClassicPage!
    @Weak var delegates: [Coordinator]
    
    let reusableViewsQueue = ReusableViewsQueue<String, TBLClassicUnit>()
    
    init(pageType: String, pageUrl: String) {
        super.init()
        page = TBLClassicPage(pageType: pageType, pageUrl: pageUrl, delegate: self, scrollView: nil)
        page.pageExtraProperties = ["disableScrollIntercept": NSNumber(value: true)]
    }
    
    // MARK: - TBLClassicPageDelegate
    
    func classicUnit(_ classicUnit: UIView!,
                     didLoadOrResizePlacementName placementName: String!,
                     height: CGFloat,
                     placementType: PlacementType) {
        let delegates = delegates.filter { placementName.contains($0.unit.placement) }
        delegates.forEach { $0.didLoadWithHeight(height: height) }
    }
    
    func classicUnit(_ classicUnit: UIView!,
                     didClickPlacementName placementName: String!,
                     itemId: String!,
                     clickUrl: String!,
                     isOrganic organic: Bool) -> Bool {
        return organic
    }
}- Use the ClassicUnitSwiftUIwrapper in your SwiftUI view:
struct TaboolaView: View {
    let pageWrapper = ClassicPageWrapper(pageType: "article", pageUrl: "https://www.example.com")
    @State var widgetHeight: CGFloat = 0
    
    var body: some View {
        VStack {
            Text("Your content above")
            
            ClassicUnitSwiftUI(pageWrapper: pageWrapper,
                               placement: "Below Article",
                               mode: "alternating-widget-without-video-1x1",
                               height: $widgetHeight)
            .frame(height: widgetHeight)
            
            Text("Your content below")
        }
    }
}
Params
pageWrapper- TheClassicPageWrapperinstance that manages the Taboola page.
placement- The placement name, as provided by Taboola - e.g."Feed without video".
mode- The UI Mode ID of the placement, as provided by Taboola - e.g."thumbs-feed-01".
height- A binding to track the dynamic height of the Taboola content.
A complete example
import SwiftUI
import TaboolaSDK
import TaboolaSDK_SwiftUI_Umbrella
struct TaboolaView: View {
    let pageWrapper = ClassicPageWrapper(pageType: "article", 
                                       pageUrl: "https://www.example.com/articles?id=123")
    @State var widgetHeight: CGFloat = 0
    @State var feedHeight: CGFloat = 0
    
    var body: some View {
        ScrollView {
            VStack {
                Text("Your content above")
                
                ClassicUnitSwiftUI(pageWrapper: pageWrapper,
                                   placement: "Below Article",
                                   mode: "alternating-widget-without-video-1x1",
                                   height: $widgetHeight)
                .frame(height: widgetHeight)
                
                Text("Your content in between")
                
                ClassicUnitSwiftUI(pageWrapper: pageWrapper,
                                   placement: "Feed without video",
                                   mode: "thumbs-feed-01",
                                   height: $feedHeight)
                .frame(height: feedHeight)
            }
        }
    }
}struct ContentView: View {
    var body: some View {
        NavigationView {
            TaboolaView()
                .navigationTitle("My App")
        }
    }
}Additional examples
See our Sample App for complete implementations using the Taboola SwiftUI Umbrella package:
- ClassicVStack.swift - Basic VStack integration
- ClassicList.swift - List view integration
- ClassicTabView.swift - Tab view integration
- ClassicScrollView.swift - ScrollView integration
- ClassicLazyVStack.swift - LazyVStack integration
- ClassicLazyVGrid.swift - LazyVGrid integration
Guidelines
- To maintain a smooth user experience, fetch Taboola content as soon as the view appears.* Do not cache Taboola content. Fetch new content each time the app opens, or the relevant screen is created.* Use the same
ClassicPageWrapperinstance for multiple placements on the same page to optimize performance.
The click event
You can handle Taboola events by implementing the TBLClassicPageDelegate protocol in your ClassicPageWrapper:
class ClassicPageWrapper: NSObject, TBLClassicPageDelegate, Π‘lassicPageWrappable {
    // ... existing code ...
    
    func classicUnit(_ classicUnit: UIView!, 
                    didClickPlacementName placementName: String!, 
                    itemId: String!, 
                    clickUrl: String!, 
                    isOrganic organic: Bool) -> Bool {
        // Insert your code here...
        // Return 'false' if you are handling the click event yourself, or 'true' if you want Taboola SDK to handle the click event.
        // Note: you can override the default behavior for *organic* content only.
        return true
    }
}You can override the default behavior for organic content only.
For more information, see Event Handling and didClickPlacementName.
Well Done!
You have completed the basic integration steps using the Taboola SwiftUI Umbrella package!
If everything is working smoothly, take a look at the What's Next section below.
Taboola content not rendering?
- Test with the same params as the sample app, and see if those work.
- Still stuck? Submit a question In our forum.
What's next?
- For handling clicks and other important events, see Event Handling.
- To use advanced options while working with the Taboola SDK, see Advanced Options.
- In order to provide personalized recommendations for impressions in the EU and California, make sure to implement GDPR & CCPA respectively.
- If you have not already done so, make sure to look at our sample app.
- Once you are complete, submit your text app to Taboola for verification - see: App Verification.
IMPORTANTPrior to launch, you must provide Taboola with a test app for verification. Skipping this step may result in a significant loss of revenue.
See: App Verification
Updated 6 days ago
