Skip to content

Commit

Permalink
Merge pull request #188 from Giphy/feat/localization
Browse files Browse the repository at this point in the history
Feat/localization
  • Loading branch information
ALexanderLonsky authored Aug 8, 2024
2 parents 6a112e5 + 973abbe commit e06573f
Show file tree
Hide file tree
Showing 4 changed files with 128 additions and 5 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ Facebook, Slack, Instagram, and more – with just a few lines of code.
- [GIPHY Animated Text Creation](docs/animated.md)
- [Example App](https://github.com/Giphy/giphy-react-native-sdk/tree/main/example)
- [How to mock the Giphy dependency in Jest](docs/testing-jest.md)
- [How to localize the Giphy SDK](docs/localization.md)

### [API Reference](docs/api.md)

Expand Down
122 changes: 122 additions & 0 deletions docs/localization.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,122 @@
## GIPHY SDK Localization

To enable localization for the SDK in your application, follow the steps outlined below for both iOS and Android platforms. This guide will also cover how to add support for additional languages. Note that our SDK is now based on the device language, not on an app-basis, ensuring that your app will display content in the language set by the user's device.

### iOS Localization

#### Adding Localization Files

1. Create Localizable.strings file:
- In your Xcode project, create/navigate to the `Localization` folder.
- Right-click on the folder and select `New File....`
- Choose `Strings File` from the templates and name it `Localizable.strings`.
- Add the file to all the targets in your project.
2. Localize `Localizable.strings` File:
- Select the `Localizable.strings` file in the Project Navigator.
- In the File Inspector (right-hand pane), find the `Localization` section.
- Click the `Localize...` button and choose your development language.
- In the `Localizable.strings` file, add key-value pairs for the strings you want to localize.

#### Example Localizable.strings

```
"no_gifs_found" = "No GIFs found";
"no_stickers_found" = "No stickers found";
"no_text_found" = "No text found";
"no_clips_found" = "No clips found";
"search_giphy" = "Search GIPHY";
"something_went_wrong" = "Something went wrong. Please try again later.";
"gifs" = "GIFs";
"stickers" = "Stickers";
"text" = "Text";
"emoji" = "Emoji";
"recents" = "Recents";
"clips" = "Clips";
"select" = "Select";
"select_gif" = "Select GIF";
"select_sticker" = "Select Sticker";
"select_clip" = "Select Clip";
"select_emoji" = "Select Emoji";
"more_from" = "More from %@";
"remove_from_recents" = "Remove from recents";
"back" = "Back";
"information" = "Information";
```

#### Adding More Languages
1. Add a New Language:
- In Xcode, select your project.
- Go to the `Info` tab and click the `+` button under `Localizations`.
- Select the new language you want to add.
2. Localize `Localizable.strings` File:
- Xcode will prompt you to localize `Localizable.strings` for the new language.
- Add translations for your strings in the newly created `Localizable.strings` file.


### Android Localization

#### Adding Localization Files

1. Create strings.xml file if it's not available:
- In your Android project, navigate to the `res/values` folder.
- Right-click on the values folder and select `New` > `Value Resource File`.
- Name the file `strings.xml` and click OK.
2. Adding Strings::
- Open `strings.xml` and add your string resources.

#### Example strings.xml

```
<resources>
<string name="app_name">GiphyReactNativeSdk Example</string>
<string name="gph_retry">Retry</string>
<string name="gph_error_generic_list_loading">Oh NO! Something Went Wrong.</string>
<string name="gph_search_giphy">Search GIPHY</string>
<string name="gph_gifs">GIFs</string>
<string name="gph_clips">Clips</string>
<string name="gph_stickers">Stickers</string>
<string name="gph_select">Select</string>
<string name="gph_choose_gif">Select GIF</string>
<string name="gph_choose_clip">Select Clip</string>
<string name="gph_choose_sticker">Select Sticker</string>
<string name="gph_choose_emoji">Select Emoji</string>
<string name="gph_attribution_back">Back</string>
<string name="gph_back">Back</string>
<string name="gph_view_on_giphy">View on GIPHY</string>
<string name="gph_copy_link">Copy Link</string>
<string name="gph_more_by">More by @%1$s</string>
<string name="gph_text">Text</string>
<string name="gph_emoji">Emoji</string>
<string name="gph_recents">Recents</string>
<string name="gph_error_no_gifs_found">No GIFs found</string>
<string name="gph_error_no_stickers_found">No stickers found</string>
<string name="gph_error_no_texts_found">No text found</string>
<string name="gph_error_no_recent_found">No recents found</string>
<string name="gph_error_no_clips_found">No clips found</string>
<string name="gph_remove">Remove</string>
<string name="gph_more_by_you">More by You</string>
<string name="gph_video_error">The clip is currently unavailable</string>
<string name="gph_clear_search">Clear search</string>
<string name="gph_info">Information</string>
</resources>
```

#### Adding More Languages
1. Create New Values Folder:
- To add a new language, create a new values folder with the language code. For example, for French, create a folder named `values-fr`.
- Right-click on the `res` folder, select `New` > `Directory`, and name it `values-fr`.
2. Create strings.xml File:
- Inside the newly created `values-fr` folder, right-click and select `New` > `Value Resource File`.
- Name the file `strings.xml`.
3. Add Translations:
- Open the newly created `strings.xml` file and add your translations.


### Device-Based Language Setting

Our SDK now bases its localization on the device's language settings rather than on an app-basis. This means that your app will automatically adapt to the language configured on the user's device, providing a seamless and intuitive user experience.

#### Benefits of Device-Based Localization:
- Consistency: Users experience the app in their preferred language without needing to configure language settings within the app.
- Simplicity: Developers don't need to implement additional logic to handle language selection within the app.
- User Experience: Enhances the user experience by ensuring the app language matches the device's language settings.
8 changes: 4 additions & 4 deletions example/ios/Podfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -69,10 +69,10 @@ PODS:
- FlipperKit/Core
- FlipperKit/FlipperKitNetworkPlugin
- fmt (6.2.1)
- Giphy (2.2.9):
- Giphy (2.2.10):
- libwebp
- giphy-react-native-sdk (3.2.6):
- Giphy (= 2.2.9)
- Giphy (= 2.2.10)
- RCT-Folly (= 2021.07.22.00)
- React-Core
- glog (0.3.5)
Expand Down Expand Up @@ -703,8 +703,8 @@ SPEC CHECKSUMS:
Flipper-PeerTalk: 116d8f857dc6ef55c7a5a75ea3ceaafe878aadc9
FlipperKit: 2efad7007d6745a3f95e4034d547be637f89d3f6
fmt: ff9d55029c625d3757ed641535fd4a75fedc7ce9
Giphy: 28cef321358869cc871b98ea5e3d707fc1f36fc6
giphy-react-native-sdk: 668dca06fc2998eb4d6d92125e7cd42d8cbd4159
Giphy: 0b86baaae0173dac8acc44a0088f51194ec4d5de
giphy-react-native-sdk: 4844d8cd973d4159b403954b9401d5816285c26c
glog: 04b94705f318337d7ead9e6d17c019bd9b1f6b1b
hermes-engine: 8057e75cfc1437b178ac86c8654b24e7fead7f60
libevent: 4049cae6c81cdb3654a443be001fb9bdceff7913
Expand Down
2 changes: 1 addition & 1 deletion giphy-react-native-sdk.podspec
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ Pod::Spec.new do |s|

s.source_files = "ios/**/*.{h,m,mm,swift}"

s.dependency "Giphy", "2.2.9"
s.dependency "Giphy", "2.2.10"

s.pod_target_xcconfig = {
"DEFINES_MODULE" => "YES"
Expand Down

0 comments on commit e06573f

Please sign in to comment.