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
0213de1d
Commit
0213de1d
authored
Apr 10, 2013
by
csillag
Committed by
Randall Leeds
Apr 12, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix #367 -- discovery/store race condition
parent
871ed38b
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
58 additions
and
53 deletions
+58
-53
services.coffee
h/js/services.coffee
+58
-53
No files found.
h/js/services.coffee
View file @
0213de1d
...
@@ -132,58 +132,7 @@ class Hypothesis extends Annotator
...
@@ -132,58 +132,7 @@ class Hypothesis extends Annotator
origin
:
$location
.
search
().
xdm
origin
:
$location
.
search
().
xdm
scope
:
'annotator:panel'
scope
:
'annotator:panel'
window
:
$window
.
parent
window
:
$window
.
parent
onReady
:
=>
onReady
:
=>
console
.
log
"Sidepanel: channel is ready"
patch_update
=
(
store
)
=>
# When the store plugin finishes a request, update the annotation
# using a monkey-patched update function which updates the threading
# if the annotation has a newly-assigned id and ensures that the id
# is enumerable.
store
.
updateAnnotation
=
(
annotation
,
data
)
=>
if
annotation
.
id
?
and
annotation
.
id
!=
data
.
id
# Update the id table for the threading
thread
=
@
threading
.
getContainer
annotation
.
id
thread
.
message
.
id
=
data
.
id
@
threading
.
idTable
[
data
.
id
]
=
thread
delete
@
threading
.
idTable
[
annotation
.
id
]
# The id is no longer temporary and should be serialized
# on future Store requests.
Object
.
defineProperty
annotation
,
'id'
,
configurable
:
true
enumerable
:
true
writable
:
true
# If the annotation is loaded in a view, switch the view
# to reference the new id.
search
=
$location
.
search
()
if
search
?
and
search
.
id
==
annotation
.
id
search
.
id
=
data
.
id
$location
.
search
(
search
).
replace
()
# Update the annotation with the new data
annotation
=
angular
.
extend
annotation
,
data
# Give angular a chance to react
$rootScope
.
$digest
()
# Get the location of the annotated document
@
provider
.
call
method
:
'getHref'
success
:
(
href
)
=>
options
=
angular
.
extend
{},
(
@
options
.
Store
or
{}),
annotationData
:
uri
:
href
loadFromSearch
:
limit
:
1000
uri
:
href
this
.
addPlugin
'Store'
,
options
patch_update
this
.
plugins
.
Store
console
.
log
"Loaded annotions for '"
+
href
+
"'."
for
href
in
this
.
getSynonymURLs
href
console
.
log
"Also loading annotations for: "
+
href
this
.
plugins
.
Store
.
_apiRequest
'search'
,
uri
:
href
,
(
data
)
=>
console
.
log
"Found "
+
data
.
total
+
" annotations here.."
this
.
plugins
.
Store
.
_onLoadAnnotationsFromSearch
data
# Dodge toolbars [DISABLE]
# Dodge toolbars [DISABLE]
#@provider.getMaxBottom (max) =>
#@provider.getMaxBottom (max) =>
...
@@ -348,8 +297,64 @@ class Hypothesis extends Annotator
...
@@ -348,8 +297,64 @@ class Hypothesis extends Annotator
@
element
.
find
(
'#toolbar'
).
removeClass
(
'shown'
)
@
element
.
find
(
'#toolbar'
).
removeClass
(
'shown'
)
.
find
(
'.tri'
).
attr
(
'draggable'
,
false
)
.
find
(
'.tri'
).
attr
(
'draggable'
,
false
)
serviceDiscovery
:
(
options
)
=>
angular
.
extend
@
options
,
Store
:
options
patch_update
:
(
store
)
=>
# When the store plugin finishes a request, update the annotation
# using a monkey-patched update function which updates the threading
# if the annotation has a newly-assigned id and ensures that the id
# is enumerable.
store
.
updateAnnotation
=
(
annotation
,
data
)
=>
if
annotation
.
id
?
and
annotation
.
id
!=
data
.
id
# Update the id table for the threading
thread
=
@
threading
.
getContainer
annotation
.
id
thread
.
message
.
id
=
data
.
id
@
threading
.
idTable
[
data
.
id
]
=
thread
delete
@
threading
.
idTable
[
annotation
.
id
]
# The id is no longer temporary and should be serialized
# on future Store requests.
Object
.
defineProperty
annotation
,
'id'
,
configurable
:
true
enumerable
:
true
writable
:
true
# If the annotation is loaded in a view, switch the view
# to reference the new id.
search
=
$location
.
search
()
if
search
?
and
search
.
id
==
annotation
.
id
search
.
id
=
data
.
id
$location
.
search
(
search
).
replace
()
# Update the annotation with the new data
annotation
=
angular
.
extend
annotation
,
data
# Give angular a chance to react
$rootScope
.
$digest
()
serviceDiscovery
:
(
options
)
=>
$location
=
@
element
.
injector
().
get
'$location'
$rootScope
=
@
element
.
injector
().
get
'$rootScope'
angular
.
extend
@
options
,
Store
:
options
# Get the location of the annotated document
@
provider
.
call
method
:
'getHref'
success
:
(
href
)
=>
options
=
angular
.
extend
{},
(
@
options
.
Store
or
{}),
annotationData
:
uri
:
href
loadFromSearch
:
limit
:
1000
uri
:
href
this
.
addPlugin
'Store'
,
options
this
.
patch_update
this
.
plugins
.
Store
console
.
log
"Loaded annotions for '"
+
href
+
"'."
for
href
in
this
.
getSynonymURLs
href
console
.
log
"Also loading annotations for: "
+
href
this
.
plugins
.
Store
.
_apiRequest
'search'
,
uri
:
href
,
(
data
)
=>
console
.
log
"Found "
+
data
.
total
+
" annotations here.."
this
.
plugins
.
Store
.
_onLoadAnnotationsFromSearch
data
class
DraftProvider
class
DraftProvider
drafts
:
[]
drafts
:
[]
...
...
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