spontaneous 0.2.0.beta1 → 0.2.0.beta2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.gitignore +24 -0
- data/.locat +42 -0
- data/.travis/gemfiles/Gemfile.empty +7 -0
- data/.travis.yml +18 -0
- data/Gemfile +12 -8
- data/LICENSE +1 -1
- data/Rakefile +15 -157
- data/Readme.markdown +1 -1
- data/application/css/core.css.scss +22 -146
- data/application/css/definitions.css.scss +7 -3
- data/application/css/dialogue.css.scss +26 -1
- data/application/css/editing.css.scss +70 -28
- data/application/css/font.css.scss +1 -1
- data/application/css/popover.css.scss +2 -0
- data/application/css/top.css.scss +231 -0
- data/application/js/add_alias_dialogue.js +1 -1
- data/application/js/add_home_dialogue.js +1 -1
- data/application/js/ajax.js +61 -31
- data/application/js/box.js +4 -4
- data/application/js/conflicted_field_dialogue.js +1 -1
- data/application/js/content.js +5 -5
- data/application/js/dom.js +5 -0
- data/application/js/edit_panel.js +1 -0
- data/application/js/editing.js +1 -1
- data/application/js/extensions.js +8 -0
- data/application/js/field/boolean.js +31 -0
- data/application/js/field/file.js +32 -4
- data/application/js/field/image.js +24 -9
- data/application/js/field/markdown.js +87 -59
- data/application/js/field/select.js +1 -1
- data/application/js/field/webvideo.js +6 -1
- data/application/js/init.js +2 -2
- data/application/js/jquery-selection-position.js +130 -0
- data/application/js/location.js +4 -25
- data/application/js/meta_view/user_admin.js +2 -2
- data/application/js/metadata.js +2 -2
- data/application/js/page_browser.js +1 -1
- data/application/js/panel/root_menu.js +0 -1
- data/application/js/popover.js +27 -12
- data/application/js/popover_view.js +20 -4
- data/application/js/preview.js +31 -16
- data/application/js/progress.js +22 -21
- data/application/js/publish.js +18 -7
- data/application/js/sharded_upload.js +9 -6
- data/application/js/spontaneous.js +3 -1
- data/application/js/top_bar.js +264 -173
- data/application/js/upload.js +12 -5
- data/application/js/upload_manager.js +4 -3
- data/application/js/user.js +1 -2
- data/application/js/views/box_view.js +1 -1
- data/application/js/views/page_view.js +16 -5
- data/application/js/views/piece_view.js +5 -4
- data/application/static/font/fontawesome-webfont-1c66a4738b40ef0f6b1abca0ba9a796d.ttf +0 -0
- data/application/views/index.erb +6 -14
- data/application/views/login.erb +6 -25
- data/application/views/schema_modification_error.html.erb +3 -7
- data/db/migrations/20130114120000_create_revision_tables.rb +2 -2
- data/db/migrations/20130813111009_increase_path_length.rb +14 -0
- data/gem-public_cert.pem +20 -0
- data/lib/spontaneous/asset/app_compiler.rb +44 -0
- data/lib/spontaneous/asset/environment.rb +225 -0
- data/lib/spontaneous/asset.rb +2 -67
- data/lib/spontaneous/box.rb +0 -1
- data/lib/spontaneous/capistrano/deploy.rb +2 -2
- data/lib/spontaneous/capistrano/sync.rb +1 -1
- data/lib/spontaneous/cli/init.rb +36 -13
- data/lib/spontaneous/cli/server.rb +0 -1
- data/lib/spontaneous/cli/site.rb +2 -1
- data/lib/spontaneous/cli.rb +3 -1
- data/lib/spontaneous/collections/entry_set.rb +4 -12
- data/lib/spontaneous/collections/hash_with_fallback.rb +20 -0
- data/lib/spontaneous/collections/prototype_set.rb +6 -5
- data/lib/spontaneous/crypt.rb +2 -2
- data/lib/spontaneous/data_mapper/content_model/associations.rb +115 -63
- data/lib/spontaneous/data_mapper.rb +1 -1
- data/lib/spontaneous/errors.rb +6 -0
- data/lib/spontaneous/extensions/object_space.rb +6 -0
- data/lib/spontaneous/facet.rb +1 -0
- data/lib/spontaneous/field/base.rb +86 -13
- data/lib/spontaneous/field/boolean.rb +65 -0
- data/lib/spontaneous/field/file.rb +17 -6
- data/lib/spontaneous/field/html.rb +13 -0
- data/lib/spontaneous/field/image/size.rb +76 -0
- data/lib/spontaneous/field/image.rb +99 -414
- data/lib/spontaneous/field/tags.rb +36 -0
- data/lib/spontaneous/field/update.rb +1 -1
- data/lib/spontaneous/field/webvideo/fallback.rb +41 -0
- data/lib/spontaneous/field/webvideo/vimeo.rb +113 -0
- data/lib/spontaneous/field/webvideo/vine.rb +94 -0
- data/lib/spontaneous/field/webvideo/youtube.rb +133 -0
- data/lib/spontaneous/field/webvideo.rb +100 -250
- data/lib/spontaneous/field.rb +1 -1
- data/lib/spontaneous/generators/site/Gemfile.tt +5 -14
- data/lib/spontaneous/generators/site/assets/README.md +20 -0
- data/lib/spontaneous/generators/site/assets/css/site.scss +8 -0
- data/lib/spontaneous/generators/site/assets/js/site.js +6 -0
- data/lib/spontaneous/generators/site/config/deploy.rb.tt +9 -0
- data/lib/spontaneous/generators/site/config/user_levels.yml +14 -3
- data/lib/spontaneous/generators/site/public/README.md +12 -0
- data/lib/spontaneous/generators/site/templates/layouts/standard.html.cut.tt +2 -2
- data/lib/spontaneous/generators/site.rb +77 -35
- data/lib/spontaneous/layout.rb +6 -7
- data/lib/spontaneous/loader.rb +21 -13
- data/lib/spontaneous/media/file.rb +22 -9
- data/lib/spontaneous/media/image/attributes.rb +33 -0
- data/lib/spontaneous/media/image/format/gif.rb +4 -0
- data/lib/spontaneous/media/image/format/jpg.rb +17 -0
- data/lib/spontaneous/media/image/format/png.rb +4 -0
- data/lib/spontaneous/media/image/format/webp.rb +26 -0
- data/lib/spontaneous/media/image/format.rb +79 -0
- data/lib/spontaneous/media/image/optimizer.rb +69 -0
- data/lib/spontaneous/media/image/processor.rb +17 -0
- data/lib/spontaneous/media/image/renderable.rb +52 -0
- data/lib/spontaneous/media/image/skeptick.rb +70 -0
- data/lib/spontaneous/media/image.rb +50 -0
- data/lib/spontaneous/media/temp_file.rb +4 -0
- data/lib/spontaneous/media.rb +1 -0
- data/lib/spontaneous/model/core/aliases.rb +14 -8
- data/lib/spontaneous/model/core/boxes.rb +5 -2
- data/lib/spontaneous/model/core/entries.rb +4 -0
- data/lib/spontaneous/model/core/entry.rb +1 -0
- data/lib/spontaneous/model/core/fields.rb +5 -2
- data/lib/spontaneous/model/core/locks.rb +16 -0
- data/lib/spontaneous/model/core/media.rb +1 -15
- data/lib/spontaneous/model/core.rb +31 -1
- data/lib/spontaneous/model/page/controllers.rb +2 -2
- data/lib/spontaneous/model/page/formats.rb +1 -4
- data/lib/spontaneous/model/page/layouts.rb +6 -2
- data/lib/spontaneous/model/page/locks.rb +8 -2
- data/lib/spontaneous/model/page/page_tree.rb +2 -2
- data/lib/spontaneous/model/page/paths.rb +74 -9
- data/lib/spontaneous/model/page.rb +11 -3
- data/lib/spontaneous/model.rb +6 -6
- data/lib/spontaneous/output/context/render_cache.rb +23 -0
- data/lib/spontaneous/output/context.rb +56 -30
- data/lib/spontaneous/output/helpers/script_helper.rb +9 -53
- data/lib/spontaneous/output/helpers/stylesheet_helper.rb +8 -40
- data/lib/spontaneous/output/template/renderer.rb +17 -5
- data/lib/spontaneous/output.rb +0 -1
- data/lib/spontaneous/paths.rb +6 -2
- data/lib/spontaneous/permissions/access_key.rb +18 -0
- data/lib/spontaneous/permissions/user.rb +1 -1
- data/lib/spontaneous/permissions.rb +4 -1
- data/lib/spontaneous/plugins/application/state.rb +19 -12
- data/lib/spontaneous/prototypes/field_prototype.rb +14 -8
- data/lib/spontaneous/published_revision.rb +7 -0
- data/lib/spontaneous/publishing/immediate.rb +43 -34
- data/lib/spontaneous/publishing/revision.rb +9 -6
- data/lib/spontaneous/rack/asset_server.rb +20 -0
- data/lib/spontaneous/rack/back/alias.rb +46 -0
- data/lib/spontaneous/rack/back/application_assets.rb +28 -0
- data/lib/spontaneous/rack/back/base.rb +34 -0
- data/lib/spontaneous/rack/back/changes.rb +19 -0
- data/lib/spontaneous/rack/back/content.rb +54 -0
- data/lib/spontaneous/rack/back/events.rb +38 -0
- data/lib/spontaneous/rack/back/field.rb +37 -0
- data/lib/spontaneous/rack/back/file.rb +118 -0
- data/lib/spontaneous/rack/back/helpers.rb +71 -0
- data/lib/spontaneous/rack/back/index.rb +16 -0
- data/lib/spontaneous/rack/back/login.rb +47 -0
- data/lib/spontaneous/rack/back/map.rb +24 -0
- data/lib/spontaneous/rack/back/page.rb +46 -0
- data/lib/spontaneous/rack/back/preview.rb +43 -0
- data/lib/spontaneous/rack/back/schema.rb +30 -0
- data/lib/spontaneous/rack/back/site.rb +25 -0
- data/lib/spontaneous/rack/back/site_assets.rb +13 -0
- data/lib/spontaneous/rack/back/unsupported_browser.rb +7 -0
- data/lib/spontaneous/rack/{user_admin.rb → back/user_admin.rb} +2 -5
- data/lib/spontaneous/rack/back.rb +85 -764
- data/lib/spontaneous/rack/cacheable_file.rb +3 -3
- data/lib/spontaneous/rack/front.rb +16 -9
- data/lib/spontaneous/rack/middleware/authenticate.rb +65 -0
- data/lib/spontaneous/rack/middleware/csrf.rb +66 -0
- data/lib/spontaneous/rack/middleware/reloader.rb +52 -0
- data/lib/spontaneous/rack/middleware/scope.rb +60 -0
- data/lib/spontaneous/rack/middleware.rb +6 -0
- data/lib/spontaneous/rack/page_controller.rb +18 -5
- data/lib/spontaneous/rack/public.rb +17 -11
- data/lib/spontaneous/rack.rb +34 -24
- data/lib/spontaneous/revision.rb +29 -2
- data/lib/spontaneous/schema/uid.rb +4 -3
- data/lib/spontaneous/schema/uid_map.rb +5 -24
- data/lib/spontaneous/schema.rb +1 -0
- data/lib/spontaneous/search/database.rb +8 -0
- data/lib/spontaneous/search/field.rb +1 -1
- data/lib/spontaneous/search/index.rb +3 -5
- data/lib/spontaneous/server.rb +1 -1
- data/lib/spontaneous/simultaneous.rb +1 -1
- data/lib/spontaneous/site/features.rb +4 -5
- data/lib/spontaneous/site/helpers.rb +22 -5
- data/lib/spontaneous/site/instance.rb +2 -2
- data/lib/spontaneous/site/selectors.rb +22 -3
- data/lib/spontaneous/storage/cloud.rb +13 -9
- data/lib/spontaneous/storage/local.rb +11 -6
- data/lib/spontaneous/style.rb +40 -23
- data/lib/spontaneous/utils/database/mysql_dumper.rb +1 -1
- data/lib/spontaneous/utils/smush_it.rb +1 -1
- data/lib/spontaneous/version.rb +1 -1
- data/lib/spontaneous.rb +35 -33
- data/spontaneous.gemspec +53 -787
- data/test/experimental/test_crypt.rb +56 -56
- data/test/experimental/test_features.rb +16 -27
- data/test/fixtures/assets/public1/css/data.css.scss +3 -0
- data/test/fixtures/assets/public1/css/image1.css.scss +4 -0
- data/test/fixtures/assets/public1/css/import.css.scss +1 -0
- data/test/fixtures/assets/public1/css/urlhash.css.scss +3 -0
- data/test/fixtures/assets/public1/js/a.js +1 -1
- data/test/fixtures/assets/public1/js/all.js +4 -0
- data/test/fixtures/assets/public1/js/{m.coffee → m.js.coffee} +1 -0
- data/test/fixtures/assets/public1/x.js +1 -0
- data/test/fixtures/assets/public2/css/all.css +4 -0
- data/test/fixtures/assets/public2/css/missing.css.scss +3 -0
- data/test/fixtures/assets/public2/i/y.png +0 -0
- data/test/fixtures/assets/public2/js/b.js +1 -1
- data/test/fixtures/assets/public2/js/c.js +1 -1
- data/test/fixtures/images/size.extended.webp +0 -0
- data/test/fixtures/images/size.lossless.webp +0 -0
- data/test/fixtures/images/size.lossy.webp +0 -0
- data/test/fixtures/schema/before.yml +4 -4
- data/test/fixtures/schema/schema.yml +1 -1
- data/test/fixtures/templates/aliases/aaa.html.cut +0 -0
- data/test/fixtures/templates/extended/partial_with_renderer.html.cut +1 -0
- data/test/fixtures/templates/extended/with_includes_and_renderer.html.cut +2 -0
- data/test/functional/test_application.rb +108 -106
- data/test/functional/test_back.rb +924 -930
- data/test/functional/test_front.rb +285 -238
- data/test/functional/test_user_manager.rb +75 -100
- data/test/integration/test_installation.rb +1 -1
- data/test/support/matchers.rb +12 -0
- data/test/support/minitest.rb +121 -0
- data/test/support/rack.rb +45 -0
- data/test/support/test_start_finish.rb +103 -0
- data/test/test_helper.rb +21 -68
- data/test/test_integration_helper.rb +1 -3
- data/test/unit/test_alias.rb +432 -408
- data/test/unit/test_asset_bundler.rb +58 -58
- data/test/unit/test_assets.rb +485 -155
- data/test/unit/test_async.rb +16 -37
- data/test/unit/test_authentication.rb +425 -457
- data/test/unit/test_boxes.rb +191 -191
- data/test/unit/test_changesets.rb +244 -254
- data/test/unit/test_config.rb +128 -142
- data/test/unit/test_content.rb +313 -359
- data/test/unit/test_content_inheritance.rb +29 -30
- data/test/unit/test_datamapper.rb +1205 -1080
- data/test/unit/test_datamapper_content.rb +49 -51
- data/test/unit/test_extensions.rb +23 -23
- data/test/unit/test_fields.rb +1488 -1180
- data/test/unit/test_formats.rb +158 -158
- data/test/unit/test_generators.rb +98 -40
- data/test/unit/test_helpers.rb +73 -76
- data/test/unit/test_image_size.rb +53 -22
- data/test/unit/test_images.rb +164 -165
- data/test/unit/test_layouts.rb +133 -122
- data/test/unit/test_logger.rb +14 -17
- data/test/unit/test_media.rb +69 -84
- data/test/unit/test_modifications.rb +513 -525
- data/test/unit/test_page.rb +462 -361
- data/test/unit/test_permissions.rb +379 -364
- data/test/unit/test_piece.rb +67 -75
- data/test/unit/test_plugins.rb +82 -89
- data/test/unit/test_prototype_set.rb +215 -216
- data/test/unit/test_prototypes.rb +114 -124
- data/test/unit/test_publishing.rb +252 -289
- data/test/unit/test_render.rb +167 -115
- data/test/unit/test_revisions.rb +436 -444
- data/test/unit/test_schema.rb +339 -309
- data/test/unit/test_search.rb +577 -574
- data/test/unit/test_serialisation.rb +136 -147
- data/test/unit/test_site.rb +252 -227
- data/test/unit/test_skeptick.rb +130 -0
- data/test/unit/test_storage.rb +46 -40
- data/test/unit/test_structure.rb +57 -66
- data/test/unit/test_styles.rb +104 -104
- data/test/unit/test_templates.rb +72 -57
- data/test/unit/test_type_hierarchy.rb +15 -16
- data/test/unit/test_visibility.rb +239 -257
- metadata +455 -326
- data/application/js/vendor/JS.Class-2.1.5/CHANGELOG +0 -283
- data/application/js/vendor/JS.Class-2.1.5/MIT-LICENSE +0 -30
- data/application/js/vendor/JS.Class-2.1.5/README +0 -30
- data/application/js/vendor/JS.Class-2.1.5/min/command.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/comparable.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/constant_scope.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/decorator.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/enumerable.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/forwardable.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/hash.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/linked_list.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/loader.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/method_chain.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/observable.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/package.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/proxy.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/ruby.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/set.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/stack_trace.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/state.js +0 -1
- data/application/js/vendor/JS.Class-2.1.5/min/stdlib.js +0 -16
- data/application/js/vendor/jquery-1.6.2.min.js +0 -18
- data/application/js/vendor/jquery-ui-1.8.16.custom.min.js +0 -791
- data/application/js/vendor/jquery-ui-1.8.9.custom.min.js +0 -415
- data/application/static/font/fontawesome-webfont-5c5c21100a346972a82c34c5e96ffcfe.ttf +0 -0
- data/application/static/select-arrow-6e7dd3745b00e934b0d7a3250c46558b.png +0 -0
- data/bin/limit-upload +0 -5
- data/bin/unlimit-upload +0 -3
- data/lib/spontaneous/asset/file.rb +0 -25
- data/lib/spontaneous/asset/source.rb +0 -28
- data/lib/spontaneous/image_size.rb +0 -123
- data/lib/spontaneous/output/assets/compression.rb +0 -58
- data/lib/spontaneous/output/assets.rb +0 -32
- data/lib/spontaneous/rack/around_back.rb +0 -20
- data/lib/spontaneous/rack/around_front.rb +0 -27
- data/lib/spontaneous/rack/around_preview.rb +0 -22
- data/lib/spontaneous/rack/assets.rb +0 -126
- data/lib/spontaneous/rack/authentication.rb +0 -20
- data/lib/spontaneous/rack/cookie_authentication.rb +0 -38
- data/lib/spontaneous/rack/helpers.rb +0 -52
- data/lib/spontaneous/rack/http.rb +0 -18
- data/lib/spontaneous/rack/media.rb +0 -30
- data/lib/spontaneous/rack/query_authentication.rb +0 -35
- data/lib/spontaneous/rack/reloader.rb +0 -45
- data/lib/spontaneous/rack/user_helpers.rb +0 -28
- /data/{README → application/js/field/markdown/text_command.js} +0 -0
- /data/application/js/vendor/{JS.Class-2.1.5/min/core.js → js.class-2.1.5.min.js} +0 -0
- /data/test/fixtures/assets/public1/css/{a.scss → a.css.scss} +0 -0
- /data/{lib/spontaneous/generators/site/public/css/site.scss → test/fixtures/assets/public1/x.css} +0 -0
- /data/{lib/spontaneous/generators/site/public/js/.empty_directory → test/fixtures/assets/public1/x.png} +0 -0
- /data/test/fixtures/assets/public2/css/{b.scss → b.css.scss} +0 -0
- /data/test/fixtures/assets/public2/js/{n.coffee → n.js.coffee} +0 -0
- /data/test/fixtures/back/{public → assets}/css/sass_include.scss +0 -0
- /data/test/fixtures/back/{public → assets}/css/sass_template.scss +0 -0
- /data/test/fixtures/back/{public → assets}/js/coffeescript.coffee +0 -0
- /data/{lib/spontaneous/generators/site/public/js/site.js → test/fixtures/templates/aliases/aa_alias.html.cut} +0 -0
@@ -90,8 +90,6 @@ module Spontaneous::Search
|
|
90
90
|
|
91
91
|
def each_indexable(page)
|
92
92
|
indexable = [page]
|
93
|
-
# not sure that I need the include? test here as page.content only returns Pieces
|
94
|
-
# and I'm not sure that there is a particular need to exclude Pieces from indexes
|
95
93
|
indexable.concat(page.pieces.select { |content| include?(content) })
|
96
94
|
indexable += page.boxes.select { |box| include?(box) }
|
97
95
|
indexable.each do |content|
|
@@ -182,11 +180,11 @@ module Spontaneous::Search
|
|
182
180
|
case selector
|
183
181
|
when Fixnum, /\A\d+\z/
|
184
182
|
page.id == selector.to_i
|
185
|
-
when /\A
|
183
|
+
when /\A\$?([a-zA-Z].*)\z/
|
186
184
|
page.uid == $1
|
187
|
-
when /\A
|
185
|
+
when /\A[\/#]/
|
188
186
|
page.path == selector
|
189
|
-
when /\A(
|
187
|
+
when /\A(>=?)\s+(.+)\z/
|
190
188
|
rule, root = $1, S::Site[$2]
|
191
189
|
root.send(rule, page)
|
192
190
|
else
|
data/lib/spontaneous/server.rb
CHANGED
@@ -15,14 +15,13 @@ class Spontaneous::Site
|
|
15
15
|
end
|
16
16
|
|
17
17
|
def register_back_controller(namespace, controller_class)
|
18
|
-
Spontaneous::Rack.make_back_controller(controller_class)
|
19
|
-
|
20
|
-
back_controllers << [namespace_url(namespace), controller_class]
|
18
|
+
app = Spontaneous::Rack.make_back_controller(controller_class)
|
19
|
+
back_controllers << [namespace_url(namespace), app]
|
21
20
|
end
|
22
21
|
|
23
22
|
def register_front_controller(namespace, controller_class)
|
24
|
-
Spontaneous::Rack.make_front_controller(controller_class)
|
25
|
-
front_controllers << [namespace_url(namespace),
|
23
|
+
app = Spontaneous::Rack.make_front_controller(controller_class)
|
24
|
+
front_controllers << [namespace_url(namespace), app]
|
26
25
|
end
|
27
26
|
|
28
27
|
def namespace_url(namespace)
|
@@ -7,10 +7,15 @@ class Spontaneous::Site
|
|
7
7
|
module ClassMethods
|
8
8
|
def helper(*formats, &block)
|
9
9
|
helper_module = Module.new(&block)
|
10
|
-
register_helper(helper_module, *formats.flatten)
|
10
|
+
register_helper(helper_module, helper_module_name(caller), *formats.flatten)
|
11
11
|
helper_module
|
12
12
|
end
|
13
13
|
|
14
|
+
def helper_module_name(_caller)
|
15
|
+
path = _caller.first.split(':').first.split('/')[-5..-1]
|
16
|
+
path.join('_').gsub(/[^A-Za-z_]/, '_').gsub(/_+/, '_').gsub(/^_+/, '').capitalize
|
17
|
+
end
|
18
|
+
|
14
19
|
# Private: Generates a module including all helper methods for the requested format(s)
|
15
20
|
def context(*formats)
|
16
21
|
formats = [:*].concat formats.flatten.map { |f| f.to_sym }
|
@@ -28,15 +33,27 @@ class Spontaneous::Site
|
|
28
33
|
helper_module
|
29
34
|
end
|
30
35
|
|
31
|
-
def register_helper(helper_module, *formats)
|
32
|
-
site
|
36
|
+
def register_helper(helper_module, module_name, *formats)
|
37
|
+
site = instance
|
38
|
+
helpers = site.registered_helpers
|
33
39
|
if formats.empty?
|
34
|
-
|
40
|
+
helpers[:*] << helper_module
|
35
41
|
else
|
36
42
|
formats.each do |format|
|
37
|
-
|
43
|
+
helpers[format.to_sym] << helper_module
|
38
44
|
end
|
39
45
|
end
|
46
|
+
# Spontaneous::Site::Helpers.const_set(module_name, helper_module)
|
47
|
+
def helper_module.__finalize
|
48
|
+
Spontaneous::Site.unregister_helper(self)
|
49
|
+
end
|
50
|
+
end
|
51
|
+
|
52
|
+
def unregister_helper(helper_module)
|
53
|
+
helpers = instance.registered_helpers
|
54
|
+
helpers.each do |format, helpers|
|
55
|
+
helpers.delete(helper_module)
|
56
|
+
end
|
40
57
|
end
|
41
58
|
|
42
59
|
def registered_helpers
|
@@ -8,11 +8,11 @@ class Spontaneous::Site
|
|
8
8
|
extend Forwardable
|
9
9
|
|
10
10
|
def instantiate(root, env, mode)
|
11
|
-
|
11
|
+
@__instance__ = Spontaneous::Site.new(root, env, mode)
|
12
12
|
end
|
13
13
|
|
14
14
|
def instance
|
15
|
-
|
15
|
+
@__instance__
|
16
16
|
end
|
17
17
|
|
18
18
|
def_delegators :instance, :config, :database, :database=
|
@@ -9,6 +9,21 @@ class Spontaneous::Site
|
|
9
9
|
content_model.root
|
10
10
|
end
|
11
11
|
|
12
|
+
# roots returns the list of top-level pages
|
13
|
+
# Only one of these is publicly visible and this is mapped to the
|
14
|
+
# configured site domain.
|
15
|
+
#
|
16
|
+
# The rest are "hidden" roots.
|
17
|
+
def roots(user = nil, content_model = Spontaneous::Content)
|
18
|
+
domain = config.site_domain
|
19
|
+
roots = pages_dataset(content_model).where(depth: 0).all
|
20
|
+
pub, hidden = roots.partition { |p| p.root? }
|
21
|
+
map = {}
|
22
|
+
map[domain] = pub.first.id unless pub.empty?
|
23
|
+
hidden.each { |p| map[p.path] = p.id }
|
24
|
+
{ "public" => domain, "roots" => map }
|
25
|
+
end
|
26
|
+
|
12
27
|
def pages(content_model = Spontaneous::Content)
|
13
28
|
pages_dataset(content_model).all
|
14
29
|
end
|
@@ -17,13 +32,17 @@ class Spontaneous::Site
|
|
17
32
|
content_model::Page.order(:depth)
|
18
33
|
end
|
19
34
|
|
35
|
+
ID_PATH = /\A\d+\z/o
|
36
|
+
PATH_PATH = /^[\/#]/o
|
37
|
+
UID_PATH = /^\$/o
|
38
|
+
|
20
39
|
def [](path_or_uid)
|
21
40
|
case path_or_uid
|
22
|
-
when Fixnum,
|
41
|
+
when Fixnum, ID_PATH
|
23
42
|
by_id(path_or_uid)
|
24
|
-
when
|
43
|
+
when PATH_PATH
|
25
44
|
by_path(path_or_uid)
|
26
|
-
when
|
45
|
+
when UID_PATH
|
27
46
|
by_uid(path_or_uid[1..-1])
|
28
47
|
else
|
29
48
|
by_uid(path_or_uid)
|
@@ -46,30 +46,34 @@ module Spontaneous::Storage
|
|
46
46
|
@public_host = @config.delete(:public_host)
|
47
47
|
end
|
48
48
|
|
49
|
-
def open(relative_path,
|
49
|
+
def open(relative_path, headers, mode, &block)
|
50
50
|
Tempfile.open("spontaneous-cloud") do |tempfile|
|
51
51
|
tempfile.binmode
|
52
52
|
block.call(tempfile)
|
53
53
|
tempfile.rewind
|
54
|
-
self.copy(tempfile, relative_path,
|
54
|
+
self.copy(tempfile, relative_path, headers)
|
55
55
|
end
|
56
56
|
end
|
57
57
|
|
58
|
-
def copy(existing_file, media_path,
|
58
|
+
def copy(existing_file, media_path, headers = {})
|
59
59
|
params = {
|
60
60
|
:key => join_path(media_path),
|
61
61
|
:idempotent => false,
|
62
62
|
:body => existing_file,
|
63
63
|
:public => true,
|
64
|
-
:
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
64
|
+
:cache_control => "max-age=#{1.year.to_i}, public",
|
65
|
+
}.merge(headers)
|
66
|
+
# Reopen file handles to catch updated contents
|
67
|
+
src_path = existing_file.respond_to?(:read) ? existing_file.path : existing_file
|
68
|
+
File.open(src_path, "rb") do |src|
|
69
|
+
src.binmode
|
70
|
+
params[:body] = src
|
71
|
+
bucket.files.create(params)
|
72
|
+
end
|
69
73
|
end
|
70
74
|
|
71
75
|
def join_path(path)
|
72
|
-
path.join("
|
76
|
+
path.join("/")
|
73
77
|
end
|
74
78
|
|
75
79
|
def local?
|
@@ -8,7 +8,7 @@ module Spontaneous::Storage
|
|
8
8
|
@root, @url_path, @accepts = ::File.expand_path(root_directory), url_path, accepts
|
9
9
|
end
|
10
10
|
|
11
|
-
def copy(existing_file, media_path,
|
11
|
+
def copy(existing_file, media_path, headers = {})
|
12
12
|
dest_path = create_absolute_path(media_path)
|
13
13
|
copy_file(existing_file, dest_path)
|
14
14
|
set_permissions(dest_path)
|
@@ -17,10 +17,15 @@ module Spontaneous::Storage
|
|
17
17
|
|
18
18
|
def copy_file(existing_file, dest_path)
|
19
19
|
if existing_file.respond_to?(:read)
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
20
|
+
# Re-open the file because it's been modified on disk by the optimisation process
|
21
|
+
# and if we don't re-open it the copy will take the unmodified version
|
22
|
+
File.open(existing_file.path, "rb") do |src|
|
23
|
+
src.binmode
|
24
|
+
File.open(dest_path, "wb") do |f|
|
25
|
+
f.binmode
|
26
|
+
while chunk = src.read(8192)
|
27
|
+
f.write(chunk)
|
28
|
+
end
|
24
29
|
end
|
25
30
|
end
|
26
31
|
else
|
@@ -28,7 +33,7 @@ module Spontaneous::Storage
|
|
28
33
|
end
|
29
34
|
end
|
30
35
|
|
31
|
-
def open(relative_path,
|
36
|
+
def open(relative_path, headers, mode, &block)
|
32
37
|
dest_path = create_absolute_path(relative_path)
|
33
38
|
File.open(dest_path, mode) do |f|
|
34
39
|
f.binmode
|
data/lib/spontaneous/style.rb
CHANGED
@@ -19,23 +19,28 @@ module Spontaneous
|
|
19
19
|
end
|
20
20
|
|
21
21
|
def template(format = :html)
|
22
|
-
|
23
|
-
template = find_template(format)
|
24
|
-
end
|
25
|
-
template
|
22
|
+
inline_template(format) || external_template(format)
|
26
23
|
end
|
27
24
|
|
28
|
-
def
|
29
|
-
unless template =
|
30
|
-
template
|
31
|
-
end
|
32
|
-
unless template
|
33
|
-
logger.warn("No template file found for style #{owner}/#{name}.#{format}")
|
25
|
+
def external_template(format = :html)
|
26
|
+
unless (template = (file_template(format) || supertype_template(format)))
|
27
|
+
logger.warn("No template file found for style #{owner}:#{name}.#{format}")
|
34
28
|
template = anonymous_template
|
35
29
|
end
|
36
30
|
template
|
37
31
|
end
|
38
32
|
|
33
|
+
def file_template(format)
|
34
|
+
local_template(format)
|
35
|
+
end
|
36
|
+
|
37
|
+
# Tests to see if a template file exists for the specified format.
|
38
|
+
# If one doesn't exist then the style would fall back to an
|
39
|
+
# 'anonymous' template.
|
40
|
+
def template?(format = :html)
|
41
|
+
!(inline_template(format) || file_template(format)).nil?
|
42
|
+
end
|
43
|
+
|
39
44
|
alias_method :path, :template
|
40
45
|
|
41
46
|
def local_template(format)
|
@@ -59,7 +64,11 @@ module Spontaneous
|
|
59
64
|
|
60
65
|
def try_supertype_styles
|
61
66
|
class_ancestors(owner).take_while { |a| a and a < Spontaneous::Content }.
|
62
|
-
map { |s|
|
67
|
+
map { |s| supertype_style_class.new(s, prototype) }
|
68
|
+
end
|
69
|
+
|
70
|
+
def supertype_style_class
|
71
|
+
self.class
|
63
72
|
end
|
64
73
|
|
65
74
|
def class_ancestors(klass)
|
@@ -73,7 +82,7 @@ module Spontaneous
|
|
73
82
|
end
|
74
83
|
|
75
84
|
def inline_template(format)
|
76
|
-
if template_string = owner.inline_templates[format.to_sym]
|
85
|
+
if (template_string = owner.inline_templates[format.to_sym])
|
77
86
|
Anonymous.new(template_string).template(format)
|
78
87
|
end
|
79
88
|
end
|
@@ -113,13 +122,6 @@ module Spontaneous
|
|
113
122
|
Spontaneous::Render.formats(self)
|
114
123
|
end
|
115
124
|
|
116
|
-
# def export
|
117
|
-
# {
|
118
|
-
# :name => name.to_s,
|
119
|
-
# :schema_id => schema_id.to_s
|
120
|
-
# }
|
121
|
-
# end
|
122
|
-
|
123
125
|
def ==(other)
|
124
126
|
other.class == self.class && other.prototype == self.prototype && other.owner == self.owner
|
125
127
|
end
|
@@ -147,10 +149,6 @@ module Spontaneous
|
|
147
149
|
Proc.new { @template_code }
|
148
150
|
end
|
149
151
|
|
150
|
-
def exists?(format = :html)
|
151
|
-
true
|
152
|
-
end
|
153
|
-
|
154
152
|
def name
|
155
153
|
nil
|
156
154
|
end
|
@@ -159,5 +157,24 @@ module Spontaneous
|
|
159
157
|
nil
|
160
158
|
end
|
161
159
|
end
|
160
|
+
|
161
|
+
# Aliases are unique in that their style depends on the instance as well
|
162
|
+
# as the class.
|
163
|
+
# This style searches for appropriate templates based on the class of the
|
164
|
+
# instance before falling back to templates for the target.
|
165
|
+
class AliasStyle
|
166
|
+
def initialize(instance)
|
167
|
+
@instance = instance
|
168
|
+
end
|
169
|
+
|
170
|
+
def template(format = :html)
|
171
|
+
target_is_content = @instance.target.respond_to?(:resolve_style)
|
172
|
+
if (style = @instance.resolve_style(@instance.style_sid))
|
173
|
+
return style.template(format) if !target_is_content || style.template?(format)
|
174
|
+
end
|
175
|
+
style = @instance.target.resolve_style(@instance.style_sid)
|
176
|
+
style.template(format)
|
177
|
+
end
|
178
|
+
end
|
162
179
|
end
|
163
180
|
end
|
@@ -75,7 +75,7 @@ module Spontaneous
|
|
75
75
|
# The whole point of this table's existance is to reduce the
|
76
76
|
# size of the db dump for syncing
|
77
77
|
def revision_archive_table
|
78
|
-
Spontaneous::Content.
|
78
|
+
Spontaneous::Content.archive_dataset.first_source.to_s
|
79
79
|
end
|
80
80
|
|
81
81
|
def option(option, add_if_nil=false)
|
data/lib/spontaneous/version.rb
CHANGED
data/lib/spontaneous.rb
CHANGED
@@ -39,39 +39,39 @@ module Spontaneous
|
|
39
39
|
instance.reload!
|
40
40
|
end
|
41
41
|
|
42
|
-
autoload :Application,
|
43
|
-
autoload :Asset,
|
44
|
-
autoload :Box,
|
45
|
-
autoload :BoxStyle,
|
46
|
-
autoload :Change,
|
47
|
-
autoload :Cli,
|
48
|
-
autoload :Config,
|
49
|
-
autoload :ContentQuery,
|
50
|
-
autoload :Crypt,
|
51
|
-
autoload :DataMapper,
|
52
|
-
autoload :Facet,
|
53
|
-
autoload :Field,
|
54
|
-
autoload :Generators,
|
55
|
-
autoload :
|
56
|
-
autoload :
|
57
|
-
autoload :
|
58
|
-
autoload :
|
59
|
-
autoload :
|
60
|
-
autoload :
|
61
|
-
autoload :
|
62
|
-
autoload :
|
63
|
-
autoload :Publishing,
|
64
|
-
autoload :Rack,
|
65
|
-
autoload :Revision,
|
66
|
-
autoload :Schema,
|
67
|
-
autoload :Search,
|
68
|
-
autoload :Server,
|
69
|
-
autoload :Simultaneous,
|
70
|
-
autoload :Site,
|
71
|
-
autoload :State,
|
72
|
-
autoload :Storage,
|
73
|
-
autoload :Style,
|
74
|
-
autoload :Utils,
|
42
|
+
autoload :Application, "spontaneous/application"
|
43
|
+
autoload :Asset, "spontaneous/asset"
|
44
|
+
autoload :Box, "spontaneous/box"
|
45
|
+
autoload :BoxStyle, "spontaneous/box_style"
|
46
|
+
autoload :Change, "spontaneous/change"
|
47
|
+
autoload :Cli, "spontaneous/cli"
|
48
|
+
autoload :Config, "spontaneous/config"
|
49
|
+
autoload :ContentQuery, "spontaneous/content_query"
|
50
|
+
autoload :Crypt, "spontaneous/crypt"
|
51
|
+
autoload :DataMapper, "spontaneous/data_mapper"
|
52
|
+
autoload :Facet, "spontaneous/facet"
|
53
|
+
autoload :Field, "spontaneous/field"
|
54
|
+
autoload :Generators, "spontaneous/generators"
|
55
|
+
autoload :Layout, "spontaneous/layout"
|
56
|
+
autoload :Media, "spontaneous/media"
|
57
|
+
autoload :Output, "spontaneous/output"
|
58
|
+
autoload :PagePiece, "spontaneous/page_piece"
|
59
|
+
autoload :PageLock, "spontaneous/page_lock"
|
60
|
+
autoload :Paths, "spontaneous/paths"
|
61
|
+
autoload :Permissions, "spontaneous/permissions"
|
62
|
+
autoload :PublishedRevision, "spontaneous/published_revision"
|
63
|
+
autoload :Publishing, "spontaneous/publishing"
|
64
|
+
autoload :Rack, "spontaneous/rack"
|
65
|
+
autoload :Revision, "spontaneous/revision"
|
66
|
+
autoload :Schema, "spontaneous/schema"
|
67
|
+
autoload :Search, "spontaneous/search"
|
68
|
+
autoload :Server, "spontaneous/server"
|
69
|
+
autoload :Simultaneous, "spontaneous/simultaneous"
|
70
|
+
autoload :Site, "spontaneous/site"
|
71
|
+
autoload :State, "spontaneous/state"
|
72
|
+
autoload :Storage, "spontaneous/storage"
|
73
|
+
autoload :Style, "spontaneous/style"
|
74
|
+
autoload :Utils, "spontaneous/utils"
|
75
75
|
|
76
76
|
module Prototypes
|
77
77
|
autoload :BoxPrototype, "spontaneous/prototypes/box_prototype"
|
@@ -85,6 +85,7 @@ module Spontaneous
|
|
85
85
|
autoload :ChangeSet, "spontaneous/collections/change_set"
|
86
86
|
autoload :EntrySet, "spontaneous/collections/entry_set"
|
87
87
|
autoload :FieldSet, "spontaneous/collections/field_set"
|
88
|
+
autoload :HashWithFallback, "spontaneous/collections/hash_with_fallback"
|
88
89
|
autoload :PrototypeSet, "spontaneous/collections/prototype_set"
|
89
90
|
autoload :StyleSet, "spontaneous/collections/style_set"
|
90
91
|
end
|
@@ -108,6 +109,7 @@ module Spontaneous
|
|
108
109
|
include Plugins::Application::Serialisation
|
109
110
|
include Plugins::Application::Features
|
110
111
|
include Plugins::Application::System
|
112
|
+
extend Revision::GlobalMethods
|
111
113
|
end
|
112
114
|
|
113
115
|
Dir["#{File.expand_path("../spontaneous", __FILE__)}/extensions/*.rb"].each { |file| require file }
|