File: badged_profile_photo.h

package info (click to toggle)
chromium 138.0.7204.183-1
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 6,071,908 kB
  • sloc: cpp: 34,937,088; ansic: 7,176,967; javascript: 4,110,704; python: 1,419,953; asm: 946,768; xml: 739,971; pascal: 187,324; sh: 89,623; perl: 88,663; objc: 79,944; sql: 50,304; cs: 41,786; fortran: 24,137; makefile: 21,806; php: 13,980; tcl: 13,166; yacc: 8,925; ruby: 7,485; awk: 3,720; lisp: 3,096; lex: 1,327; ada: 727; jsp: 228; sed: 36
file content (53 lines) | stat: -rw-r--r-- 2,035 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
// Copyright 2017 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROME_BROWSER_UI_VIEWS_PROFILES_BADGED_PROFILE_PHOTO_H_
#define CHROME_BROWSER_UI_VIEWS_PROFILES_BADGED_PROFILE_PHOTO_H_

#include "ui/base/metadata/metadata_header_macros.h"
#include "ui/gfx/image/image.h"
#include "ui/views/metadata/view_factory.h"
#include "ui/views/view.h"

// Creates a bagded profile photo for the current profile card in the
// profile chooser menu. The view includes the photo and the badge itself,
// but not the bagde border to the right and to the bottom.
// More badges, e.g. for syncing, will be supported in the future (project
// DICE).
class BadgedProfilePhoto : public views::View {
  METADATA_HEADER(BadgedProfilePhoto, views::View)

 public:
  enum BadgeType {
    BADGE_TYPE_NONE,
    BADGE_TYPE_SUPERVISOR,
    BADGE_TYPE_CHILD,
    BADGE_TYPE_SYNC_COMPLETE,
    BADGE_TYPE_SYNC_ERROR,
    BADGE_TYPE_SYNC_PAUSED,
    BADGE_TYPE_SYNC_DISABLED,
    BADGE_TYPE_SYNC_OFF,
  };

  // Width/Height of the profile photo.
  static constexpr int kImageSize = 40;

  // Constructs a View hierarchy with the gfx::ImageSkia corresponding to
  // |badge_type| positioned in the bottom-right corner of |profile_photo|. In
  // RTL mode the badge is positioned in the bottom-left corner. The profile
  // photo will be adjusted to be circular and of size 40x40 (kImageSize).
  // If |badge_type| is BADGE_TYPE_NONE no badge will be placed on top of the
  // profile photo. The size of the View is fixed.
  // TODO(tangltom): Add accessibility features in the future.
  BadgedProfilePhoto(BadgeType badge_type, const gfx::Image& profile_photo);
  BadgedProfilePhoto(const BadgedProfilePhoto&) = delete;
  BadgedProfilePhoto& operator=(const BadgedProfilePhoto&) = delete;
};

BEGIN_VIEW_BUILDER(, BadgedProfilePhoto, views::View)
END_VIEW_BUILDER

DEFINE_VIEW_BUILDER(, BadgedProfilePhoto)

#endif  // CHROME_BROWSER_UI_VIEWS_PROFILES_BADGED_PROFILE_PHOTO_H_