Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
C
coopwire-hypothesis
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
孙灵跃 Leon Sun
coopwire-hypothesis
Commits
44918b5e
Commit
44918b5e
authored
Jun 07, 2017
by
Juan Corona
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Clean up and refactor the multi frame support in CrossFrame
parent
e11f88f2
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
48 additions
and
44 deletions
+48
-44
cross-frame.coffee
src/annotator/plugin/cross-frame.coffee
+48
-44
No files found.
src/annotator/plugin/cross-frame.coffee
View file @
44918b5e
...
...
@@ -3,8 +3,9 @@ Plugin = require('../plugin')
AnnotationSync
=
require
(
'../annotation-sync'
)
Bridge
=
require
(
'../../shared/bridge'
)
Discovery
=
require
(
'../../shared/discovery'
)
f
rameUtil
=
require
(
'../util/frame-util'
)
F
rameUtil
=
require
(
'../util/frame-util'
)
debounce
=
require
(
'lodash.debounce'
)
# Extracts individual keys from an object and returns a new one.
extract
=
extract
=
(
obj
,
keys
...)
->
...
...
@@ -12,11 +13,17 @@ extract = extract = (obj, keys...) ->
ret
[
key
]
=
obj
[
key
]
for
key
in
keys
when
obj
.
hasOwnProperty
(
key
)
ret
# Find difference of two arrays
difference
=
(
arrayA
,
arrayB
)
->
arrayA
.
filter
(
x
)
->
!
arrayB
.
includes
(
x
)
# Class for establishing a messaging connection to the parent sidebar as well
# as keeping the annotation state in sync with the sidebar application, this
# frame acts as the bridge client, the sidebar is the server. This plugin
# can also be used to send messages through to the sidebar using the
# call method.
# call method. This plugin also enables the discovery and management of
# not yet known frames in a multiple frame scenario.
module
.
exports
=
class
CrossFrame
extends
Plugin
constructor
:
(
elem
,
options
)
->
super
...
...
@@ -29,21 +36,15 @@ module.exports = class CrossFrame extends Plugin
opts
=
extract
(
options
,
'on'
,
'emit'
)
annotationSync
=
new
AnnotationSync
(
bridge
,
opts
)
handledFrames
=
[]
this
.
pluginInit
=
->
onDiscoveryCallback
=
(
source
,
origin
,
token
)
->
bridge
.
createChannel
(
source
,
origin
,
token
)
discovery
.
startDiscovery
(
onDiscoveryCallback
)
# THESIS TODO: Disabled until fully implemented.
#
# Find, and inject Hypothesis into Guest's iframes
# _discoverOwnFrames()
# Listen for DOM mutations, to know when iframes are added / removed
observer
=
new
MutationObserver
(
_checkForIFrames
)
config
=
{
childList
:
true
,
subtree
:
true
};
# THESIS TODO: Disabled until multi-guest support is fully implemented
# observer.observe(elem, config);
if
options
.
enableMultiFrameSupport
_setupFrameDetection
()
this
.
destroy
=
->
# super doesnt work here :(
...
...
@@ -63,36 +64,39 @@ module.exports = class CrossFrame extends Plugin
this
.
onConnect
=
(
fn
)
->
bridge
.
onConnect
(
fn
)
_discoverOwnFrames
=
()
->
# Discover existing iframes
iframes
=
frameUtil
.
findIFrames
(
elem
)
_handleIFrames
(
iframes
)
_checkForIFrames
=
(
mutations
)
->
for
own
key
,
mutation
of
mutations
addedNodes
=
mutation
.
addedNodes
removedNodes
=
mutation
.
removedNodes
# Add iframes
for
own
key
,
node
of
addedNodes
if
(
node
.
tagName
==
'IFRAME'
&&
node
.
className
!=
'h-sidebar-iframe'
)
node
.
addEventListener
'load'
,
->
bridge
.
call
(
'addedIFrame'
)
_handleIFrame
(
node
)
# Remove iframes
for
own
key
,
node
of
removedNodes
if
(
node
.
tagName
==
'IFRAME'
)
bridge
.
call
(
'removedIFrame'
)
_handleIFrame
=
(
iframe
)
->
if
!
frameUtil
.
isAccessible
(
iframe
)
then
return
if
!
frameUtil
.
hasHypothesis
(
iframe
)
frameUtil
.
injectHypothesis
(
iframe
)
_handleIFrames
=
(
iframes
)
->
for
own
index
,
iframe
of
iframes
_handleIFrame
(
iframe
)
_setupFrameDetection
=
->
_discoverOwnFrames
()
# Listen for DOM mutations, to know when frames are added / removed
observer
=
new
MutationObserver
(
debounce
(
_discoverOwnFrames
,
300
))
observer
.
observe
(
elem
,
{
childList
:
true
,
subtree
:
true
});
_discoverOwnFrames
=
->
frames
=
FrameUtil
.
findFrames
(
elem
)
for
frame
in
frames
if
frame
not
in
handledFrames
_handleFrame
(
frame
)
handledFrames
.
push
(
frame
)
for
frame
,
i
in
difference
(
handledFrames
,
frames
)
_iframeUnloaded
(
frame
)
delete
handledFrames
[
i
]
_injectToFrame
=
(
frame
)
->
if
!
FrameUtil
.
hasHypothesis
(
frame
)
FrameUtil
.
injectHypothesis
(
frame
,
options
.
embedScriptUrl
)
frame
.
contentWindow
.
addEventListener
'unload'
,
->
_iframeUnloaded
(
frame
)
_handleFrame
=
(
frame
)
->
if
!
FrameUtil
.
isAccessible
(
frame
)
then
return
if
frame
.
contentDocument
.
readyState
!=
'complete'
frame
.
addEventListener
'load'
,
->
_injectToFrame
(
frame
)
else
_injectToFrame
(
frame
)
_iframeUnloaded
=
(
frame
)
->
bridge
.
call
(
'destroyFrame'
,
frame
.
src
);
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment