2018-05-22 15:48:19 -07:00
|
|
|
/**
|
|
|
|
* 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 <memory>
|
2018-06-01 09:36:25 -07:00
|
|
|
#include <mutex>
|
2018-05-22 15:48:19 -07:00
|
|
|
|
|
|
|
#include <folly/dynamic.h>
|
2018-07-17 22:41:39 -07:00
|
|
|
#include <fabric/events/EventDispatcher.h>
|
|
|
|
#include <fabric/events/primitives.h>
|
2018-05-22 15:48:19 -07:00
|
|
|
|
|
|
|
namespace facebook {
|
|
|
|
namespace react {
|
|
|
|
|
2018-06-09 13:02:55 -07:00
|
|
|
class EventEmitter;
|
2018-05-22 15:48:19 -07:00
|
|
|
|
2018-06-09 13:02:55 -07:00
|
|
|
using SharedEventEmitter = std::shared_ptr<const EventEmitter>;
|
2018-05-22 15:48:19 -07:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Base class for all particular typed event handlers.
|
|
|
|
* Stores `InstanceHandle` identifying a particular component and the pointer
|
|
|
|
* to `EventDispatcher` which is responsible for delivering the event.
|
|
|
|
*/
|
2018-08-27 07:21:24 -07:00
|
|
|
class EventEmitter:
|
|
|
|
public std::enable_shared_from_this<EventEmitter> {
|
2018-05-22 15:48:19 -07:00
|
|
|
|
2018-07-17 22:41:39 -07:00
|
|
|
/*
|
|
|
|
* We have to repeat `Tag` type definition here because `events` module does
|
|
|
|
* not depend on `core` module (and should not).
|
|
|
|
*/
|
|
|
|
using Tag = int32_t;
|
|
|
|
|
2018-05-22 15:48:19 -07:00
|
|
|
public:
|
2018-08-27 07:21:24 -07:00
|
|
|
static std::recursive_mutex &DispatchMutex();
|
2018-05-22 15:48:19 -07:00
|
|
|
|
2018-08-27 07:21:24 -07:00
|
|
|
EventEmitter(const EventTarget &eventTarget, const Tag &tag, const std::shared_ptr<const EventDispatcher> &eventDispatcher);
|
|
|
|
virtual ~EventEmitter() = default;
|
2018-05-22 15:48:19 -07:00
|
|
|
|
2018-08-27 07:21:24 -07:00
|
|
|
/*
|
|
|
|
* Indicates that an event can be delivered to `eventTarget`.
|
|
|
|
* Callsite must acquire `DispatchMutex` to access those methods.
|
|
|
|
*/
|
|
|
|
void setEnabled(bool enabled) const;
|
|
|
|
bool getEnabled() const;
|
|
|
|
|
|
|
|
protected:
|
2018-05-22 15:48:19 -07:00
|
|
|
/*
|
|
|
|
* Initates an event delivery process.
|
|
|
|
* Is used by particular subclasses only.
|
|
|
|
*/
|
|
|
|
void dispatchEvent(
|
2018-06-01 09:36:19 -07:00
|
|
|
const std::string &type,
|
|
|
|
const folly::dynamic &payload = folly::dynamic::object(),
|
2018-05-22 15:48:19 -07:00
|
|
|
const EventPriority &priority = EventPriority::AsynchronousBatched
|
|
|
|
) const;
|
|
|
|
|
|
|
|
private:
|
2018-08-27 07:21:24 -07:00
|
|
|
EventTarget eventTarget_;
|
2018-06-01 09:36:19 -07:00
|
|
|
Tag tag_;
|
2018-05-22 15:48:19 -07:00
|
|
|
std::weak_ptr<const EventDispatcher> eventDispatcher_;
|
2018-08-27 07:21:24 -07:00
|
|
|
mutable bool enabled_; // Protected by `DispatchMutex`.
|
2018-05-22 15:48:19 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace react
|
|
|
|
} // namespace facebook
|