Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(47)

Side by Side Diff: components/feature_engagement_tracker/public/feature_engagement_tracker.h

Issue 2782113002: Add component for feature engagement tracking. (Closed)
Patch Set: Remove multi-line comment and change public component target to source_set Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2017 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef COMPONENTS_FEATURE_ENGAGEMENT_TRACKER_PUBLIC_FEATURE_ENGAGEMENT_TRACKER_ H_
6 #define COMPONENTS_FEATURE_ENGAGEMENT_TRACKER_PUBLIC_FEATURE_ENGAGEMENT_TRACKER_ H_
7
8 #include <string>
9
10 #include "base/callback.h"
11 #include "base/compiler_specific.h"
12 #include "base/files/file_path.h"
13 #include "base/memory/ref_counted.h"
14 #include "base/sequenced_task_runner.h"
15 #include "components/keyed_service/core/keyed_service.h"
16
17 #if defined(OS_ANDROID)
18 #include "base/android/jni_android.h"
19 #endif // defined(OS_ANDROID)
Elliot Glaysher 2017/03/29 21:11:39 I'm a bit confused about where this gets compiled.
nyquist 2017/03/30 22:58:54 I'll keep the compile on Linux for now to ensure t
20
21 namespace feature_engagement_tracker {
22
23 // The FeatureEngagementTracker provides a backend for displaying feature
24 // enlightenment or in-product help (IPH) with a clean and easy to use API to be
25 // consumed by the UI frontend. The backend behaves as a black box and takes
26 // input about user behavior. Whenever the frontend gives a trigger signal that
27 // IPH could be displayed, the backend will provide an answer to whether it is
28 // appropriate to show it or not.
29 class FeatureEngagementTracker : public KeyedService {
30 public:
31 #if defined(OS_ANDROID)
32 // Returns a Java object of the type FeatureEngagementTracker for the given
33 // FeatureEngagementTracker.
34 static base::android::ScopedJavaLocalRef<jobject> GetJavaObject(
35 FeatureEngagementTracker* feature_engagement_tracker);
36 #endif // defined(OS_ANDROID)
37
38 // Invoked when the tracker has been initialized. The |success| parameter
39 // indicates that the initialization was a success and it it ready to receive
40 // calls.
41 using OnInitializedCallback = base::Callback<void(bool success)>;
42
43 // The |storage_dir| is the path to where all local storage will be.
44 // The |bakground_task_runner| will be used for all disk reads and writes.
45 static FeatureEngagementTracker* Create(
46 const base::FilePath& storage_dir,
47 const scoped_refptr<base::SequencedTaskRunner>& background_task_runner);
48
49 // Must be called whenever an event related to a precondition happens.
50 virtual void Event(const std::string& feature,
51 const std::string& precondition) = 0;
52
53 // Must be called whenever a feature has been used.
54 virtual void Used(const std::string& feature) = 0;
55
56 // This function must be called whenever the triggering condition for a
57 // specific feature happens. Returns true iff the display of feature
58 // enlightenment must happen.
59 // If |true| is returned, the caller *must* call Dismissed() when display
60 // of feature enlightenment ends.
61 virtual bool Trigger(const std::string& feature) WARN_UNUSED_RESULT = 0;
62
63 // Must be called after display of feature enlightenment finishes.
64 virtual void Dismissed() = 0;
65
66 // For features that trigger on startup, they register a callback to ensure
67 // that they are told when the tracker has been initialized.
68 virtual void AddOnInitializedCallback(OnInitializedCallback callback) = 0;
69
70 protected:
71 FeatureEngagementTracker() = default;
72
73 private:
74 DISALLOW_COPY_AND_ASSIGN(FeatureEngagementTracker);
75 };
76
77 } // namespace feature_engagement_tracker
78
79 #endif // COMPONENTS_FEATURE_ENGAGEMENT_TRACKER_PUBLIC_FEATURE_ENGAGEMENT_TRACK ER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698