| author | veltr |
| Wed, 21 Mar 2012 16:43:25 +0100 | |
| branch | popcorn-port |
| changeset 836 | 526f91f5253e |
| parent 834 | 573c7ca752e0 |
| child 837 | 353a78021ebc |
| permissions | -rw-r--r-- |
| 543 | 1 |
IriSP.createAnnotationWidget = function(Popcorn, config, Serializer) { |
2 |
IriSP.Widget.call(this, Popcorn, config, Serializer); |
|
3 |
this._hidden = true; |
|
| 718 | 4 |
|
| 830 | 5 |
this.checkOption("keywords"); |
6 |
this.checkOption("polemic_mode", true); |
|
7 |
this.checkOption("polemics"); |
|
8 |
this.checkOption("cinecast_version", false); |
|
9 |
this.checkOption("api_endpoint_template"); |
|
10 |
this.checkOption("show_from_field", true); |
|
11 |
this.checkOption("api_method"); |
|
12 |
|
|
13 |
if (!IriSP.null_or_undefined(IriSP.user)) { |
|
14 |
if (!IriSP.null_or_undefined(IriSP.user.avatar)) { |
|
15 |
this.user_avatar = IriSP.user.avatar; |
|
16 |
} |
|
17 |
if (!IriSP.null_or_undefined(IriSP.user.name)) { |
|
18 |
this.user_name = IriSP.user.name; |
|
19 |
} |
|
20 |
} |
|
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
21 |
|
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
22 |
/* variables to save the current position of the slicer */ |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
23 |
if (this.cinecast_version) { |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
24 |
this.sliceLeft = 0; |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
25 |
this.sliceWidth = 0; |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
26 |
} |
| 543 | 27 |
}; |
28 |
||
29 |
||
30 |
IriSP.createAnnotationWidget.prototype = new IriSP.Widget(); |
|
31 |
||
32 |
IriSP.createAnnotationWidget.prototype.clear = function() { |
|
33 |
this.selector.find(".Ldt-SaTitle").text(""); |
|
34 |
this.selector.find(".Ldt-SaDescription").text(""); |
|
35 |
this.selector.find(".Ldt-SaKeywordText").text(""); |
|
36 |
}; |
|
37 |
||
38 |
IriSP.createAnnotationWidget.prototype.draw = function() { |
|
39 |
var _this = this; |
|
|
762
5497895a3ddb
if the platform has defined an user avatar, use it when submitting the annotation.
hamidouk
parents:
759
diff
changeset
|
40 |
|
| 718 | 41 |
var annotationMarkup = IriSP.templToHTML(IriSP.createAnnotationWidget_template, |
| 830 | 42 |
this); |
|
553
10d08f43c534
widget works now more or less like in samuel's crea.
hamidouk
parents:
549
diff
changeset
|
43 |
|
| 543 | 44 |
this.selector.append(annotationMarkup); |
| 548 | 45 |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
46 |
if (!this.cinecast_version) |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
47 |
this.selector.hide(); |
|
817
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
48 |
else { |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
49 |
this.showStartScreen(); |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
50 |
} |
| 830 | 51 |
|
52 |
// Add onclick event to both polemic and keywords buttons |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
53 |
|
| 831 | 54 |
this.selector.find(".Ldt-createAnnotation-btnblock button").click(function() { |
| 830 | 55 |
_this.addKeyword(IriSP.jQuery(this).text()); |
56 |
}); |
|
| 548 | 57 |
|
| 799 | 58 |
// js_mod is a custom event because there's no simple way to test for a js |
59 |
// change in a textfield. |
|
| 549 | 60 |
this.selector.find(".Ldt-createAnnotation-Description") |
| 799 | 61 |
.bind("propertychange keyup input paste js_mod", IriSP.wrap(this, this.handleTextChanges)); |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
62 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
63 |
/* the cinecast version of the player is supposed to pause when the user clicks on the button */ |
| 833 | 64 |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
65 |
/* the cinecast version expects the user to comment on a defined segment. |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
66 |
As the widget is always shown, we need a way to update it's content as |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
67 |
time passes. We do this like we did with the annotationsWidget : we schedule |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
68 |
a .code start function which will be called at the right time. |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
69 |
*/ |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
70 |
if (this.cinecast_version) { |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
71 |
var legal_ids; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
72 |
if (typeof(this._serializer.getChapitrage()) !== "undefined") |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
73 |
legal_id = this._serializer.getChapitrage(); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
74 |
else |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
75 |
legal_id = this._serializer.getNonTweetIds()[0]; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
76 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
77 |
var annotations = this._serializer._data.annotations; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
78 |
var i; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
79 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
80 |
for (i in annotations) { |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
81 |
var annotation = annotations[i]; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
82 |
if (typeof(annotation.meta) !== "undefined" && typeof(annotation.meta["id-ref"]) !== "undefined" |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
83 |
&& legal_id !== annotation.meta["id-ref"]) { |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
84 |
continue; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
85 |
} |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
86 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
87 |
code = {start: annotation.begin / 1000, end: annotation.end / 1000, |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
88 |
onStart: function(annotation) { return function() { |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
89 |
if (typeof(annotation.content) !== "undefined") |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
90 |
_this.selector.find(".Ldt-createAnnotation-Title").html(annotation.content.title); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
91 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
92 |
_this._currentAnnotation = annotation; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
93 |
var beginTime = IriSP.msToTime(annotation.begin); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
94 |
var endTime = IriSP.msToTime(annotation.end); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
95 |
var timeTemplate = IriSP.templToHTML("- ({{begin}} - {{ end }})", {begin: beginTime, end: endTime }); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
96 |
_this.selector.find(".Ldt-createAnnotation-TimeFrame").html(timeTemplate); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
97 |
} }(annotation) |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
98 |
}; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
99 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
100 |
this._Popcorn.code(code); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
101 |
} |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
102 |
} |
| 543 | 103 |
|
|
553
10d08f43c534
widget works now more or less like in samuel's crea.
hamidouk
parents:
549
diff
changeset
|
104 |
this.selector.find(".Ldt-createAnnotation-submitButton").click(IriSP.wrap(this, this.handleButtonClick)); |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
105 |
|
| 721 | 106 |
if (!this.cinecast_version) { |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
107 |
this._Popcorn.listen("IriSP.PlayerWidget.AnnotateButton.clicked", |
| 721 | 108 |
IriSP.wrap(this, this.handleAnnotateSignal)); |
109 |
|
|
110 |
// handle clicks on the cancel button too. |
|
111 |
this.selector.find(".Ldt-createAnnotation-Minimize").click(IriSP.wrap(this, |
|
112 |
function() { |
|
113 |
// we've got to simulate the pressing of the button because there's no |
|
114 |
// other way to minimize the widget and show the widgets that were hidden |
|
115 |
// same time |
|
116 |
this._Popcorn.trigger("IriSP.PlayerWidget.AnnotateButton.clicked"); |
|
117 |
} |
|
118 |
)); |
|
119 |
} |
|
| 543 | 120 |
}; |
121 |
||
| 830 | 122 |
/* Handles adding keywords and polemics */ |
123 |
IriSP.createAnnotationWidget.prototype.addKeyword = function(_keyword) { |
|
124 |
var _field = this.selector.find(".Ldt-createAnnotation-Description"), |
|
125 |
_rx = IriSP.regexpFromText(_keyword), |
|
126 |
_contents = _field.val(); |
|
127 |
_contents = ( _rx.test(_contents) |
|
128 |
? _contents.replace(_rx,"").replace(" "," ").trim() |
|
129 |
: _contents.trim() + " " + _keyword |
|
130 |
); |
|
131 |
_field.val(_contents); |
|
132 |
_field.trigger("js_mod"); |
|
133 |
} |
|
134 |
||
|
620
fe981f0aab71
automatically position and show the sliceWidget under the current chapter.
hamidouk
parents:
616
diff
changeset
|
135 |
/** handles clicks on the annotate button. Works only for the non-cinecast version */ |
| 543 | 136 |
IriSP.createAnnotationWidget.prototype.handleAnnotateSignal = function() { |
|
620
fe981f0aab71
automatically position and show the sliceWidget under the current chapter.
hamidouk
parents:
616
diff
changeset
|
137 |
|
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
138 |
if (this._hidden == false && this._state == 'startScreen') { |
| 543 | 139 |
this.selector.hide(); |
140 |
this._hidden = true; |
|
| 570 | 141 |
|
142 |
// free the arrow. |
|
143 |
this._Popcorn.trigger("IriSP.ArrowWidget.releaseArrow"); |
|
|
620
fe981f0aab71
automatically position and show the sliceWidget under the current chapter.
hamidouk
parents:
616
diff
changeset
|
144 |
this._Popcorn.trigger("IriSP.SliceWidget.hide"); |
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
145 |
this._Popcorn.trigger("IriSP.AnnotationsWidget.show"); |
|
620
fe981f0aab71
automatically position and show the sliceWidget under the current chapter.
hamidouk
parents:
616
diff
changeset
|
146 |
|
| 543 | 147 |
} else { |
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
148 |
this._Popcorn.trigger("IriSP.AnnotationsWidget.hide"); |
|
817
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
149 |
this.showStartScreen(); |
| 543 | 150 |
this.selector.show(); |
151 |
this._hidden = false; |
|
|
620
fe981f0aab71
automatically position and show the sliceWidget under the current chapter.
hamidouk
parents:
616
diff
changeset
|
152 |
var currentTime = this._Popcorn.currentTime(); |
| 563 | 153 |
|
154 |
// block the arrow. |
|
155 |
this._Popcorn.trigger("IriSP.ArrowWidget.blockArrow"); |
|
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
156 |
|
|
820
7968346b9689
Added compatibility with cinecast format (with get_aliased)
veltr
parents:
817
diff
changeset
|
157 |
var duration = this._serializer.getDuration(); |
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
158 |
|
|
620
fe981f0aab71
automatically position and show the sliceWidget under the current chapter.
hamidouk
parents:
616
diff
changeset
|
159 |
var currentChapter = this._serializer.currentChapitre(currentTime); |
|
779
52be94ec8e1c
fixed default slicerWidget position bug. check boundaries of created annotations.
hamidouk
parents:
778
diff
changeset
|
160 |
|
|
52be94ec8e1c
fixed default slicerWidget position bug. check boundaries of created annotations.
hamidouk
parents:
778
diff
changeset
|
161 |
if (IriSP.null_or_undefined(currentChapter)) { |
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
162 |
var left = this.selector.width() / 2; |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
163 |
var width = this.selector.width() / 10; |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
164 |
} else { |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
165 |
var left = (currentChapter.begin / duration) * this.selector.width(); |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
166 |
var width = (currentChapter.end / duration) * this.selector.width() - left; |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
167 |
} |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
168 |
|
|
779
52be94ec8e1c
fixed default slicerWidget position bug. check boundaries of created annotations.
hamidouk
parents:
778
diff
changeset
|
169 |
// slider position and length is kept in percents. |
|
52be94ec8e1c
fixed default slicerWidget position bug. check boundaries of created annotations.
hamidouk
parents:
778
diff
changeset
|
170 |
this.sliceLeft = (left / this.selector.width()) * 100; |
|
52be94ec8e1c
fixed default slicerWidget position bug. check boundaries of created annotations.
hamidouk
parents:
778
diff
changeset
|
171 |
this.sliceWidth = (width / this.selector.width()) * 100; |
|
52be94ec8e1c
fixed default slicerWidget position bug. check boundaries of created annotations.
hamidouk
parents:
778
diff
changeset
|
172 |
|
|
620
fe981f0aab71
automatically position and show the sliceWidget under the current chapter.
hamidouk
parents:
616
diff
changeset
|
173 |
this._Popcorn.trigger("IriSP.SliceWidget.position", [left, width]); |
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
174 |
this._Popcorn.listen("IriSP.SliceWidget.zoneChange", IriSP.wrap(this, this.handleSliderChanges)); |
|
620
fe981f0aab71
automatically position and show the sliceWidget under the current chapter.
hamidouk
parents:
616
diff
changeset
|
175 |
this._Popcorn.trigger("IriSP.SliceWidget.show"); |
| 722 | 176 |
|
| 776 | 177 |
if (!IriSP.null_or_undefined(currentChapter)) { |
178 |
this.selector.find(".Ldt-createAnnotation-Title").html(currentChapter.content.title); |
|
| 722 | 179 |
|
| 776 | 180 |
this._currentcurrentChapter = currentChapter; |
181 |
var beginTime = IriSP.msToTime(currentChapter.begin); |
|
182 |
var endTime = IriSP.msToTime(currentChapter.end); |
|
183 |
var timeTemplate = IriSP.templToHTML("- ({{begin}} - {{ end }})", {begin: beginTime, end: endTime }); |
|
184 |
this.selector.find(".Ldt-createAnnotation-TimeFrame").html(timeTemplate); |
|
185 |
} |
|
| 543 | 186 |
} |
| 549 | 187 |
}; |
188 |
||
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
189 |
|
| 549 | 190 |
/** watch for changes in the textfield and change the buttons accordingly */ |
191 |
IriSP.createAnnotationWidget.prototype.handleTextChanges = function(event) { |
|
192 |
var contents = this.selector.find(".Ldt-createAnnotation-Description").val(); |
|
| 833 | 193 |
if (this.cinecast_version && !this._Popcorn.media.paused) { |
194 |
this._Popcorn.pause(); |
|
195 |
} |
|
| 831 | 196 |
this.selector.find(".Ldt-createAnnotation-btnblock button").each(function() { |
| 830 | 197 |
var _rx = IriSP.regexpFromText(IriSP.jQuery(this).text()); |
198 |
if (_rx.test(contents)) { |
|
| 831 | 199 |
IriSP.jQuery(this).parent().addClass("Ldt-createAnnotation-active-button"); |
| 830 | 200 |
} else { |
| 831 | 201 |
IriSP.jQuery(this).parent().removeClass("Ldt-createAnnotation-active-button"); |
| 549 | 202 |
} |
| 830 | 203 |
}); |
| 831 | 204 |
|
|
553
10d08f43c534
widget works now more or less like in samuel's crea.
hamidouk
parents:
549
diff
changeset
|
205 |
}; |
|
10d08f43c534
widget works now more or less like in samuel's crea.
hamidouk
parents:
549
diff
changeset
|
206 |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
207 |
IriSP.createAnnotationWidget.prototype.showStartScreen = function() { |
| 831 | 208 |
this.selector.find(".Ldt-createAnnotation-screen").hide(); |
|
627
13b9f14bf49a
added a spinner displayed while submitting an annotation.
hamidouk
parents:
626
diff
changeset
|
209 |
this.selector.find(".Ldt-createAnnotation-startScreen").show(); |
|
817
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
210 |
|
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
211 |
var jqTextfield = this.selector.find(".Ldt-createAnnotation-Description"); // handle on the textfield. used for the closure |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
212 |
|
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
213 |
/* test if the browser supports the placeholder attribute */ |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
214 |
if (!IriSP.null_or_undefined(jqTextfield.get(0).placeholder)) { |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
215 |
jqTextfield.attr("placeholder", "Type your annotation here."); |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
216 |
} else { |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
217 |
jqTextfield.val("Type your annotation here."); |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
218 |
jqTextfield.one("click", IriSP.wrap(this, function() { jqTextfield.val(""); })); |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
219 |
} |
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
220 |
|
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
221 |
|
|
e9599ee285ab
implements the most asked for feature ever : placeholder text in the
hamidouk
parents:
814
diff
changeset
|
222 |
|
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
223 |
this._state = "startScreen"; |
|
627
13b9f14bf49a
added a spinner displayed while submitting an annotation.
hamidouk
parents:
626
diff
changeset
|
224 |
}; |
|
13b9f14bf49a
added a spinner displayed while submitting an annotation.
hamidouk
parents:
626
diff
changeset
|
225 |
|
|
13b9f14bf49a
added a spinner displayed while submitting an annotation.
hamidouk
parents:
626
diff
changeset
|
226 |
IriSP.createAnnotationWidget.prototype.showWaitScreen = function() { |
| 831 | 227 |
this.selector.find(".Ldt-createAnnotation-screen").hide(); |
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
228 |
this.selector.find(".Ldt-createAnnotation-waitScreen").show(); |
|
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
229 |
this._state = "waitScreen"; |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
230 |
}; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
231 |
|
| 769 | 232 |
IriSP.createAnnotationWidget.prototype.showErrorScreen = function() { |
| 831 | 233 |
this.selector.find(".Ldt-createAnnotation-screen").hide(); |
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
234 |
this.selector.find(".Ldt-createAnnotation-errorScreen").show(); |
|
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
235 |
this._state = "errorScreen"; |
| 832 | 236 |
var _this = this; |
237 |
window.setTimeout(function() { _this.showStartScreen(); }, 2000); |
|
| 769 | 238 |
}; |
239 |
||
240 |
/** update show the final screen with links to share the created annotation */ |
|
| 651 | 241 |
IriSP.createAnnotationWidget.prototype.showEndScreen = function(annotation) { |
| 831 | 242 |
this.selector.find(".Ldt-createAnnotation-screen").hide(); |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
243 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
244 |
if (this.cinecast_version) { |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
245 |
this.selector.find(".Ldt-createAnnotation-Title").parent().show(); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
246 |
} |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
247 |
|
| 836 | 248 |
var url = ( (typeof annotation.meta == "object" && typeof annotation.meta.url == "string" && annotation.meta.url.length) |
249 |
? annotation.meta.url |
|
250 |
: ( document.location.href + "#id=" + annotation.id ) ); |
|
| 651 | 251 |
var twStatus = IriSP.mkTweetUrl(url); |
252 |
var gpStatus = IriSP.mkGplusUrl(url); |
|
253 |
var fbStatus = IriSP.mkFbUrl(url); |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
254 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
255 |
this.selector.find(".Ldt-createAnnotation-endScreen-TweetLink").attr("href", twStatus); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
256 |
this.selector.find(".Ldt-createAnnotation-endScreen-FbLink").attr("href", fbStatus); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
257 |
this.selector.find(".Ldt-createAnnotation-endScreen-GplusLink").attr("href", gpStatus); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
258 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
259 |
this.selector.find(".Ldt-createAnnotation-endScreen").show(); |
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
260 |
this._state = "endScreen"; |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
261 |
}; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
262 |
|
|
553
10d08f43c534
widget works now more or less like in samuel's crea.
hamidouk
parents:
549
diff
changeset
|
263 |
/** handle clicks on "send annotation" button */ |
|
10d08f43c534
widget works now more or less like in samuel's crea.
hamidouk
parents:
549
diff
changeset
|
264 |
IriSP.createAnnotationWidget.prototype.handleButtonClick = function(event) { |
| 597 | 265 |
var _this = this; |
|
561
a10e7b6fdb08
display an error message when the user forget to enter text.
hamidouk
parents:
553
diff
changeset
|
266 |
var textfield = this.selector.find(".Ldt-createAnnotation-Description"); |
|
a10e7b6fdb08
display an error message when the user forget to enter text.
hamidouk
parents:
553
diff
changeset
|
267 |
var contents = textfield.val(); |
| 830 | 268 |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
269 |
if (contents === "") { |
| 570 | 270 |
if (this.selector.find(".Ldt-createAnnotation-errorMessage").length === 0) { |
271 |
this.selector.find(".Ldt-createAnnotation-Container") |
|
272 |
.after(IriSP.templToHTML(IriSP.createAnnotation_errorMessage_template)); |
|
| 571 | 273 |
textfield.css("background-color", "#d93c71"); |
| 769 | 274 |
} else { |
| 571 | 275 |
this.selector.find(".Ldt-createAnnotation-errorMessage").show(); |
276 |
} |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
277 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
278 |
textfield.one("js_mod propertychange keyup input paste", IriSP.wrap(this, function() { |
| 570 | 279 |
var contents = textfield.val(); |
| 611 | 280 |
|
| 570 | 281 |
if (contents !== "") { |
282 |
this.selector.find(".Ldt-createAnnotation-errorMessage").hide(); |
|
283 |
textfield.css("background-color", ""); |
|
284 |
} |
|
285 |
})); |
|
|
561
a10e7b6fdb08
display an error message when the user forget to enter text.
hamidouk
parents:
553
diff
changeset
|
286 |
} else { |
|
627
13b9f14bf49a
added a spinner displayed while submitting an annotation.
hamidouk
parents:
626
diff
changeset
|
287 |
this.showWaitScreen(); |
|
594
96af41097260
WIP - adapting the widget to the new segments conventions.
hamidouk
parents:
575
diff
changeset
|
288 |
|
| 678 | 289 |
this.sendLdtData(contents, function(annotation) { |
| 683 | 290 |
if (_this.cinecast_version) { |
291 |
if (_this._Popcorn.media.paused) |
|
292 |
_this._Popcorn.play(); |
|
293 |
} |
|
|
630
7c53857650b1
create a new contribution line in the json if it's not defined already.
hamidouk
parents:
627
diff
changeset
|
294 |
|
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
295 |
if (_this._state == "waitScreen") { |
|
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
296 |
_this.showEndScreen(annotation); |
|
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
297 |
if (_this.cinecast_version) { |
| 832 | 298 |
window.setTimeout(function() { _this.showStartScreen(); }, 5000); |
|
778
8329f476d852
clicking on the annotate button when the annotation creation widget is opened
hamidouk
parents:
776
diff
changeset
|
299 |
} |
| 683 | 300 |
} |
301 |
// hide the slicer widget |
|
302 |
if (!_this.cinecast_version) { |
|
303 |
_this._Popcorn.trigger("IriSP.SliceWidget.hide"); |
|
304 |
} |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
305 |
}); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
306 |
} |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
307 |
}; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
308 |
|
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
309 |
IriSP.createAnnotationWidget.prototype.handleSliderChanges = function(params) { |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
310 |
this.sliceLeft = params[0]; |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
311 |
this.sliceWidth = params[1]; |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
312 |
}; |
|
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
313 |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
314 |
IriSP.createAnnotationWidget.prototype.sendLdtData = function(contents, callback) { |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
315 |
var _this = this; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
316 |
var apiJson = {annotations : [{}], meta: {}}; |
| 836 | 317 |
var annotation = apiJson.annotations[0]; |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
318 |
|
| 836 | 319 |
annotation.media = this._serializer.currentMedia()["id"]; |
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
320 |
|
| 678 | 321 |
if (this.cinecast_version) { |
| 836 | 322 |
annotation.begin = Math.round(this._Popcorn.currentTime() * 1000); |
323 |
annotation.end = annotation.begin; |
|
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
324 |
} else { |
|
820
7968346b9689
Added compatibility with cinecast format (with get_aliased)
veltr
parents:
817
diff
changeset
|
325 |
var duration = this._serializer.getDuration(); |
| 836 | 326 |
annotation.begin = +((duration * (this.sliceLeft / 100)).toFixed(0)); |
327 |
annotation.end = +((duration * ((this.sliceWidth + this.sliceLeft) / 100)).toFixed(0)); |
|
|
623
d8f107938feb
WIP - create custom-sized segments in "normal" (non-cinecast) mode.
hamidouk
parents:
620
diff
changeset
|
328 |
} |
|
779
52be94ec8e1c
fixed default slicerWidget position bug. check boundaries of created annotations.
hamidouk
parents:
778
diff
changeset
|
329 |
|
|
52be94ec8e1c
fixed default slicerWidget position bug. check boundaries of created annotations.
hamidouk
parents:
778
diff
changeset
|
330 |
// boundary checks |
| 836 | 331 |
annotation.begin = Math.max(0, annotation.begin); |
332 |
annotation.end = Math.min(this._serializer.getDuration(), annotation.end); |
|
| 645 | 333 |
|
| 836 | 334 |
annotation.type = ( this.cinecast_version ? "cinecast:UserAnnotation" : ( this._serializer.getContributions() || "" )); |
335 |
if (typeof(annotation.type) === "undefined") |
|
336 |
annotation.type = ""; |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
337 |
|
| 836 | 338 |
annotation.type_title = "Contributions"; |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
339 |
annotation.content = {}; |
| 836 | 340 |
annotation.content.data = contents; |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
341 |
|
| 836 | 342 |
var meta = apiJson.meta; |
| 830 | 343 |
|
344 |
|
|
345 |
var _username = this.selector.find(".Ldt-createAnnotation-userName").val(); |
|
346 |
meta.creator = ( |
|
347 |
(_username && _username.length) |
|
348 |
? _username |
|
349 |
: ( |
|
350 |
(!IriSP.null_or_undefined(IriSP.user) && !IriSP.null_or_undefined(IriSP.user.name)) |
|
351 |
? IriSP.user.name |
|
352 |
: "Anonymous user" |
|
353 |
) |
|
354 |
); |
|
|
759
4dc3240f2c56
send the correct username if the user is loggedin on the platform.
hamidouk
parents:
722
diff
changeset
|
355 |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
356 |
meta.created = Date().toString(); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
357 |
|
| 830 | 358 |
// All #hashtags are added to tags |
| 836 | 359 |
annotation.tags = contents.match(/#[^#\s]+\b/gim) || []; |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
360 |
|
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
361 |
var jsonString = JSON.stringify(apiJson); |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
362 |
var project_id = this._serializer._data.meta.id; |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
363 |
|
|
797
8407313c144f
correct url for annotations + null data on serializer
ymh <ymh.work@gmail.com>
parents:
779
diff
changeset
|
364 |
//TODO: extract magic url |
|
814
9abad8fe5207
get the annotation creation api endpoint from the settings instead of
hamidouk
parents:
807
diff
changeset
|
365 |
var url = Mustache.to_html(this.api_endpoint_template, |
|
9abad8fe5207
get the annotation creation api endpoint from the settings instead of
hamidouk
parents:
807
diff
changeset
|
366 |
{id: project_id}); |
|
627
13b9f14bf49a
added a spinner displayed while submitting an annotation.
hamidouk
parents:
626
diff
changeset
|
367 |
|
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
368 |
IriSP.jQuery.ajax({ |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
369 |
url: url, |
| 830 | 370 |
type: this.api_method, |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
371 |
contentType: 'application/json', |
|
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
372 |
data: jsonString, |
| 626 | 373 |
//dataType: 'json', |
|
630
7c53857650b1
create a new contribution line in the json if it's not defined already.
hamidouk
parents:
627
diff
changeset
|
374 |
success: IriSP.wrap(this, function(json, textStatus, XMLHttpRequest) { |
|
7c53857650b1
create a new contribution line in the json if it's not defined already.
hamidouk
parents:
627
diff
changeset
|
375 |
/* add the annotation to the annotation and tell the world */ |
| 836 | 376 |
if (this.cinecast_version) { |
377 |
var annotation = json.annotations[0]; |
|
378 |
} else { |
|
|
630
7c53857650b1
create a new contribution line in the json if it's not defined already.
hamidouk
parents:
627
diff
changeset
|
379 |
/* if the media doesn't have a contributions line, we need to add one */ |
| 836 | 380 |
if (typeof(this._serializer.getContributions()) === "undefined") { |
381 |
/* set up a basic view */ |
|
382 |
var tmp_view = {"dc:contributor": "perso", "dc:creator": "perso", "dc:title": "Contributions", |
|
383 |
"id": json.annotations[0].type} |
|
384 |
|
|
385 |
|
|
386 |
IriSP.get_aliased(this._serializer._data, ["annotation_types", "annotation-types"]).push(tmp_view); |
|
387 |
} |
|
388 |
|
|
389 |
delete annotation.tags; |
|
390 |
annotation.content.description = annotation.content.data; |
|
391 |
annotation.content.title = ""; |
|
392 |
delete annotation.content.data; |
|
393 |
annotation.id = json.annotations[0].id; |
|
394 |
|
|
395 |
annotation.meta = meta; |
|
396 |
annotation.meta["id-ref"] = json.annotations[0]["type"]; |
|
|
630
7c53857650b1
create a new contribution line in the json if it's not defined already.
hamidouk
parents:
627
diff
changeset
|
397 |
} |
| 836 | 398 |
|
| 597 | 399 |
// everything is shared so there's no need to propagate the change |
400 |
_this._serializer._data.annotations.push(annotation); |
|
| 651 | 401 |
|
| 643 | 402 |
_this._Popcorn.trigger("IriSP.createAnnotationWidget.addedAnnotation", annotation); |
| 651 | 403 |
callback(annotation); |
|
630
7c53857650b1
create a new contribution line in the json if it's not defined already.
hamidouk
parents:
627
diff
changeset
|
404 |
}), |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
405 |
error: |
| 626 | 406 |
function(jqXHR, textStatus, errorThrown) { |
|
614
116de1c38a7d
lots of refactoring for this widget, as well as changes to support the cinecast
hamidouk
parents:
611
diff
changeset
|
407 |
console.log("an error occured while contacting " |
| 769 | 408 |
+ url + " and sending " + jsonString + textStatus ); |
409 |
_this.showErrorScreen(); } }); |
|
| 543 | 410 |
}; |