🏠 Homepage
Introducing our innovative Flutter app, specifically designed to transform the landscape of e-commerce personalization and segmentation. Built upon the versatile and robust Flutter framework, this app offers a seamless cross-platform experience for both iOS and Android users. It's tailored to empower e-commerce businesses in elevating their customer engagement and retention strategies. With this app, gone are the days of one-size-fits-all marketing approaches. It enables businesses to deeply understand their customers, customizing offerings to individual preferences and behaviors, and thus paving the way for more personalized and effective marketing campaigns.
- Personalized Recommendations:
Our app leverages advanced algorithms and machine learning techniques to analyze user behavior, purchase history, and preferences. Based on these insights, it generates personalized product recommendations that are displayed within the app. This helps businesses enhance the user experience, increase conversions, and drive customer loyalty. - Dynamic Content: Delivering the right content to the right audience is crucial in capturing users' attention. Our app allows businesses to dynamically update and customize app content based on user segments. Whether it's displaying targeted banners, promotional offers, or exclusive content, our app ensures that each user sees content relevant to their interests and needs.
- Search Functionality: Our app includes a powerful search feature that allows users to quickly find products based on their preferences. Users can search by keywords, filters, categories, or any other relevant attributes. The search results are displayed in real-time, ensuring a smooth and efficient user experience. Businesses can also utilize search analytics to gain insights into popular search terms, customer preferences, and optimize their product offerings.
- User Segmentation: Understanding your audience is key to effective marketing. Our app enables businesses to segment their user base using a wide range of criteria, including demographics, purchase history, engagement level, and more. This segmentation capability allows businesses to create highly targeted marketing campaigns and tailor their messaging to specific user groups, resulting in higher engagement and conversion rates.
- A/B Testing: Optimizing user experiences and marketing strategies is made easy with our A/B testing feature. Businesses can create multiple versions of app components, such as layouts, UI elements, or promotional content, and test them with different user segments. By measuring and analyzing user interactions and conversion rates, businesses can make data-driven decisions to continuously improve their app's performance and user satisfaction.
- Seamless Integration: Our Flutter app seamlessly integrates with existing e-commerce platforms, ensuring a smooth and hassle-free implementation process. Whether you're using popular e-commerce platforms like Shopify or WooCommerce, our app can be easily integrated into your existing infrastructure, allowing you to leverage the power of personalization and segmentation without disrupting your current operations.
- Analytics and Insights : In-depth analytics and reporting provide businesses with valuable insights into user behavior, preferences, and campaign performance. Our app provides detailed analytics dashboards, allowing businesses to track key metrics, monitor the success of personalization efforts, and make data-backed decisions to optimize their marketing strategies.
- Push Notifications: Our app allows businesses to send personalized push notifications to their users. Businesses can create custom push notifications based on user segments, such as location, demographics, or purchase history. This enables businesses to deliver targeted messages to specific user groups, resulting in higher engagement and conversion rates.
Take your e-commerce business to new heights with our Flutter app that brings personalization and segmentation to the forefront. Engage your users on a personal level, deliver relevant content, and drive conversions like never before. Stay ahead of the competition and build lasting relationships with your customers with our powerful and intuitive app..
flutter >= v2.8
flutter pub add segmentify-sdk
Segmentify Flutter App SDK is a Flutter library designed to enable the integration of Segmentify into your Flutter app. It offers a straightforward interface for tracking user behavior and sending events.
This SDK is already coded with Flutter's philosophy in mind, making it a seamless addition to any Flutter project.
Config is a type that contains the following properties:
apiKey
: string (required)dataCenterUrl
: string (required)dataCenterPushUrl
: string (optional)subDomain
: string (required)language
: string (required)
This is the configuration that you can get from Segmentify.
const Map<String, dynamic> segmentifyConfig = {
'sgm_config': {
'apiKey': 'your-api-key',
'dataCenterUrl': 'https://per.segmentify.com',
'subDomain': 'https://www.yoursite.com',
'dataCenterPushUrl': 'https://psh.segmentify.com',
'isApnsEnabled': false,
'language': 'TR',
},
'sgm_user': {
'userId': '',
'sessionId': '',
},
};
User flow is flexible. You can use it like this as well. In this way segmentify will generate userId and sessionId for you.
In this Flutter application, start by importing the segmentify_flutter_sdk package using the alias Segmentify. Then, in your main method, initialize the package by calling Segmentify.SegmentifyInitializer
with your specific configuration settings provided in segmentifyConfig
. This step prepares the package for use throughout your application.
import 'package:segmentify_flutter_sdk/main.dart' as Segmentify;
import 'config.dart';
void main() async {
Segmentify.SegmentifyInitializer(segmentifyConfig: segmentifyConfig);
runApp(const MyApp());
}
If you have access to Segmentify Web Push product, you will need additional steps to integrate Segmentify SDK to your application. Please follow here for more information.
The SegmentifyEvent class contains various functions used to send events to Segmentify. To use these functions, you need to import types from the SegmentifyTypes module.
To use Segmentify events, you must import the Segmentify and SegmentifyTypes modules at the top of your file like this:
import 'package:segmentify_flutter_sdk/main.dart' as Segmentify;
import 'package:segmentify_flutter_sdk/models/event_types.dart' as SegmentifyTypes;
Below is an example of how to use Segmentify events. When creating a model, you can see the required parameters. For instance, a pageView event is created using SegmentifyTypes.PageViewModel
and sent to Segmentify through Segmentify.segmentifyEvent
. The variable responseOfEvent captures the response from this event:
final segmentifyEvent = await Segmentify.segmentifyEvent();
final pageViewPayload = SegmentifyTypes.PageViewModel(category: 'Home Page');
final responseOfEvent = await segmentifyEvent.pageView(pageViewPayload);
Segmentify Handles push notification according to your firebase integration. Flutter projects requires an external package for firebase integration. You can find more information from here.
flutter pub add firebase_core
flutter pub add firebase_messaging
The firebase_core
and firebase_messaging
modules must be installed before using any other Firebase service.
To allow the Android app to securely connect to your Firebase project, a configuration file must be downloaded and added to your project.
On the Firebase console, add a new Android application and enter your projects details. The Android package name
must match your local projects package name which can be found inside of the manifest tag within the /android/app/src/main/AndroidManifest.xml
file within your project.
Download the google-services.json
file and place it inside of your project at the following location: /android/app/google-services.json
.
To allow Firebase on Android to use the credentials, the google-services
plugin must be enabled on the project. This requires modification to two files in the Android directory.
First, add the google-services
plugin as a dependency inside of your /android/build.gradle
file:
buildscript {
dependencies {
// ... other dependencies
classpath 'com.google.gms:google-services:4.3.15'
// Add me --- /\
}
}
Lastly, execute the plugin by adding the following to your /android/app/build.gradle
file:
apply plugin: 'com.android.application'
apply plugin: 'com.google.gms.google-services' // <- Add this line
To allow the iOS app to securely connect to your Firebase project, a configuration file must be downloaded and added to your project, and you must enable frameworks in CocoaPods.
On the Firebase console, add a new iOS application and enter your projects details. The "iOS bundle ID" must match your local project bundle ID. The bundle ID can be found within the "General" tab when opening the project with Xcode.
Download the GoogleService-Info.plist
file.
Using Xcode, open the projects /ios/{projectName}.xcodeproj
file (or /ios/{projectName}.xcworkspace
if using Pods).
Right click on the project name and "Add files" to the project, as demonstrated below:
Select the downloaded GoogleService-Info.plist
file from your computer, and ensure the "Copy items if needed" checkbox is enabled.
To allow Firebase on iOS to use the credentials, the Firebase iOS SDK must be configured during the bootstrap phase of your application.
To do this, open your /ios/{projectName}/AppDelegate.mm
file, and add the following:
At the top of the file, import the Firebase SDK right after #import "AppDelegate.h"
:
#import <Firebase.h>
Then, inside of the didFinishLaunchingWithOptions
method, add the following:
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// Add me --- \/
[FIRApp configure];
// Add me --- /\
// ...
}
flutter pub get
cd ios/
pod install --repo-update
cd ..
flutter run
Once successfully linked and rebuilt, your application will be connected to Firebase using the firebase_core
Flutter module. This module alone does not provide extensive functionality, so to utilize other Firebase services, you will need to install separate modules for each Firebase service.
Immediately after installing Segmentify and Firebase in your Flutter project, it's recommended to run the following commands to ensure everything is set up correctly. This is particularly important for iOS:
cd ios/
rm -rf Pods
pod deintegrate
pod install --repo-update
cd ..
flutter clean
flutter pub get
flutter run
These commands clean and set up the iOS part of your Flutter project and then ensure all Flutter dependencies are correctly fetched and the app is ready to run.
To use Segmentify Push, we need to make changes to the initial SegmentifyInitializer part that we did at the beginning. For this, we need to modify the changes we made in the main.dart file as follows.
First, you need to create FirebaseOptions to use in Firebase's initialization step.
import 'package:firebase_core/firebase_core.dart' show FirebaseOptions;
import 'package:flutter/foundation.dart'
show defaultTargetPlatform, TargetPlatform;
FirebaseOptions get firebaseOptions {
if (defaultTargetPlatform == TargetPlatform.android) {
return const FirebaseOptions(
appId:
'android_appId', // google-services.json -> client -> client_info -> mobilesdk_app_id
apiKey:
'android_apiKey', // google-services.json -> client -> api_key -> current
projectId:
'android_projectId', // google-services.json -> project_info -> project_id
messagingSenderId:
'android_messagingSenderId', // google-services.json -> project_info -> project_number
);
}
if (defaultTargetPlatform == TargetPlatform.iOS) {
return const FirebaseOptions(
appId:
'ios_appId', // GoogleService-Info.plist -> CLIENT_ID -> REVERSED_CLIENT_ID
apiKey:
'ios_apiKey', // GoogleService-Info.plist -> API_KEY -> CURRENT_KEY (or API_KEY)
projectId:
'ios_projectId', // GoogleService-Info.plist -> PROJECT_ID (or PROJECT_NUMBER)
messagingSenderId:
'ios_messagingSenderId', // GoogleService-Info.plist -> PROJECT_NUMBER (or SENDER_ID)
);
}
throw UnsupportedError('Unsupported platform');
}
Segmentify requires your Firebase and Firebase Messaging instance to be passed to SegmentifyInitializer to execute your push flow automatically.
import 'package:segmentify_flutter_sdk/main.dart' as Segmentify;
import 'package:segmentify_flutter_sdk/models/event_types.dart' as SegmentifyTypes;
import 'config.dart';
import 'firebase_options.dart';
void main() async {
// Initialization for Flutter
WidgetsFlutterBinding.ensureInitialized();
// Initialization for Firebase
await Firebase.initializeApp(options: firebaseOptions); // firebase_options.dart
// Initialization for Segmentify
messagingCallback(messageData) {
// It is called when a push notification is clicked
print('Callback function is called');
print('Message Data: $messageData');
print('Message Data Body: ${messageData['body']}');
print('Message Data Title: ${messageData['title']}');
}
FirebaseMessaging messaging = FirebaseMessaging.instance;
Segmentify.SegmentifyInitializer(
segmentifyConfig: segmentifyConfig,
messaging: messaging,
messagingCallback: messagingCallback);
runApp(const MyApp());
}
personalization recommendation segmentation push notification e-commerce
Made with ❤️ by Segmentify Development Team