![38% of CISOs Fear They’re Not Moving Fast Enough on AI](https://cdn.sanity.io/images/cgdhsj6q/production/faa0bc28df98f791e11263f8239b34207f84b86f-1024x1024.webp?w=400&fit=max&auto=format)
Security News
38% of CISOs Fear They’re Not Moving Fast Enough on AI
CISOs are racing to adopt AI for cybersecurity, but hurdles in budgets and governance may leave some falling behind in the fight against cyber threats.
react-native-search-api
Advanced tools
A React Native module that allows to perform the Spotlight integration on iOS
The SearchApi
module gives you a general React Native interface to interact with the iOS Search API, Core Spotlight.
For more information about iOS Search APIs, see https://developer.apple.com/ios/search/.
npm install react-native-search-api --save
react-native link
To the top of your AppDelegate.m
add the following line:
#import "RCTSearchApiManager.h"
In your AppDelegate implementation add the following:
- (BOOL)application:(UIApplication *)application continueUserActivity:(NSUserActivity *)userActivity restorationHandler:(void (^)(NSArray * _Nullable))restorationHandler {
return [RCTSearchApiManager application:application continueUserActivity:userActivity restorationHandler:restorationHandler];
}
Subscribe to the search item open events in your components like this:
componentDidMount() {
<...>
SearchApi.addOnSpotlightItemOpenEventListener(this.handleOnSpotlightItemOpenEventListener);
SearchApi.addOnAppHistoryItemOpenEventListener(this.handleOnAppHistoryItemOpenEventListener);
}
To prevent memory leaks don't forget to unsubscribe:
componentWillUnmount() {
<...>
SearchApi.removeOnSpotlightItemOpenEventListener(this.handleOnSpotlightItemOpenEventListener);
SearchApi.removeOnAppHistoryItemOpenEventListener(this.handleOnAppHistoryItemOpenEventListener)
}
Generally you should be interested whether the app was started using the search, therefore consider using the following two methods:
// For the spotlight item:
SearchApi.getInitialSpotlightItem().then(result => {
if (result) {
console.log('Started with a spotlight item!')
}
})
// For the app history item:
SearchApi.getInitialAppHistoryItem().then(result => {
if (result) {
console.log('Started with an app history item!')
}
})
In order to create a new spotlight item, use indexSpotlightItem
or indexSpotlightItems
:
SearchApi.indexSpotlightItem(item).then(result => {
console.log('Success');
}).catch(err => {
console.log('Error: ' + err);
});
To add new items to the app history, use createUserActivity
:
SearchApi.indexAppHistoryItem(item).then(result => {
console.log('Success');
that.setState({labelText: 'Success'});
}).catch(err => {
console.log('Error: ' + err);
that.setState({labelText: ('Error: ' + err)});
});
The parameters, that items may specify are listed below:
Dictionaries, passed to create spotlight and app history items have some common and some specific keys, here is the list of all possible keys.
title
: stringTitle of the item. Required for both item types.
contentDescription
: stringDescription of the item. Optional.
keywords
: ArrayAn array of keywords, assigned to the search item. Optional.
thumbnail
: string|int|objectThumbnail to be presented in the search results. The same format as source
in
the Image
component. Optional.
Examples:
var localItem = {
<...>,
thumbnail: require('/react-native/img/favicon.png')
};
var remoteItem = {
<...>,
thumbnail: {uri: 'https://facebook.github.io/react-native/docs/assets/favicon.png'}
};
Please refer to documentation for more details.
uniqueIdentifier
: stringThe unique identifier of the spotlight item, passed later on during the item opening event. Required.
domain
: stringThe domain for the spotlight item. Optional.
userInfo
: ObjectA dictionary, passed later on during the item opening event. Required.
eligibleForPublicIndexing
: booleanA flag, that when set to true
allows to add the item to the public index.
Optional.
expirationDate
: DateExpiration date of the user activity item. Optional.
webpageURL
: stringURL of the page, representing the same content on the app's website.
FAQs
A React Native module that allows to perform the Spotlight integration on iOS
The npm package react-native-search-api receives a total of 0 weekly downloads. As such, react-native-search-api popularity was classified as not popular.
We found that react-native-search-api demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 13 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
CISOs are racing to adopt AI for cybersecurity, but hurdles in budgets and governance may leave some falling behind in the fight against cyber threats.
Research
Security News
Socket researchers uncovered a backdoored typosquat of BoltDB in the Go ecosystem, exploiting Go Module Proxy caching to persist undetected for years.
Security News
Company News
Socket is joining TC54 to help develop standards for software supply chain security, contributing to the evolution of SBOMs, CycloneDX, and Package URL specifications.