kuji-mercury-rails 0.3.2
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +25 -0
- data/POST_INSTALL +15 -0
- data/app/controllers/mercury/images_controller.rb +19 -0
- data/app/controllers/mercury_controller.rb +34 -0
- data/app/models/mercury/image.rb +16 -0
- data/app/views/layouts/mercury.html.erb +33 -0
- data/app/views/mercury/lightviews/about.html +11 -0
- data/app/views/mercury/modals/character.html +255 -0
- data/app/views/mercury/modals/htmleditor.html +13 -0
- data/app/views/mercury/modals/link.html +75 -0
- data/app/views/mercury/modals/media.html +82 -0
- data/app/views/mercury/modals/table.html +84 -0
- data/app/views/mercury/palettes/backcolor.html +73 -0
- data/app/views/mercury/palettes/forecolor.html +73 -0
- data/app/views/mercury/panels/history.html +3 -0
- data/app/views/mercury/panels/notes.html +3 -0
- data/app/views/mercury/panels/snippets.html +12 -0
- data/app/views/mercury/selects/formatblock.html +11 -0
- data/app/views/mercury/selects/style.html +5 -0
- data/app/views/mercury/snippets/example/options.html.erb +34 -0
- data/app/views/mercury/snippets/example/preview.html.erb +1 -0
- data/config/engine.rb +41 -0
- data/db/migrate/20110526035601_create_mercury_images.rb +11 -0
- data/features/loading/loading.feature +22 -0
- data/features/loading/navigating.feature +77 -0
- data/features/loading/user_interface.feature +67 -0
- data/features/regions/editable/advanced_editing.feature +0 -0
- data/features/regions/editable/basic_editing.feature +195 -0
- data/features/regions/editable/inserting_links.feature +98 -0
- data/features/regions/editable/inserting_media.feature +110 -0
- data/features/regions/editable/inserting_snippets.feature +102 -0
- data/features/regions/editable/inserting_special_characters.feature +24 -0
- data/features/regions/editable/inserting_tables.feature +109 -0
- data/features/regions/editable/pasting.feature +0 -0
- data/features/regions/editable/uploading_images.feature +0 -0
- data/features/regions/image/uploading_images.feature +0 -0
- data/features/regions/markupable/advanced_editing.feature +0 -0
- data/features/regions/markupable/basic_editing.feature +0 -0
- data/features/regions/markupable/inserting_links.feature +0 -0
- data/features/regions/markupable/inserting_media.feature +0 -0
- data/features/regions/markupable/inserting_snippets.feature +0 -0
- data/features/regions/markupable/inserting_special_characters.feature +0 -0
- data/features/regions/markupable/inserting_tables.feature +0 -0
- data/features/regions/markupable/uploading_images.feature +0 -0
- data/features/regions/simple/basic_editing.feature +5 -0
- data/features/regions/snippetable/advanced_editing.feature +0 -0
- data/features/regions/snippetable/basic_editing.feature +0 -0
- data/features/regions/snippetable/inserting_snippets.feature +0 -0
- data/features/saving/saving.feature +33 -0
- data/features/step_definitions/debug_steps.rb +14 -0
- data/features/step_definitions/mercury_steps.rb +438 -0
- data/features/step_definitions/web_steps.rb +211 -0
- data/features/support/env.rb +46 -0
- data/features/support/mercury_contents.rb +25 -0
- data/features/support/mercury_selectors.rb +148 -0
- data/features/support/paths.rb +38 -0
- data/features/support/selectors.rb +44 -0
- data/lib/generators/mercury/install/install_generator.rb +49 -0
- data/lib/generators/mercury/install/templates/mongoid_paperclip_image.rb +17 -0
- data/lib/mercury-rails.rb +3 -0
- data/lib/mercury/authentication.rb +8 -0
- data/spec/javascripts/mercury/dialog_spec.js.coffee +281 -0
- data/spec/javascripts/mercury/dialogs/backcolor_spec.js.coffee +37 -0
- data/spec/javascripts/mercury/dialogs/forecolor_spec.js.coffee +37 -0
- data/spec/javascripts/mercury/dialogs/formatblock_spec.js.coffee +25 -0
- data/spec/javascripts/mercury/dialogs/snippetpanel_spec.js.coffee +30 -0
- data/spec/javascripts/mercury/dialogs/style_spec.js.coffee +25 -0
- data/spec/javascripts/mercury/history_buffer_spec.js.coffee +76 -0
- data/spec/javascripts/mercury/lightview_spec.js.coffee +497 -0
- data/spec/javascripts/mercury/mercury_spec.js.coffee +132 -0
- data/spec/javascripts/mercury/modal_spec.js.coffee +504 -0
- data/spec/javascripts/mercury/modals/htmleditor_spec.js.coffee +30 -0
- data/spec/javascripts/mercury/modals/insertcharacter_spec.js.coffee +29 -0
- data/spec/javascripts/mercury/modals/insertlink_spec.js.coffee +220 -0
- data/spec/javascripts/mercury/modals/insertmedia_spec.js.coffee +167 -0
- data/spec/javascripts/mercury/modals/insertsnippet_spec.js.coffee +52 -0
- data/spec/javascripts/mercury/modals/inserttable_spec.js.coffee +160 -0
- data/spec/javascripts/mercury/native_extensions_spec.js.coffee +60 -0
- data/spec/javascripts/mercury/page_editor_spec.js.coffee +757 -0
- data/spec/javascripts/mercury/palette_spec.js.coffee +49 -0
- data/spec/javascripts/mercury/panel_spec.js.coffee +183 -0
- data/spec/javascripts/mercury/region_spec.js.coffee +298 -0
- data/spec/javascripts/mercury/regions/editable_spec.js.coffee +561 -0
- data/spec/javascripts/mercury/regions/image_spec.js.coffee +34 -0
- data/spec/javascripts/mercury/regions/markupable_spec.js.coffee +367 -0
- data/spec/javascripts/mercury/regions/simple_spec.js.coffee +33 -0
- data/spec/javascripts/mercury/regions/snippetable_spec.js.coffee +370 -0
- data/spec/javascripts/mercury/select_spec.js.coffee +49 -0
- data/spec/javascripts/mercury/snippet_spec.js.coffee +253 -0
- data/spec/javascripts/mercury/snippet_toolbar_spec.js.coffee +184 -0
- data/spec/javascripts/mercury/statusbar_spec.js.coffee +150 -0
- data/spec/javascripts/mercury/table_editor_spec.js.coffee +194 -0
- data/spec/javascripts/mercury/toolbar.button_group_spec.js.coffee +90 -0
- data/spec/javascripts/mercury/toolbar.button_spec.js.coffee +360 -0
- data/spec/javascripts/mercury/toolbar.expander_spec.js.coffee +118 -0
- data/spec/javascripts/mercury/toolbar_spec.js.coffee +222 -0
- data/spec/javascripts/mercury/tooltip_spec.js.coffee +186 -0
- data/spec/javascripts/mercury/uploader_spec.js.coffee +530 -0
- data/spec/javascripts/spec_helper.js +513 -0
- data/spec/javascripts/templates/mercury/dialog.html +2 -0
- data/spec/javascripts/templates/mercury/dialogs/backcolor.html +5 -0
- data/spec/javascripts/templates/mercury/dialogs/forecolor.html +5 -0
- data/spec/javascripts/templates/mercury/dialogs/formatblock.html +3 -0
- data/spec/javascripts/templates/mercury/dialogs/snippetpanel.html +16 -0
- data/spec/javascripts/templates/mercury/dialogs/style.html +3 -0
- data/spec/javascripts/templates/mercury/lightview.html +13 -0
- data/spec/javascripts/templates/mercury/modal.html +13 -0
- data/spec/javascripts/templates/mercury/modals/htmleditor.html +5 -0
- data/spec/javascripts/templates/mercury/modals/insertcharacter.html +5 -0
- data/spec/javascripts/templates/mercury/modals/insertlink.html +30 -0
- data/spec/javascripts/templates/mercury/modals/insertmedia.html +35 -0
- data/spec/javascripts/templates/mercury/modals/insertsnippet.html +6 -0
- data/spec/javascripts/templates/mercury/modals/inserttable.html +27 -0
- data/spec/javascripts/templates/mercury/page_editor.html +35 -0
- data/spec/javascripts/templates/mercury/palette.html +16 -0
- data/spec/javascripts/templates/mercury/panel.html +16 -0
- data/spec/javascripts/templates/mercury/region.html +2 -0
- data/spec/javascripts/templates/mercury/regions/editable.html +3 -0
- data/spec/javascripts/templates/mercury/regions/image.html +1 -0
- data/spec/javascripts/templates/mercury/regions/simple.html +3 -0
- data/spec/javascripts/templates/mercury/regions/snippetable.html +4 -0
- data/spec/javascripts/templates/mercury/select.html +16 -0
- data/spec/javascripts/templates/mercury/snippet.html +1 -0
- data/spec/javascripts/templates/mercury/snippet_toolbar.html +16 -0
- data/spec/javascripts/templates/mercury/statusbar.html +8 -0
- data/spec/javascripts/templates/mercury/table_editor.html +65 -0
- data/spec/javascripts/templates/mercury/toolbar.button.html +64 -0
- data/spec/javascripts/templates/mercury/toolbar.button_group.html +9 -0
- data/spec/javascripts/templates/mercury/toolbar.expander.html +18 -0
- data/spec/javascripts/templates/mercury/toolbar.html +11 -0
- data/spec/javascripts/templates/mercury/tooltip.html +12 -0
- data/spec/javascripts/templates/mercury/uploader.html +11 -0
- data/vendor/assets/images/mercury/button.png +0 -0
- data/vendor/assets/images/mercury/close.png +0 -0
- data/vendor/assets/images/mercury/default-snippet.png +0 -0
- data/vendor/assets/images/mercury/loading-dark.gif +0 -0
- data/vendor/assets/images/mercury/loading-light.gif +0 -0
- data/vendor/assets/images/mercury/missing-image.png +0 -0
- data/vendor/assets/images/mercury/search-icon.png +0 -0
- data/vendor/assets/images/mercury/temp-logo.png +0 -0
- data/vendor/assets/images/mercury/toolbar/editable/buttons.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/_expander.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/_pressed.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/historypanel.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/insertcharacter.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/insertlink.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/insertmedia.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/inserttable.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/inspectorpanel.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/notespanel.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/preview.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/redo.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/save.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/snippetpanel.png +0 -0
- data/vendor/assets/images/mercury/toolbar/primary/undo.png +0 -0
- data/vendor/assets/images/mercury/toolbar/snippetable/buttons.png +0 -0
- data/vendor/assets/javascripts/mercury.js +479 -0
- data/vendor/assets/javascripts/mercury/dependencies/jquery-1.7.js +9300 -0
- data/vendor/assets/javascripts/mercury/dependencies/jquery-ui-1.8.13.custom.js +1328 -0
- data/vendor/assets/javascripts/mercury/dependencies/jquery.additions.js +206 -0
- data/vendor/assets/javascripts/mercury/dependencies/jquery.htmlClean.js +527 -0
- data/vendor/assets/javascripts/mercury/dependencies/liquidmetal.js +88 -0
- data/vendor/assets/javascripts/mercury/dependencies/showdown.js +1340 -0
- data/vendor/assets/javascripts/mercury/dialog.js.coffee +159 -0
- data/vendor/assets/javascripts/mercury/dialogs/backcolor.js.coffee +6 -0
- data/vendor/assets/javascripts/mercury/dialogs/forecolor.js.coffee +6 -0
- data/vendor/assets/javascripts/mercury/dialogs/formatblock.js.coffee +4 -0
- data/vendor/assets/javascripts/mercury/dialogs/snippetpanel.js.coffee +10 -0
- data/vendor/assets/javascripts/mercury/dialogs/style.js.coffee +4 -0
- data/vendor/assets/javascripts/mercury/finalize.js.coffee +3 -0
- data/vendor/assets/javascripts/mercury/history_buffer.js.coffee +30 -0
- data/vendor/assets/javascripts/mercury/lightview.js.coffee +205 -0
- data/vendor/assets/javascripts/mercury/locales/ar.locale.js.coffee +207 -0
- data/vendor/assets/javascripts/mercury/locales/da.locale.js.coffee +211 -0
- data/vendor/assets/javascripts/mercury/locales/de.locale.js.coffee +206 -0
- data/vendor/assets/javascripts/mercury/locales/es.locale.js.coffee +211 -0
- data/vendor/assets/javascripts/mercury/locales/example.local.js.coffee +211 -0
- data/vendor/assets/javascripts/mercury/locales/fr.locale.js.coffee +211 -0
- data/vendor/assets/javascripts/mercury/locales/it.locale.js.coffee +208 -0
- data/vendor/assets/javascripts/mercury/locales/ko.local.js.coffee +206 -0
- data/vendor/assets/javascripts/mercury/locales/nl.locale.js.coffee +206 -0
- data/vendor/assets/javascripts/mercury/locales/pt.locale.js.coffee +211 -0
- data/vendor/assets/javascripts/mercury/locales/sv.local.js.coffee +209 -0
- data/vendor/assets/javascripts/mercury/locales/swedish_chef.locale.js.coffee +213 -0
- data/vendor/assets/javascripts/mercury/mercury.js.coffee +109 -0
- data/vendor/assets/javascripts/mercury/modal.js.coffee +198 -0
- data/vendor/assets/javascripts/mercury/modals/htmleditor.js.coffee +11 -0
- data/vendor/assets/javascripts/mercury/modals/insertcharacter.js.coffee +4 -0
- data/vendor/assets/javascripts/mercury/modals/insertlink.js.coffee +92 -0
- data/vendor/assets/javascripts/mercury/modals/insertmedia.js.coffee +81 -0
- data/vendor/assets/javascripts/mercury/modals/insertsnippet.js.coffee +12 -0
- data/vendor/assets/javascripts/mercury/modals/inserttable.js.coffee +54 -0
- data/vendor/assets/javascripts/mercury/native_extensions.js.coffee +55 -0
- data/vendor/assets/javascripts/mercury/page_editor.js.coffee +225 -0
- data/vendor/assets/javascripts/mercury/palette.js.coffee +29 -0
- data/vendor/assets/javascripts/mercury/panel.js.coffee +115 -0
- data/vendor/assets/javascripts/mercury/plugins/save_as_xml/mercury/page_editor.js.coffee +28 -0
- data/vendor/assets/javascripts/mercury/plugins/save_as_xml/plugin.js +9 -0
- data/vendor/assets/javascripts/mercury/region.js.coffee +107 -0
- data/vendor/assets/javascripts/mercury/regions/editable.js.coffee +600 -0
- data/vendor/assets/javascripts/mercury/regions/image.js.coffee +114 -0
- data/vendor/assets/javascripts/mercury/regions/markupable.js.coffee +398 -0
- data/vendor/assets/javascripts/mercury/regions/simple.js.coffee +325 -0
- data/vendor/assets/javascripts/mercury/regions/snippetable.js.coffee +124 -0
- data/vendor/assets/javascripts/mercury/select.js.coffee +44 -0
- data/vendor/assets/javascripts/mercury/snippet.js.coffee +106 -0
- data/vendor/assets/javascripts/mercury/snippet_toolbar.js.coffee +72 -0
- data/vendor/assets/javascripts/mercury/statusbar.js.coffee +51 -0
- data/vendor/assets/javascripts/mercury/support/history.js +1 -0
- data/vendor/assets/javascripts/mercury/table_editor.js.coffee +265 -0
- data/vendor/assets/javascripts/mercury/toolbar.button.js.coffee +173 -0
- data/vendor/assets/javascripts/mercury/toolbar.button_group.js.coffee +42 -0
- data/vendor/assets/javascripts/mercury/toolbar.expander.js.coffee +56 -0
- data/vendor/assets/javascripts/mercury/toolbar.js.coffee +86 -0
- data/vendor/assets/javascripts/mercury/tooltip.js.coffee +74 -0
- data/vendor/assets/javascripts/mercury/uploader.js.coffee +244 -0
- data/vendor/assets/javascripts/mercury_loader.js +193 -0
- data/vendor/assets/javascripts/mercury_overrides.js +6 -0
- data/vendor/assets/stylesheets/mercury.css +28 -0
- data/vendor/assets/stylesheets/mercury/all_images.css.erb +89 -0
- data/vendor/assets/stylesheets/mercury/dialog.css +212 -0
- data/vendor/assets/stylesheets/mercury/form.css +118 -0
- data/vendor/assets/stylesheets/mercury/lightview.css +151 -0
- data/vendor/assets/stylesheets/mercury/mercury.css +37 -0
- data/vendor/assets/stylesheets/mercury/modal.css +183 -0
- data/vendor/assets/stylesheets/mercury/statusbar.css +32 -0
- data/vendor/assets/stylesheets/mercury/toolbar.css +304 -0
- data/vendor/assets/stylesheets/mercury/tooltip.css +26 -0
- data/vendor/assets/stylesheets/mercury/uploader.css +111 -0
- data/vendor/assets/stylesheets/mercury_overrides.css +17 -0
- metadata +572 -0
@@ -0,0 +1,198 @@
|
|
1
|
+
@Mercury.modal = (url, options = {}) ->
|
2
|
+
Mercury.modal.show(url, options)
|
3
|
+
return Mercury.modal
|
4
|
+
|
5
|
+
jQuery.extend Mercury.modal,
|
6
|
+
minWidth: 400
|
7
|
+
|
8
|
+
show: (@url, @options = {}) ->
|
9
|
+
Mercury.trigger('focus:window')
|
10
|
+
@initialize()
|
11
|
+
if @visible then @update() else @appear()
|
12
|
+
if @options.content
|
13
|
+
setTimeout 500, => @loadContent(@options.content)
|
14
|
+
|
15
|
+
|
16
|
+
initialize: ->
|
17
|
+
return if @initialized
|
18
|
+
@build()
|
19
|
+
@bindEvents()
|
20
|
+
@initialized = true
|
21
|
+
|
22
|
+
|
23
|
+
build: ->
|
24
|
+
@element = jQuery('<div>', {class: 'mercury-modal loading'})
|
25
|
+
@element.html('<h1 class="mercury-modal-title"><span></span><a>×</a></h1>')
|
26
|
+
@element.append('<div class="mercury-modal-content-container"><div class="mercury-modal-content"></div></div>')
|
27
|
+
|
28
|
+
@overlay = jQuery('<div>', {class: 'mercury-modal-overlay'})
|
29
|
+
|
30
|
+
@titleElement = @element.find('.mercury-modal-title')
|
31
|
+
@contentContainerElement = @element.find('.mercury-modal-content-container')
|
32
|
+
|
33
|
+
@contentElement = @element.find('.mercury-modal-content')
|
34
|
+
|
35
|
+
@element.appendTo(jQuery(@options.appendTo).get(0) ? 'body')
|
36
|
+
@overlay.appendTo(jQuery(@options.appendTo).get(0) ? 'body')
|
37
|
+
|
38
|
+
|
39
|
+
bindEvents: ->
|
40
|
+
Mercury.on 'refresh', => @resize(true)
|
41
|
+
Mercury.on 'resize', => @position()
|
42
|
+
|
43
|
+
@overlay.on 'click', =>
|
44
|
+
@hide() if @options.allowHideUsingOverlay
|
45
|
+
|
46
|
+
@titleElement.find('a').on 'click', =>
|
47
|
+
@hide()
|
48
|
+
|
49
|
+
@element.on 'ajax:beforeSend', (event, xhr, options) =>
|
50
|
+
options.success = (content) =>
|
51
|
+
@loadContent(content)
|
52
|
+
|
53
|
+
jQuery(document).on 'keydown', (event) =>
|
54
|
+
@hide() if event.keyCode == 27 && @visible
|
55
|
+
|
56
|
+
|
57
|
+
appear: ->
|
58
|
+
@showing = true
|
59
|
+
@position()
|
60
|
+
|
61
|
+
@overlay.show()
|
62
|
+
@overlay.animate {opacity: 1}, 200, 'easeInOutSine', =>
|
63
|
+
@element.css({top: -@element.height()})
|
64
|
+
@setTitle()
|
65
|
+
@element.show()
|
66
|
+
@element.animate {top: 0}, 200, 'easeInOutSine', =>
|
67
|
+
@visible = true
|
68
|
+
@showing = false
|
69
|
+
@load()
|
70
|
+
|
71
|
+
|
72
|
+
resize: (keepVisible) ->
|
73
|
+
visibility = if keepVisible then 'visible' else 'hidden'
|
74
|
+
|
75
|
+
titleHeight = @titleElement.outerHeight()
|
76
|
+
|
77
|
+
width = @contentElement.outerWidth()
|
78
|
+
|
79
|
+
@contentPane.css({height: 'auto'}) if @contentPane
|
80
|
+
@contentElement.css({height: 'auto', visibility: visibility, display: 'block'})
|
81
|
+
|
82
|
+
height = @contentElement.outerHeight() + titleHeight
|
83
|
+
|
84
|
+
width = @minWidth if width < @minWidth
|
85
|
+
height = Mercury.displayRect.fullHeight - 20 if height > Mercury.displayRect.fullHeight - 20 || @options.fullHeight
|
86
|
+
|
87
|
+
@element.stop().animate {left: (Mercury.displayRect.width - width) / 2, width: width, height: height}, 200, 'easeInOutSine', =>
|
88
|
+
@contentElement.css({visibility: 'visible', display: 'block'})
|
89
|
+
if @contentPane.length
|
90
|
+
@contentElement.css({height: height - titleHeight, overflow: 'visible'})
|
91
|
+
controlHeight = if @contentControl.length then @contentControl.outerHeight() else 0
|
92
|
+
@contentPane.css({height: height - titleHeight - controlHeight - 40})
|
93
|
+
@contentPane.find('.mercury-display-pane').css({width: width - 40})
|
94
|
+
else
|
95
|
+
@contentElement.css({height: height - titleHeight, overflow: 'auto'})
|
96
|
+
|
97
|
+
|
98
|
+
position: ->
|
99
|
+
viewportWidth = Mercury.displayRect.width
|
100
|
+
|
101
|
+
@contentPane.css({height: 'auto'}) if @contentPane
|
102
|
+
@contentElement.css({height: 'auto'})
|
103
|
+
@element.css({width: 'auto', height: 'auto', display: 'block', visibility: 'hidden'})
|
104
|
+
|
105
|
+
width = @element.width()
|
106
|
+
height = @element.height()
|
107
|
+
|
108
|
+
width = @minWidth if width < @minWidth
|
109
|
+
height = Mercury.displayRect.fullHeight - 20 if height > Mercury.displayRect.fullHeight - 20 || @options.fullHeight
|
110
|
+
|
111
|
+
titleHeight = @titleElement.outerHeight()
|
112
|
+
if @contentPane && @contentPane.length
|
113
|
+
@contentElement.css({height: height - titleHeight, overflow: 'visible'})
|
114
|
+
controlHeight = if @contentControl.length then @contentControl.outerHeight() else 0
|
115
|
+
@contentPane.css({height: height - titleHeight - controlHeight - 40})
|
116
|
+
@contentPane.find('.mercury-display-pane').css({width: width - 40})
|
117
|
+
else
|
118
|
+
@contentElement.css({height: height - titleHeight, overflow: 'auto'})
|
119
|
+
|
120
|
+
@element.css {
|
121
|
+
left: (viewportWidth - width) / 2
|
122
|
+
width: width
|
123
|
+
height: height
|
124
|
+
display: if @visible then 'block' else 'none'
|
125
|
+
visibility: 'visible'
|
126
|
+
}
|
127
|
+
|
128
|
+
|
129
|
+
update: ->
|
130
|
+
@reset()
|
131
|
+
@resize()
|
132
|
+
@load()
|
133
|
+
|
134
|
+
|
135
|
+
load: ->
|
136
|
+
@setTitle()
|
137
|
+
return unless @url
|
138
|
+
@element.addClass('loading')
|
139
|
+
if Mercury.preloadedViews[@url]
|
140
|
+
setTimeout(10, => @loadContent(Mercury.preloadedViews[@url]))
|
141
|
+
else
|
142
|
+
jQuery.ajax @url, {
|
143
|
+
headers: Mercury.ajaxHeaders()
|
144
|
+
type: @options.loadType || 'GET'
|
145
|
+
data: @options.loadData
|
146
|
+
success: (data) => @loadContent(data)
|
147
|
+
error: =>
|
148
|
+
@hide()
|
149
|
+
Mercury.notify("Mercury was unable to load %s for the modal.", @url)
|
150
|
+
}
|
151
|
+
|
152
|
+
|
153
|
+
loadContent: (data, options = null) ->
|
154
|
+
@initialize()
|
155
|
+
@options = options || @options
|
156
|
+
@setTitle()
|
157
|
+
@loaded = true
|
158
|
+
@element.removeClass('loading')
|
159
|
+
@contentElement.html(data)
|
160
|
+
@contentElement.css({display: 'none', visibility: 'hidden'})
|
161
|
+
|
162
|
+
# for complex modal content, we provide panes and controls
|
163
|
+
@contentPane = @element.find('.mercury-display-pane-container')
|
164
|
+
@contentControl = @element.find('.mercury-display-controls')
|
165
|
+
|
166
|
+
@options.afterLoad.call(@) if @options.afterLoad
|
167
|
+
if @options.handler
|
168
|
+
if Mercury.modalHandlers[@options.handler]
|
169
|
+
Mercury.modalHandlers[@options.handler].call(@)
|
170
|
+
else if Mercury.lightviewHandlers[@options.handler]
|
171
|
+
Mercury.lightviewHandlers[@options.handler].call(@)
|
172
|
+
|
173
|
+
@element.localize(Mercury.locale()) if Mercury.config.localization.enabled
|
174
|
+
@resize()
|
175
|
+
|
176
|
+
|
177
|
+
setTitle: ->
|
178
|
+
@titleElement.find('span').html(Mercury.I18n(@options.title))
|
179
|
+
closeButton = @titleElement.find('a')
|
180
|
+
if @options.closeButton == false then closeButton.hide() else closeButton.show()
|
181
|
+
|
182
|
+
|
183
|
+
reset: ->
|
184
|
+
@titleElement.find('span').html('')
|
185
|
+
@contentElement.html('')
|
186
|
+
|
187
|
+
|
188
|
+
hide: ->
|
189
|
+
return if @showing
|
190
|
+
@options = {}
|
191
|
+
@initialized = false
|
192
|
+
|
193
|
+
Mercury.trigger('focus:frame')
|
194
|
+
@element.hide()
|
195
|
+
@overlay.hide()
|
196
|
+
@reset()
|
197
|
+
|
198
|
+
@visible = false
|
@@ -0,0 +1,11 @@
|
|
1
|
+
@Mercury.modalHandlers.htmlEditor = ->
|
2
|
+
# fill the text area with the content
|
3
|
+
content = Mercury.region.content(null, true, false)
|
4
|
+
@element.find('textarea').val(content)
|
5
|
+
|
6
|
+
# replace the contents on form submit
|
7
|
+
@element.find('form').on 'submit', (event) =>
|
8
|
+
event.preventDefault()
|
9
|
+
value = @element.find('textarea').val().replace(/\n/g, '')
|
10
|
+
Mercury.trigger('action', {action: 'replaceHTML', value: value})
|
11
|
+
@hide()
|
@@ -0,0 +1,92 @@
|
|
1
|
+
@Mercury.modalHandlers.insertLink = ->
|
2
|
+
# make the inputs work with the radio buttons
|
3
|
+
@element.find('label input').on 'click', ->
|
4
|
+
jQuery(@).closest('label').next('.selectable').focus()
|
5
|
+
|
6
|
+
@element.find('.selectable').on 'focus', ->
|
7
|
+
jQuery(@).prev('label').find('input[type=radio]').prop("checked", true)
|
8
|
+
|
9
|
+
# show/hide the link target options on target change
|
10
|
+
@element.find('#link_target').on 'change', =>
|
11
|
+
@element.find(".link-target-options").hide()
|
12
|
+
@element.find("##{@element.find('#link_target').val()}_options").show()
|
13
|
+
@resize(true)
|
14
|
+
|
15
|
+
# fill the existing bookmark select
|
16
|
+
bookmarkSelect = @element.find('#link_existing_bookmark')
|
17
|
+
for link in jQuery('a[name]', window.mercuryInstance.document)
|
18
|
+
bookmarkSelect.append(jQuery('<option>', {value: jQuery(link).attr('name')}).text(jQuery(link).text()))
|
19
|
+
|
20
|
+
# get the selection and initialize its information into the form
|
21
|
+
if Mercury.region && Mercury.region.selection
|
22
|
+
selection = Mercury.region.selection()
|
23
|
+
|
24
|
+
# if we're editing a link prefill the information
|
25
|
+
container = selection.commonAncestor(true).closest('a') if selection && selection.commonAncestor
|
26
|
+
if container && container.length
|
27
|
+
existingLink = container
|
28
|
+
|
29
|
+
# don't allow changing the content on edit
|
30
|
+
@element.find('#link_text_container').hide()
|
31
|
+
|
32
|
+
# fill in the external url or bookmark select based on what it looks like
|
33
|
+
if container.attr('href') && container.attr('href').indexOf('#') == 0
|
34
|
+
bookmarkSelect.val(container.attr('href').replace(/[^#]*#/, ''))
|
35
|
+
bookmarkSelect.prev('label').find('input[type=radio]').prop("checked", true)
|
36
|
+
else
|
37
|
+
@element.find('#link_external_url').val(container.attr('href'))
|
38
|
+
|
39
|
+
# if it has a name, assume it's a bookmark target
|
40
|
+
if container.attr('name')
|
41
|
+
newBookmarkInput = @element.find('#link_new_bookmark')
|
42
|
+
newBookmarkInput.val(container.attr('name'))
|
43
|
+
newBookmarkInput.prev('label').find('input[type=radio]').prop("checked", true)
|
44
|
+
|
45
|
+
# if it has a target, select it, and try to pull options out
|
46
|
+
if container.attr('target')
|
47
|
+
@element.find('#link_target').val(container.attr('target'))
|
48
|
+
|
49
|
+
# if it's a popup window
|
50
|
+
if container.attr('href') && container.attr('href').indexOf('javascript:void') == 0
|
51
|
+
href = container.attr('href')
|
52
|
+
@element.find('#link_external_url').val(href.match(/window.open\('([^']+)',/)[1])
|
53
|
+
@element.find('#link_target').val('popup')
|
54
|
+
@element.find('#link_popup_width').val(href.match(/width=(\d+),/)[1])
|
55
|
+
@element.find('#link_popup_height').val(href.match(/height=(\d+),/)[1])
|
56
|
+
@element.find('#popup_options').show()
|
57
|
+
|
58
|
+
# get the text content
|
59
|
+
@element.find('#link_text').val(selection.textContent()) if selection.textContent
|
60
|
+
|
61
|
+
# build the link on form submission
|
62
|
+
@element.find('form').on 'submit', (event) =>
|
63
|
+
event.preventDefault()
|
64
|
+
|
65
|
+
content = @element.find('#link_text').val()
|
66
|
+
target = @element.find('#link_target').val()
|
67
|
+
type = @element.find('input[name=link_type]:checked').val()
|
68
|
+
|
69
|
+
switch type
|
70
|
+
when 'existing_bookmark' then attrs = {href: "##{@element.find('#link_existing_bookmark').val()}"}
|
71
|
+
when 'new_bookmark' then attrs = {name: "#{@element.find('#link_new_bookmark').val()}"}
|
72
|
+
else attrs = {href: @element.find("#link_#{type}").val()}
|
73
|
+
|
74
|
+
switch target
|
75
|
+
when 'popup'
|
76
|
+
args = {
|
77
|
+
width: parseInt(@element.find('#link_popup_width').val()) || 500,
|
78
|
+
height: parseInt(@element.find('#link_popup_height').val()) || 500,
|
79
|
+
menubar: 'no',
|
80
|
+
toolbar: 'no'
|
81
|
+
}
|
82
|
+
attrs['href'] = "javascript:void(window.open('#{attrs['href']}', 'popup_window', '#{jQuery.param(args).replace(/&/g, ',')}'))"
|
83
|
+
else attrs['target'] = target if target
|
84
|
+
|
85
|
+
value = {tagName: 'a', attrs: attrs, content: content}
|
86
|
+
|
87
|
+
if existingLink
|
88
|
+
Mercury.trigger('action', {action: 'replaceLink', value: value, node: existingLink.get(0)})
|
89
|
+
else
|
90
|
+
Mercury.trigger('action', {action: 'insertLink', value: value})
|
91
|
+
|
92
|
+
@hide()
|
@@ -0,0 +1,81 @@
|
|
1
|
+
@Mercury.modalHandlers.insertMedia = ->
|
2
|
+
# make the inputs work with the radio buttons, and options
|
3
|
+
@element.find('label input').on 'click', ->
|
4
|
+
jQuery(@).closest('label').next('.selectable').focus()
|
5
|
+
|
6
|
+
@element.find('.selectable').on 'focus', (event) =>
|
7
|
+
element = jQuery(event.target)
|
8
|
+
element.prev('label').find('input[type=radio]').prop("checked", true)
|
9
|
+
|
10
|
+
@element.find(".media-options").hide()
|
11
|
+
@element.find("##{element.attr('id').replace('media_', '')}").show()
|
12
|
+
@resize(true)
|
13
|
+
|
14
|
+
# get the selection and initialize its information into the form
|
15
|
+
if Mercury.region && Mercury.region.selection
|
16
|
+
selection = Mercury.region.selection()
|
17
|
+
|
18
|
+
# if we're editing an image prefill the information
|
19
|
+
if selection.is && image = selection.is('img')
|
20
|
+
@element.find('#media_image_url').val(image.attr('src'))
|
21
|
+
@element.find('#media_image_alignment').val(image.attr('align'))
|
22
|
+
setTimeout 300, => @element.find('#media_image_url').focus()
|
23
|
+
|
24
|
+
# if we're editing an iframe (assume it's a video for now)
|
25
|
+
if selection.is && iframe = selection.is('iframe')
|
26
|
+
src = iframe.attr('src')
|
27
|
+
if src.indexOf('http://www.youtube.com') > -1
|
28
|
+
# it's a youtube video
|
29
|
+
@element.find('#media_youtube_url').val("http://youtu.be/#{src.match(/\/embed\/(\w+)/)[1]}")
|
30
|
+
@element.find('#media_youtube_width').val(iframe.width())
|
31
|
+
@element.find('#media_youtube_height').val(iframe.height())
|
32
|
+
setTimeout 300, => @element.find('#media_youtube_url').focus()
|
33
|
+
else if src.indexOf('http://player.vimeo.com') > -1
|
34
|
+
# it's a vimeo video
|
35
|
+
@element.find('#media_vimeo_url').val("http://vimeo.com/#{src.match(/\/video\/(\w+)/)[1]}")
|
36
|
+
@element.find('#media_vimeo_width').val(iframe.width())
|
37
|
+
@element.find('#media_vimeo_height').val(iframe.height())
|
38
|
+
setTimeout 300, => @element.find('#media_vimeo_url').focus()
|
39
|
+
|
40
|
+
|
41
|
+
# build the image or youtube embed on form submission
|
42
|
+
@element.find('form').on 'submit', (event) =>
|
43
|
+
event.preventDefault()
|
44
|
+
type = @element.find('input[name=media_type]:checked').val()
|
45
|
+
|
46
|
+
switch type
|
47
|
+
when 'image_url'
|
48
|
+
attrs = {src: @element.find('#media_image_url').val()}
|
49
|
+
attrs['align'] = alignment if alignment = @element.find('#media_image_alignment').val()
|
50
|
+
Mercury.trigger('action', {action: 'insertImage', value: attrs})
|
51
|
+
|
52
|
+
when 'youtube_url'
|
53
|
+
url = @element.find('#media_youtube_url').val()
|
54
|
+
unless /^http:\/\/youtu.be\//.test(url)
|
55
|
+
Mercury.notify('Error: The provided youtube share url was invalid.')
|
56
|
+
return
|
57
|
+
code = url.replace('http://youtu.be/', '')
|
58
|
+
value = jQuery('<iframe>', {
|
59
|
+
width: @element.find('#media_youtube_width').val() || 560,
|
60
|
+
height: @element.find('#media_youtube_height').val() || 349,
|
61
|
+
src: "http://www.youtube.com/embed/#{code}?wmode=transparent",
|
62
|
+
frameborder: 0,
|
63
|
+
allowfullscreen: 'true'
|
64
|
+
})
|
65
|
+
Mercury.trigger('action', {action: 'insertHTML', value: value})
|
66
|
+
|
67
|
+
when 'vimeo_url'
|
68
|
+
url = @element.find('#media_vimeo_url').val()
|
69
|
+
unless /^http:\/\/vimeo.com\//.test(url)
|
70
|
+
Mercury.notify('Error: The provided vimeo url was invalid.')
|
71
|
+
return
|
72
|
+
code = url.replace('http://vimeo.com/', '')
|
73
|
+
value = jQuery('<iframe>', {
|
74
|
+
width: @element.find('#media_vimeo_width').val() || 400,
|
75
|
+
height: @element.find('#media_vimeo_height').val() || 225,
|
76
|
+
src: "http://player.vimeo.com/video/#{code}?title=1&byline=1&portrait=0&color=ffffff",
|
77
|
+
frameborder: 0
|
78
|
+
})
|
79
|
+
Mercury.trigger('action', {action: 'insertHTML', value: value})
|
80
|
+
|
81
|
+
@hide()
|
@@ -0,0 +1,12 @@
|
|
1
|
+
@Mercury.modalHandlers.insertSnippet = ->
|
2
|
+
@element.find('form').on 'submit', (event) =>
|
3
|
+
event.preventDefault()
|
4
|
+
serializedForm = @element.find('form').serializeObject()
|
5
|
+
if Mercury.snippet
|
6
|
+
snippet = Mercury.snippet
|
7
|
+
snippet.setOptions(serializedForm)
|
8
|
+
Mercury.snippet = null
|
9
|
+
else
|
10
|
+
snippet = Mercury.Snippet.create(@options.snippetName, serializedForm)
|
11
|
+
Mercury.trigger('action', {action: 'insertSnippet', value: snippet})
|
12
|
+
@hide()
|
@@ -0,0 +1,54 @@
|
|
1
|
+
@Mercury.modalHandlers.insertTable = ->
|
2
|
+
table = @element.find('#table_display table')
|
3
|
+
|
4
|
+
# make td's selectable
|
5
|
+
table.on 'click', (event) =>
|
6
|
+
cell = jQuery(event.target)
|
7
|
+
table = cell.closest('table')
|
8
|
+
table.find('.selected').removeAttr('class')
|
9
|
+
cell.addClass('selected')
|
10
|
+
Mercury.tableEditor(table, cell, ' ')
|
11
|
+
|
12
|
+
# select the first td
|
13
|
+
firstCell = table.find('td, th').first()
|
14
|
+
firstCell.addClass('selected')
|
15
|
+
Mercury.tableEditor(table, firstCell, ' ')
|
16
|
+
|
17
|
+
# make the buttons work
|
18
|
+
@element.find('input.action').on 'click', (event) =>
|
19
|
+
action = jQuery(event.target).attr('name')
|
20
|
+
switch action
|
21
|
+
when 'insertRowBefore' then Mercury.tableEditor.addRow('before')
|
22
|
+
when 'insertRowAfter' then Mercury.tableEditor.addRow('after')
|
23
|
+
when 'deleteRow' then Mercury.tableEditor.removeRow()
|
24
|
+
when 'insertColumnBefore' then Mercury.tableEditor.addColumn('before')
|
25
|
+
when 'insertColumnAfter' then Mercury.tableEditor.addColumn('after')
|
26
|
+
when 'deleteColumn' then Mercury.tableEditor.removeColumn()
|
27
|
+
when 'increaseColspan' then Mercury.tableEditor.increaseColspan()
|
28
|
+
when 'decreaseColspan' then Mercury.tableEditor.decreaseColspan()
|
29
|
+
when 'increaseRowspan' then Mercury.tableEditor.increaseRowspan()
|
30
|
+
when 'decreaseRowspan' then Mercury.tableEditor.decreaseRowspan()
|
31
|
+
|
32
|
+
# set the alignment
|
33
|
+
@element.find('#table_alignment').on 'change', =>
|
34
|
+
table.attr({align: @element.find('#table_alignment').val()})
|
35
|
+
|
36
|
+
# set the border
|
37
|
+
@element.find('#table_border').on 'keyup', =>
|
38
|
+
table.attr({border: parseInt(@element.find('#table_border').val())})
|
39
|
+
|
40
|
+
# set the cellspacing
|
41
|
+
@element.find('#table_spacing').on 'keyup', =>
|
42
|
+
table.attr({cellspacing: parseInt(@element.find('#table_spacing').val())})
|
43
|
+
|
44
|
+
# build the table on form submission
|
45
|
+
@element.find('form').on 'submit', (event) =>
|
46
|
+
event.preventDefault()
|
47
|
+
table.find('.selected').removeAttr('class')
|
48
|
+
table.find('td, th').html('<br/>')
|
49
|
+
|
50
|
+
html = jQuery('<div>').html(table).html()
|
51
|
+
value = html.replace(/^\s+|\n/gm, '').replace(/(<\/.*?>|<table.*?>|<tbody>|<tr>)/g, '$1\n')
|
52
|
+
|
53
|
+
Mercury.trigger('action', {action: 'insertTable', value: value})
|
54
|
+
@hide()
|