mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-10 02:03:07 +08:00
fix(injected-component): Correctly call methods to the injected instance
- Adds check to `_runInnerDOMMethod` to check if inner is an UnsafeComponent and relay the call appropriately - Removes duplicated logic from `_setRequiredMethods`
This commit is contained in:
parent
bb9f9d4b84
commit
5158ab1e38
1 changed files with 7 additions and 8 deletions
|
@ -127,27 +127,26 @@ class InjectedComponent extends React.Component
|
|||
# 2. Any native implementation provided by the DOM
|
||||
# 3. Ourselves, so that the method always has /some/ effect.
|
||||
#
|
||||
_runInnerDOMMethod: (method) =>
|
||||
_runInnerDOMMethod: (method, args...) =>
|
||||
target = null
|
||||
if @refs.inner and @refs.inner[method]
|
||||
if @refs.inner instanceof UnsafeComponent and @refs.inner.injected[method]?
|
||||
target = @refs.inner.injected
|
||||
else if @refs.inner and @refs.inner[method]?
|
||||
target = @refs.inner
|
||||
else if @refs.inner
|
||||
target = React.findDOMNode(@refs.inner)
|
||||
else
|
||||
target = React.findDOMNode(@)
|
||||
|
||||
target[method]?()
|
||||
target[method].bind(target)(args...)
|
||||
|
||||
_setRequiredMethods: (methods) =>
|
||||
methods.forEach (method) =>
|
||||
Object.defineProperty(@, method,
|
||||
configurable: true
|
||||
enumerable: true
|
||||
get: =>
|
||||
if @refs.inner instanceof UnsafeComponent
|
||||
@refs.inner.injected[method]?.bind(@refs.inner.injected)
|
||||
else
|
||||
@refs.inner[method]?.bind(@refs.inner)
|
||||
value: (args...)=>
|
||||
@_runInnerDOMMethod(method, args...)
|
||||
)
|
||||
|
||||
_verifyRequiredMethods: =>
|
||||
|
|
Loading…
Reference in a new issue