mirror of
https://github.com/status-im/react-native.git
synced 2025-01-17 04:50:59 +00:00
80f7891287
Summary: @public This is follow up for D8601600 and D8247652 (the last one has detailed explanation of the problem). From this commit I propose that we have to follow simple rule: If some prop has a default value which differs from the default value of its type, we have to specify it as {<value>} in .h file and explicitly in .m file, for all other props the default value must not be specified explicitly (in .h files it must be specified as {}). The reason is that we have to embrase those cases and establish behaviour: if we change the default value in .h file, it always means that we have to change the value in .cpp file too. Reviewed By: fkgozali Differential Revision: D8601776 fbshipit-source-id: 3379aace4e2d72febb2b942a3da1cb24decf54be
66 lines
1.6 KiB
C++
66 lines
1.6 KiB
C++
/**
|
|
* Copyright (c) 2015-present, Facebook, Inc.
|
|
*
|
|
* 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 <limits>
|
|
|
|
#include <fabric/attributedstring/primitives.h>
|
|
#include <fabric/debug/DebugStringConvertible.h>
|
|
#include <fabric/graphics/Geometry.h>
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
class ParagraphAttributes;
|
|
|
|
using SharedParagraphAttributes = std::shared_ptr<const ParagraphAttributes>;
|
|
|
|
/*
|
|
* Represents all visual attributes of a paragraph of text.
|
|
* Two data structures, ParagraphAttributes and AttributedText, should be
|
|
* enough to define visual representation of a piece of text on the screen.
|
|
*/
|
|
class ParagraphAttributes:
|
|
public DebugStringConvertible {
|
|
|
|
public:
|
|
|
|
#pragma mark - Fields
|
|
|
|
/*
|
|
* Maximum number of lines which paragraph can take.
|
|
* Zero value represents "no limit".
|
|
*/
|
|
int maximumNumberOfLines {};
|
|
|
|
/*
|
|
* In case if a text cannot fit given boundaries, defines a place where
|
|
* an ellipsize should be placed.
|
|
*/
|
|
EllipsizeMode ellipsizeMode {};
|
|
|
|
/*
|
|
* Enables font size adjustment to fit constrained boundaries.
|
|
*/
|
|
bool adjustsFontSizeToFit {};
|
|
|
|
/*
|
|
* In case of font size adjustment enabled, defines minimum and maximum
|
|
* font sizes.
|
|
*/
|
|
Float minimumFontSize {std::numeric_limits<Float>::quiet_NaN()};
|
|
Float maximumFontSize {std::numeric_limits<Float>::quiet_NaN()};
|
|
|
|
#pragma mark - DebugStringConvertible
|
|
|
|
SharedDebugStringConvertibleList getDebugProps() const override;
|
|
};
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|