chromium/chromeos/ui/base/file_icon_util.h

// Copyright 2019 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef CHROMEOS_UI_BASE_FILE_ICON_UTIL_H_
#define CHROMEOS_UI_BASE_FILE_ICON_UTIL_H_

#include <optional>

#include "base/files/file_path.h"
#include "chromeos/constants/chromeos_features.h"
#include "third_party/skia/include/core/SkColor.h"
#include "ui/gfx/color_palette.h"
#include "ui/gfx/image/image_skia.h"

namespace gfx {
struct VectorIcon;
}  // namespace gfx

namespace chromeos {

enum class IconType {
  kAudio,
  kArchive,
  kChart,
  kDrive,
  kExcel,
  kFolder,
  kFolderShared,
  kGdoc,
  kGdraw,
  kGeneric,
  kGform,
  kGmap,
  kGsheet,
  kGsite,
  kGmaillayout,
  kGslide,
  kGtable,
  kLinux,
  kImage,
  kPdf,
  kPpt,
  kScript,
  kSites,
  kTini,
  kVideo,
  kWord,
};

namespace internal {

COMPONENT_EXPORT(CHROMEOS_UI_BASE)
IconType GetIconTypeFromString(const std::string& icon_type_string);

COMPONENT_EXPORT(CHROMEOS_UI_BASE)
IconType GetIconTypeForPath(const base::FilePath& filepath);

}  // namespace internal

// Returns the file type vector icon for the specified `file_path`.
COMPONENT_EXPORT(CHROMEOS_UI_BASE)
const gfx::VectorIcon& GetIconForPath(const base::FilePath& file_path);

// Returns the file type icon for the specified `file_path`. If
// `dark_background` is `true`, lighter foreground colors are used to ensure
// sufficient contrast.
COMPONENT_EXPORT(CHROMEOS_UI_BASE)
gfx::ImageSkia GetIconForPath(const base::FilePath& file_path,
                              bool dark_background,
                              std::optional<int> dip_size = {});

// Returns the file type chip icon for the specified `filepath`.
COMPONENT_EXPORT(CHROMEOS_UI_BASE)
gfx::ImageSkia GetChipIconForPath(const base::FilePath& filepath,
                                  bool dark_background);

// Returns the file type vector icon for the specified `icon_type`.
COMPONENT_EXPORT(CHROMEOS_UI_BASE)
const gfx::VectorIcon& GetIconFromType(const std::string& icon_type);

// Returns the file type icon for the specified `icon_type`.
COMPONENT_EXPORT(CHROMEOS_UI_BASE)
gfx::ImageSkia GetIconFromType(const std::string& icon_type,
                               bool dark_background);

// Returns the file type icon for the specified `icon_type`. If
// `dark_background` is `true`, lighter foreground colors are used to ensure
// sufficient contrast.
COMPONENT_EXPORT(CHROMEOS_UI_BASE)
gfx::ImageSkia GetIconFromType(IconType icon_type,
                               bool dark_background,
                               std::optional<int> dip_size = {});

// Returns the resolved color of the file type icon for the specified
// `filepath`. If `dark_background` is `true`, lighter foreground colors are
// used to ensure sufficient contrast.
COMPONENT_EXPORT(CHROMEOS_UI_BASE)
SkColor GetIconColorForPath(const base::FilePath& filepath,
                            bool dark_background);

}  // namespace chromeos

#endif  // CHROMEOS_UI_BASE_FILE_ICON_UTIL_H_