Wesley de Groot's Blog
CoreSpotlight

Back

CoreSpotlight

CoreSpotlight is a framework provided by Apple that allows you to index and search content within your app. It provides a way to make your app's content searchable and discoverable by users through the Spotlight search feature on iOS and macOS.

Why should i implement CoreSpotlight?

Implementing CoreSpotlight in your app can greatly enhance the discoverability and searchability of your app's content. By indexing your app's content using CoreSpotlight, users will be able to find relevant information from your app directly through the Spotlight search feature on iOS and macOS.

This can lead to a better user experience, as users can quickly access specific content within your app without having to open the app itself. It also allows your app to be more integrated with the overall system search functionality, making it easier for users to find and interact with your app's content.

Additionally, CoreSpotlight provides a powerful set of APIs and features that allow you to customize the search experience and provide rich metadata for your app's content. You can define searchable attributes, create custom search UI, and even deep link users to specific content within your app.

Overall, implementing CoreSpotlight can help increase the visibility and accessibility of your app's content, improving user engagement and satisfaction.

How to implement CoreSpotlight?

To implement CoreSpotlight in your app, you need to follow these steps:

  1. Import CoreSpotlight: First, import the CoreSpotlight framework in your project.

  2. Indexing Content: Identify the content within your app that you want to make searchable and index it using the CoreSpotlight APIs. You can create CSSearchableItem objects to represent the content and define searchable attributes such as title, description, keywords, and more.

  3. Updating the Index: Whenever the content in your app changes, update the CoreSpotlight index to reflect the changes. You can add, update, or delete searchable items using the CSSearchableIndex API.

  4. Handling Search Queries: Implement the search functionality in your app to handle search queries from the user. You can use the CSSearchQuery API to perform searches and retrieve search results based on the user's input.

  5. Customizing Search Results: Customize the search results to provide a rich and interactive search experience for users. You can display custom UI elements, provide additional metadata, and deep link users to specific content within your app.

By following these steps, you can effectively implement CoreSpotlight in your app and make your content searchable and discoverable through the Spotlight search feature.

Example of Use Case

Here's an example of how you can implement CoreSpotlight in a simple pokedex app:

import CoreSpotlight

// Define a Pokemon struct
struct Pokemon {
    let id: String
    let name: String
    let description: String
}

// Index a pokemon
func indexPokemon(pokemon: Pokemon) {
    let attributeSet = CSSearchableItemAttributeSet(
        contentType: .content
    )
    attributeSet.title = pokemon.name
    attributeSet.contentDescription = pokemon.description
    attributeSet.keywords = ["Pokedex", pokemon.id, pokemon.name, pokemon.description]

    // Optionally set thumbnail image using the options below
    // attributeSet.thumbnailData
    // attributeSet.thumbnailURL
    // attributeSet.darkThumbnailURL

    let searchableItem = CSSearchableItem(
        uniqueIdentifier: pokemon.id,
        domainIdentifier: "nl.wesleydegroot.pokedex",
        attributeSet: attributeSet
    )

    CSSearchableIndex.default().indexSearchableItems([searchableItem]) { error in
        if let error = error {
            print("Error indexing pokemon: \(error)")
        } else {
            print("Pokemon \(pokemon.name) indexed successfully")
        }
    }
}

// Update the pokemon
func updatePokemon(pokemon: Pokemon) {
    // Update the pokemon in the app
    // ...

    // Re-index the pokemon
    indexPokemon(pokemon: pokemon)
}

// Delete a Pokemon
func deletePokemon(pokemon: String) {
    CSSearchableIndex.default().deleteSearchableItems(withIdentifiers: [pokemon]) { error in
        if let error = error {
            print("Error deleting Pokemon: \(error)")
        } else {
            print("Pokemon deleted successfully")
        }
    }
}

let pokemon: [Pokemon] = [
    Pokemon(
        id: "149",
        name: "Dragonite",
        description: "It is said that somewhere in the ocean lies an island where these gather. Only they live there."
    ),
    Pokemon(
        id: "25",
        name: "Pikachu",
        description: "When it is angered, it immediately discharges the energy stored in the pouches in its cheeks."
    ),
    Pokemon(
        id: "249",
        name: "Lugia",
        description: "Lugia’s wings pack devastating power—a light fluttering of its wings can blow apart regular houses. As a result, this Pokémon chooses to live out of sight deep under the sea."
    )
]


// Index the pokemon
pokemon.forEach { indexPokemon(pokemon: $0) }

In this example, we define a Pokemon struct representing a pokemon in the app. We then implement functions to index, update, and delete pokemon using CoreSpotlight. When a pokemon is indexed, it becomes searchable through the Spotlight search feature, allowing users to find it based on the title and content.

Caveats

When implementing CoreSpotlight in your app, there are a few things to keep in mind:

  • Privacy Considerations: Ensure that you handle user data and content responsibly when indexing it with CoreSpotlight. Be mindful of user privacy and only index content that users have consented to make searchable.

  • Indexing Performance: Indexing large amounts of content or frequently updating the index can impact the performance of your app. Consider batching updates and indexing only relevant content to optimize performance.

  • Search Relevance: To provide a good search experience for users, make sure that the searchable attributes of your content are relevant and accurately reflect the content. Use keywords, descriptions, and other metadata to improve search results.

  • User Experience: Design the search UI and search results to provide a seamless and intuitive experience for users. Consider customizing the search results to display additional information and make it easy for users to interact with the content.

Wrap up

CoreSpotlight is a powerful framework that allows you to make your app's content searchable and discoverable through the Spotlight search feature on iOS and macOS. By indexing your app's content and handling search queries effectively, you can enhance the user experience and increase the visibility of your app's content.

Resources:

x-twitter mastodon github linkedin discord threads instagram whatsapp bluesky square-rss sitemap