Valentin Shergin d9ff1769aa Fabric/Text: <Paragraph> is now supporting text attributes
Summary:
I was shamed by Sebastian's sebmarkbage concerns (totally unrelated to this topic) about introducing another level of indirection into the system and decided to change my original plan not to support text attributes for the <Paragraph> component.

So, now <Paragraph> shares <View>, <Text> and <Paragraph> itself capabilities. That reduces the minimum amount of required components for trivial text fragment from three (Paragraph, Text, RawText) to two (Paragraph and RawText).

Special thanks for C++ for supporting multiple inheritance.

Reviewed By: mdvacca

Differential Revision: D7785889

fbshipit-source-id: dd9f2e2650bfbfd76d7d4b538adaf409f9429df3
2018-05-08 19:24:10 -07:00

49 lines
1007 B
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 <fabric/attributedstring/TextAttributes.h>
#include <fabric/core/Props.h>
#include <fabric/graphics/Color.h>
#include <fabric/graphics/Geometry.h>
namespace facebook {
namespace react {
/*
* `Props`-like class which is used as a base class for all Props classes
* that can have text attributes (such as Text and Paragraph).
*/
class BaseTextProps {
public:
/*
* Same semantic as `Props::apply(...)`.
*/
void apply(const RawProps &rawProps);
#pragma mark - Getters
/*
* Returns all props values as `TextAttributes` object.
*/
TextAttributes getTextAttributes() const;
#pragma mark - DebugStringConvertible (partially)
SharedDebugStringConvertibleList getDebugProps() const;
private:
TextAttributes textAttributes_;
};
} // namespace react
} // namespace facebook