mirror of
https://github.com/status-im/react-native.git
synced 2025-02-23 14:48:25 +00:00
Summary: All code styles are terribly ugly. We have the only choise - choise something and embrace it. This particular code style was borrowed from a neibour Fabric-friendly project because it follows established Facebook guides and respects client-side traditions. Reviewed By: mdvacca Differential Revision: D10218598 fbshipit-source-id: 8c4cf6713c07768566dadef479191661c79988f0
49 lines
884 B
C++
49 lines
884 B
C++
/**
|
|
* Copyright (c) Facebook, Inc. and its affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include <fabric/graphics/Geometry.h>
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
class ImageSource {
|
|
public:
|
|
enum class Type { Invalid, Remote, Local };
|
|
|
|
Type type{};
|
|
std::string uri{};
|
|
std::string bundle{};
|
|
Float scale{3};
|
|
Size size{0};
|
|
|
|
bool operator==(const ImageSource &rhs) const {
|
|
return std::tie(this->type, this->uri) == std::tie(rhs.type, rhs.uri);
|
|
}
|
|
|
|
bool operator!=(const ImageSource &rhs) const {
|
|
return !(*this == rhs);
|
|
}
|
|
};
|
|
|
|
using ImageSources = std::vector<ImageSource>;
|
|
|
|
enum class ImageResizeMode {
|
|
Cover,
|
|
Contain,
|
|
Stretch,
|
|
Center,
|
|
Repeat,
|
|
};
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|