# rntpc_react-native-default-preference **Repository Path**: openharmony-sig/rntpc_react-native-default-preference ## Basic Information - **Project Name**: rntpc_react-native-default-preference - **Description**: No description available - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: master - **Homepage**: https://gitee.com/openharmony-sig/rntpc_react-native-default-preference - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2024-10-14 - **Last Updated**: 2025-05-07 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # 🚨 **重要提示 | IMPORTANT** > > **⚠️ 此代码仓已归档。新地址请访问 [rntpc_react-native-default-preference](https://gitcode.com/openharmony-sig/rntpc_react-native-default-preference)。| ⚠️ This repository has been archived. For the new address, please visit [rntpc_react-native-default-preference](https://gitcode.com/openharmony-sig/rntpc_react-native-default-preference).** > --- > [![npm version](https://badge.fury.io/js/react-native-default-preference.svg)](https://badge.fury.io/js/react-native-default-preference) # react-native-default-preference Use `SharedPreferences` (Android) and `UserDefaults` (iOS) with React Native over a unified interface. All data is stored as a string. If you need to support more complex data structures, use serialization/deserialization (e.g. JSON). ## Getting started `$ npm install react-native-default-preference --save` ### React Native >= 0.60 `$ cd ios && pod install` ### React Native <= 0.59 `$ react-native link react-native-default-preference` ### Manual installation #### iOS 1. In XCode, in the project navigator, right click `Libraries` ➜ `Add Files to [your project's name]` 2. Go to `node_modules` ➜ `react-native-default-preference` and add `RNDefaultPreference.xcodeproj` 3. In XCode, in the project navigator, select your project. Add `libRNDefaultPreference.a` to your project's `Build Phases` ➜ `Link Binary With Libraries` 4. Run your project (`Cmd+R`)< #### Android 1. Open up `android/app/src/main/java/[...]/MainApplication.java` - Add `import com.kevinresol.react_native_default_preference.RNDefaultPreferencePackage;` to the imports at the top of the file - Add `new RNDefaultPreferencePackage()` to the list returned by the `getPackages()` method 2. Append the following lines to `android/settings.gradle`: ``` include ':react-native-default-preference' project(':react-native-default-preference').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-default-preference/android') ``` 3. Insert the following lines inside the dependencies block in `android/app/build.gradle`: ``` compile project(':react-native-default-preference') ``` ## Usage ```javascript import DefaultPreference from 'react-native-default-preference'; DefaultPreference.get('my key').then(function(value) {console.log(value)}); DefaultPreference.set('my key', 'my value').then(function() {console.log('done')}); ``` ## API ```typescript function get(key: string): Promise; function set(key: string, value: string): Promise; function clear(key: string): Promise; function getMultiple(keys: string[]): Promise; function setMultiple(data: {[key: string]: string}): Promise; function clearMultiple(keys: string[]): Promise; function getAll(): Promise<{[key: string]: string}>; function clearAll(): Promise; /** Gets and sets the current preferences file name (android) or user default suite name (ios) **/ function getName(): Promise; function setName(name: string): Promise; ``` ## Cordova Native Storage Compatibility This module is compatible with cordova-plugin-native-storage. ### Android You need to use the same SharedPreference as in the cordova plugin, to do so add the following line: ```js import { Platform } from 'react-native'; // ... if (Platform.OS === 'android') DefaultPreference.setName('NativeStorage'); ``` ### iOS You don't need to change the name, as cordova-plugin-native-storage uses the default value.