sufia 0.0.1 → 0.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (50) hide show
  1. data/Gemfile +1 -1
  2. data/app/assets/javascripts/sufia.js +6 -5
  3. data/app/assets/javascripts/terms_of_service.js +28 -0
  4. data/app/controllers/batch_edits_controller.rb +2 -2
  5. data/app/controllers/generic_files_controller.rb +2 -2
  6. data/app/models/datastreams/fits_datastream.rb +1 -1
  7. data/app/views/batch/edit.html.erb +6 -6
  8. data/app/views/batch_edits/edit.html.erb +10 -6
  9. data/app/views/catalog/_search_form.html.erb +2 -2
  10. data/app/views/dashboard/index.html.erb +7 -7
  11. data/app/views/generic_files/_asset_updated_flash.html.erb +1 -1
  12. data/app/views/generic_files/_descriptions.html.erb +1 -1
  13. data/app/views/generic_files/_versioning.html.erb +1 -1
  14. data/app/views/generic_files/edit.html.erb +10 -10
  15. data/app/views/generic_files/new.html.erb +3 -3
  16. data/app/views/generic_files/show.html.erb +1 -1
  17. data/app/views/users/edit.html.erb +3 -3
  18. data/config/locales/sufia.en.yml +10 -3
  19. data/features/step_definitions/scholarsphere.rb +3 -1
  20. data/features/support/paths.rb +1 -1
  21. data/lib/sufia/generic_file.rb +2 -3
  22. data/lib/sufia/generic_file/characterization.rb +1 -1
  23. data/lib/sufia/jobs/batch_update_job.rb +2 -2
  24. data/lib/sufia/version.rb +1 -1
  25. data/lib/tasks/resque.rake +27 -1
  26. data/spec/models/file_content_datastream_spec.rb +2 -2
  27. data/spec/models/generic_file_spec.rb +7 -4
  28. data/sufia.gemspec +3 -5
  29. data/vendor/assets/javascripts/fileupload.js +1 -3
  30. data/vendor/assets/javascripts/fileupload/application.js +0 -25
  31. data/vendor/assets/javascripts/fileupload/tmpl.js +86 -0
  32. data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.autocomplete.js +602 -0
  33. data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.core.js +356 -0
  34. data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.menu.js +610 -0
  35. data/vendor/assets/javascripts/jquery-ui-1.9.2/jquery.ui.widget.js +528 -0
  36. data/vendor/assets/javascripts/swfobject.js +4 -0
  37. metadata +15 -37
  38. data/app/assets/javascripts/generic_files.js +0 -17
  39. data/tasks/resque.rake +0 -27
  40. data/vendor/assets/javascripts/blacklight.js +0 -513
  41. data/vendor/assets/javascripts/bootstrap-collapse.js +0 -157
  42. data/vendor/assets/javascripts/bootstrap-popover.js +0 -98
  43. data/vendor/assets/javascripts/bootstrap-tooltip.js +0 -275
  44. data/vendor/assets/javascripts/fileupload/tmpl.min.js +0 -1
  45. data/vendor/assets/javascripts/jquery-1.7.2.min.js +0 -4
  46. data/vendor/assets/javascripts/jquery-1.8.2.js +0 -9440
  47. data/vendor/assets/javascripts/jquery-1.8.2.min.js +0 -2
  48. data/vendor/assets/javascripts/jquery-ui-1.8.16.custom.min.js +0 -791
  49. data/vendor/assets/javascripts/jquery-ui-1.8.23.custom.min.js +0 -125
  50. data/vendor/assets/javascripts/jquery_ujs.js +0 -377
@@ -1,157 +0,0 @@
1
- /* =============================================================
2
- * bootstrap-collapse.js v2.0.4
3
- * http://twitter.github.com/bootstrap/javascript.html#collapse
4
- * =============================================================
5
- * Copyright 2012 Twitter, Inc.
6
- *
7
- * Licensed under the Apache License, Version 2.0 (the "License");
8
- * you may not use this file except in compliance with the License.
9
- * You may obtain a copy of the License at
10
- *
11
- * http://www.apache.org/licenses/LICENSE-2.0
12
- *
13
- * Unless required by applicable law or agreed to in writing, software
14
- * distributed under the License is distributed on an "AS IS" BASIS,
15
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
- * See the License for the specific language governing permissions and
17
- * limitations under the License.
18
- * ============================================================ */
19
-
20
-
21
- !function ($) {
22
-
23
- "use strict"; // jshint ;_;
24
-
25
-
26
- /* COLLAPSE PUBLIC CLASS DEFINITION
27
- * ================================ */
28
-
29
- var Collapse = function (element, options) {
30
- this.$element = $(element)
31
- this.options = $.extend({}, $.fn.collapse.defaults, options)
32
-
33
- if (this.options.parent) {
34
- this.$parent = $(this.options.parent)
35
- }
36
-
37
- this.options.toggle && this.toggle()
38
- }
39
-
40
- Collapse.prototype = {
41
-
42
- constructor: Collapse
43
-
44
- , dimension: function () {
45
- var hasWidth = this.$element.hasClass('width')
46
- return hasWidth ? 'width' : 'height'
47
- }
48
-
49
- , show: function () {
50
- var dimension
51
- , scroll
52
- , actives
53
- , hasData
54
-
55
- if (this.transitioning) return
56
-
57
- dimension = this.dimension()
58
- scroll = $.camelCase(['scroll', dimension].join('-'))
59
- actives = this.$parent && this.$parent.find('> .accordion-group > .in')
60
-
61
- if (actives && actives.length) {
62
- hasData = actives.data('collapse')
63
- if (hasData && hasData.transitioning) return
64
- actives.collapse('hide')
65
- hasData || actives.data('collapse', null)
66
- }
67
-
68
- this.$element[dimension](0)
69
- this.transition('addClass', $.Event('show'), 'shown')
70
- this.$element[dimension](this.$element[0][scroll])
71
- }
72
-
73
- , hide: function () {
74
- var dimension
75
- if (this.transitioning) return
76
- dimension = this.dimension()
77
- this.reset(this.$element[dimension]())
78
- this.transition('removeClass', $.Event('hide'), 'hidden')
79
- this.$element[dimension](0)
80
- }
81
-
82
- , reset: function (size) {
83
- var dimension = this.dimension()
84
-
85
- this.$element
86
- .removeClass('collapse')
87
- [dimension](size || 'auto')
88
- [0].offsetWidth
89
-
90
- this.$element[size !== null ? 'addClass' : 'removeClass']('collapse')
91
-
92
- return this
93
- }
94
-
95
- , transition: function (method, startEvent, completeEvent) {
96
- var that = this
97
- , complete = function () {
98
- if (startEvent.type == 'show') that.reset()
99
- that.transitioning = 0
100
- that.$element.trigger(completeEvent)
101
- }
102
-
103
- this.$element.trigger(startEvent)
104
-
105
- if (startEvent.isDefaultPrevented()) return
106
-
107
- this.transitioning = 1
108
-
109
- this.$element[method]('in')
110
-
111
- $.support.transition && this.$element.hasClass('collapse') ?
112
- this.$element.one($.support.transition.end, complete) :
113
- complete()
114
- }
115
-
116
- , toggle: function () {
117
- this[this.$element.hasClass('in') ? 'hide' : 'show']()
118
- }
119
-
120
- }
121
-
122
-
123
- /* COLLAPSIBLE PLUGIN DEFINITION
124
- * ============================== */
125
-
126
- $.fn.collapse = function (option) {
127
- return this.each(function () {
128
- var $this = $(this)
129
- , data = $this.data('collapse')
130
- , options = typeof option == 'object' && option
131
- if (!data) $this.data('collapse', (data = new Collapse(this, options)))
132
- if (typeof option == 'string') data[option]()
133
- })
134
- }
135
-
136
- $.fn.collapse.defaults = {
137
- toggle: true
138
- }
139
-
140
- $.fn.collapse.Constructor = Collapse
141
-
142
-
143
- /* COLLAPSIBLE DATA-API
144
- * ==================== */
145
-
146
- $(function () {
147
- $('body').on('click.collapse.data-api', '[data-toggle=collapse]', function ( e ) {
148
- var $this = $(this), href
149
- , target = $this.attr('data-target')
150
- || e.preventDefault()
151
- || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') //strip for ie7
152
- , option = $(target).data('collapse') ? 'toggle' : $this.data()
153
- $(target).collapse(option)
154
- })
155
- })
156
-
157
- }(window.jQuery);
@@ -1,98 +0,0 @@
1
- /* ===========================================================
2
- * bootstrap-popover.js v2.0.4
3
- * http://twitter.github.com/bootstrap/javascript.html#popovers
4
- * ===========================================================
5
- * Copyright 2012 Twitter, Inc.
6
- *
7
- * Licensed under the Apache License, Version 2.0 (the "License");
8
- * you may not use this file except in compliance with the License.
9
- * You may obtain a copy of the License at
10
- *
11
- * http://www.apache.org/licenses/LICENSE-2.0
12
- *
13
- * Unless required by applicable law or agreed to in writing, software
14
- * distributed under the License is distributed on an "AS IS" BASIS,
15
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16
- * See the License for the specific language governing permissions and
17
- * limitations under the License.
18
- * =========================================================== */
19
-
20
-
21
- !function ($) {
22
-
23
- "use strict"; // jshint ;_;
24
-
25
-
26
- /* POPOVER PUBLIC CLASS DEFINITION
27
- * =============================== */
28
-
29
- var Popover = function ( element, options ) {
30
- this.init('popover', element, options)
31
- }
32
-
33
-
34
- /* NOTE: POPOVER EXTENDS BOOTSTRAP-TOOLTIP.js
35
- ========================================== */
36
-
37
- Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype, {
38
-
39
- constructor: Popover
40
-
41
- , setContent: function () {
42
- var $tip = this.tip()
43
- , title = this.getTitle()
44
- , content = this.getContent()
45
-
46
- $tip.find('.popover-title')[this.isHTML(title) ? 'html' : 'text'](title)
47
- $tip.find('.popover-content > *')[this.isHTML(content) ? 'html' : 'text'](content)
48
-
49
- $tip.removeClass('fade top bottom left right in')
50
- }
51
-
52
- , hasContent: function () {
53
- return this.getTitle() || this.getContent()
54
- }
55
-
56
- , getContent: function () {
57
- var content
58
- , $e = this.$element
59
- , o = this.options
60
-
61
- content = $e.attr('data-content')
62
- || (typeof o.content == 'function' ? o.content.call($e[0]) : o.content)
63
-
64
- return content
65
- }
66
-
67
- , tip: function () {
68
- if (!this.$tip) {
69
- this.$tip = $(this.options.template)
70
- }
71
- return this.$tip
72
- }
73
-
74
- })
75
-
76
-
77
- /* POPOVER PLUGIN DEFINITION
78
- * ======================= */
79
-
80
- $.fn.popover = function (option) {
81
- return this.each(function () {
82
- var $this = $(this)
83
- , data = $this.data('popover')
84
- , options = typeof option == 'object' && option
85
- if (!data) $this.data('popover', (data = new Popover(this, options)))
86
- if (typeof option == 'string') data[option]()
87
- })
88
- }
89
-
90
- $.fn.popover.Constructor = Popover
91
-
92
- $.fn.popover.defaults = $.extend({} , $.fn.tooltip.defaults, {
93
- placement: 'right'
94
- , content: ''
95
- , template: '<div class="popover"><div class="arrow"></div><div class="popover-inner"><h3 class="popover-title"></h3><div class="popover-content"><p></p></div></div></div>'
96
- })
97
-
98
- }(window.jQuery);
@@ -1,275 +0,0 @@
1
- /* ===========================================================
2
- * bootstrap-tooltip.js v2.0.4
3
- * http://twitter.github.com/bootstrap/javascript.html#tooltips
4
- * Inspired by the original jQuery.tipsy by Jason Frame
5
- * ===========================================================
6
- * Copyright 2012 Twitter, Inc.
7
- *
8
- * Licensed under the Apache License, Version 2.0 (the "License");
9
- * you may not use this file except in compliance with the License.
10
- * You may obtain a copy of the License at
11
- *
12
- * http://www.apache.org/licenses/LICENSE-2.0
13
- *
14
- * Unless required by applicable law or agreed to in writing, software
15
- * distributed under the License is distributed on an "AS IS" BASIS,
16
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
- * See the License for the specific language governing permissions and
18
- * limitations under the License.
19
- * ========================================================== */
20
-
21
-
22
- !function ($) {
23
-
24
- "use strict"; // jshint ;_;
25
-
26
-
27
- /* TOOLTIP PUBLIC CLASS DEFINITION
28
- * =============================== */
29
-
30
- var Tooltip = function (element, options) {
31
- this.init('tooltip', element, options)
32
- }
33
-
34
- Tooltip.prototype = {
35
-
36
- constructor: Tooltip
37
-
38
- , init: function (type, element, options) {
39
- var eventIn
40
- , eventOut
41
-
42
- this.type = type
43
- this.$element = $(element)
44
- this.options = this.getOptions(options)
45
- this.enabled = true
46
-
47
- if (this.options.trigger != 'manual') {
48
- eventIn = this.options.trigger == 'hover' ? 'mouseenter' : 'focus'
49
- eventOut = this.options.trigger == 'hover' ? 'mouseleave' : 'blur'
50
- this.$element.on(eventIn, this.options.selector, $.proxy(this.enter, this))
51
- this.$element.on(eventOut, this.options.selector, $.proxy(this.leave, this))
52
- }
53
-
54
- this.options.selector ?
55
- (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
56
- this.fixTitle()
57
- }
58
-
59
- , getOptions: function (options) {
60
- options = $.extend({}, $.fn[this.type].defaults, options, this.$element.data())
61
-
62
- if (options.delay && typeof options.delay == 'number') {
63
- options.delay = {
64
- show: options.delay
65
- , hide: options.delay
66
- }
67
- }
68
-
69
- return options
70
- }
71
-
72
- , enter: function (e) {
73
- var self = $(e.currentTarget)[this.type](this._options).data(this.type)
74
-
75
- if (!self.options.delay || !self.options.delay.show) return self.show()
76
-
77
- clearTimeout(this.timeout)
78
- self.hoverState = 'in'
79
- this.timeout = setTimeout(function() {
80
- if (self.hoverState == 'in') self.show()
81
- }, self.options.delay.show)
82
- }
83
-
84
- , leave: function (e) {
85
- var self = $(e.currentTarget)[this.type](this._options).data(this.type)
86
-
87
- if (this.timeout) clearTimeout(this.timeout)
88
- if (!self.options.delay || !self.options.delay.hide) return self.hide()
89
-
90
- self.hoverState = 'out'
91
- this.timeout = setTimeout(function() {
92
- if (self.hoverState == 'out') self.hide()
93
- }, self.options.delay.hide)
94
- }
95
-
96
- , show: function () {
97
- var $tip
98
- , inside
99
- , pos
100
- , actualWidth
101
- , actualHeight
102
- , placement
103
- , tp
104
-
105
- if (this.hasContent() && this.enabled) {
106
- $tip = this.tip()
107
- this.setContent()
108
-
109
- if (this.options.animation) {
110
- $tip.addClass('fade')
111
- }
112
-
113
- placement = typeof this.options.placement == 'function' ?
114
- this.options.placement.call(this, $tip[0], this.$element[0]) :
115
- this.options.placement
116
-
117
- inside = /in/.test(placement)
118
-
119
- $tip
120
- .remove()
121
- .css({ top: 0, left: 0, display: 'block' })
122
- .appendTo(inside ? this.$element : document.body)
123
-
124
- pos = this.getPosition(inside)
125
-
126
- actualWidth = $tip[0].offsetWidth
127
- actualHeight = $tip[0].offsetHeight
128
-
129
- switch (inside ? placement.split(' ')[1] : placement) {
130
- case 'bottom':
131
- tp = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2}
132
- break
133
- case 'top':
134
- tp = {top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2}
135
- break
136
- case 'left':
137
- tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth}
138
- break
139
- case 'right':
140
- tp = {top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width}
141
- break
142
- }
143
-
144
- $tip
145
- .css(tp)
146
- .addClass(placement)
147
- .addClass('in')
148
- }
149
- }
150
-
151
- , isHTML: function(text) {
152
- // html string detection logic adapted from jQuery
153
- return typeof text != 'string'
154
- || ( text.charAt(0) === "<"
155
- && text.charAt( text.length - 1 ) === ">"
156
- && text.length >= 3
157
- ) || /^(?:[^<]*<[\w\W]+>[^>]*$)/.exec(text)
158
- }
159
-
160
- , setContent: function () {
161
- var $tip = this.tip()
162
- , title = this.getTitle()
163
-
164
- $tip.find('.tooltip-inner')[this.isHTML(title) ? 'html' : 'text'](title)
165
- $tip.removeClass('fade in top bottom left right')
166
- }
167
-
168
- , hide: function () {
169
- var that = this
170
- , $tip = this.tip()
171
-
172
- $tip.removeClass('in')
173
-
174
- function removeWithAnimation() {
175
- var timeout = setTimeout(function () {
176
- $tip.off($.support.transition.end).remove()
177
- }, 500)
178
-
179
- $tip.one($.support.transition.end, function () {
180
- clearTimeout(timeout)
181
- $tip.remove()
182
- })
183
- }
184
-
185
- $.support.transition && this.$tip.hasClass('fade') ?
186
- removeWithAnimation() :
187
- $tip.remove()
188
- }
189
-
190
- , fixTitle: function () {
191
- var $e = this.$element
192
- if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') {
193
- $e.attr('data-original-title', $e.attr('title') || '').removeAttr('title')
194
- }
195
- }
196
-
197
- , hasContent: function () {
198
- return this.getTitle()
199
- }
200
-
201
- , getPosition: function (inside) {
202
- return $.extend({}, (inside ? {top: 0, left: 0} : this.$element.offset()), {
203
- width: this.$element[0].offsetWidth
204
- , height: this.$element[0].offsetHeight
205
- })
206
- }
207
-
208
- , getTitle: function () {
209
- var title
210
- , $e = this.$element
211
- , o = this.options
212
-
213
- title = $e.attr('data-original-title')
214
- || (typeof o.title == 'function' ? o.title.call($e[0]) : o.title)
215
-
216
- return title
217
- }
218
-
219
- , tip: function () {
220
- return this.$tip = this.$tip || $(this.options.template)
221
- }
222
-
223
- , validate: function () {
224
- if (!this.$element[0].parentNode) {
225
- this.hide()
226
- this.$element = null
227
- this.options = null
228
- }
229
- }
230
-
231
- , enable: function () {
232
- this.enabled = true
233
- }
234
-
235
- , disable: function () {
236
- this.enabled = false
237
- }
238
-
239
- , toggleEnabled: function () {
240
- this.enabled = !this.enabled
241
- }
242
-
243
- , toggle: function () {
244
- this[this.tip().hasClass('in') ? 'hide' : 'show']()
245
- }
246
-
247
- }
248
-
249
-
250
- /* TOOLTIP PLUGIN DEFINITION
251
- * ========================= */
252
-
253
- $.fn.tooltip = function ( option ) {
254
- return this.each(function () {
255
- var $this = $(this)
256
- , data = $this.data('tooltip')
257
- , options = typeof option == 'object' && option
258
- if (!data) $this.data('tooltip', (data = new Tooltip(this, options)))
259
- if (typeof option == 'string') data[option]()
260
- })
261
- }
262
-
263
- $.fn.tooltip.Constructor = Tooltip
264
-
265
- $.fn.tooltip.defaults = {
266
- animation: true
267
- , placement: 'top'
268
- , selector: false
269
- , template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>'
270
- , trigger: 'hover'
271
- , title: ''
272
- , delay: 0
273
- }
274
-
275
- }(window.jQuery);