card 1.17.4 → 1.18.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/card.gemspec +24 -25
- data/config/initializers/01_init_ruby_extensions.rb +0 -4
- data/config/initializers/inflections.rb +1 -1
- data/config/initializers/notification.rb +2 -2
- data/db/migrate/20110511221913_require_earlier_migrations.rb +3 -3
- data/db/migrate/20120105203350_require_1_8_migrations.rb +3 -3
- data/db/migrate/20121111025347_require_1_10_migrations.rb +3 -3
- data/db/migrate/20130106052640_table_cleanup.rb +4 -4
- data/db/migrate/20130411210957_update_codenames.rb +2 -2
- data/db/migrate/20141001105348_move_revisions_to_actions.rb +4 -4
- data/db/migrate/20141121172918_rename_card_migration_table.rb +2 -2
- data/db/migrate/20141208132159_remove_present_from_reference_table.rb +2 -2
- data/db/migrate/20141216053032_better_index_names.rb +9 -9
- data/db/migrate_core_cards/20120611203506_rails_inflection_updates.rb +29 -32
- data/db/migrate_core_cards/20130411191151_renaming_for_menu.rb +3 -4
- data/db/migrate_core_cards/20130411211600_delete_old_related_tab_cards.rb +1 -1
- data/db/migrate_core_cards/20130419215612_import_help_text.rb +1 -2
- data/db/migrate_core_cards/20130823192433_add_style_cards.rb +3 -3
- data/db/migrate_core_cards/20130910183318_move_styles_to_content.rb +2 -3
- data/db/migrate_core_cards/20130920214038_jsonize_tinymce.rb +2 -2
- data/db/migrate_core_cards/20130920291703_update_stylesheets.rb +1 -2
- data/db/migrate_core_cards/20130927191728_account_events.rb +5 -6
- data/db/migrate_core_cards/20131016172445_common_css_patch.rb +2 -3
- data/db/migrate_core_cards/20140110193325_reset_account_request_type.rb +0 -1
- data/db/migrate_core_cards/20140307231621_user_data_to_cards.rb +23 -32
- data/db/migrate_core_cards/20140317035504_account_requests_to_signups.rb +1 -7
- data/db/migrate_core_cards/20140512155840_add_script_cards.rb +21 -24
- data/db/migrate_core_cards/20140629222005_add_email_cards.rb +17 -22
- data/db/migrate_core_cards/20140725180118_config_card_updates.rb +2 -2
- data/db/migrate_core_cards/20141111083921_delete_machine_output.rb +1 -3
- data/db/migrate_core_cards/20141115034214_config_descriptions_etc.rb +2 -2
- data/db/migrate_core_cards/20141119001955_make_symlinks_relative.rb +3 -3
- data/db/migrate_core_cards/20141120120605_fix_notification_html_message.rb +1 -1
- data/db/migrate_core_cards/20141204061304_watchers_to_following.rb +8 -12
- data/db/migrate_core_cards/20141208162106_add_ace_script.rb +2 -3
- data/db/migrate_core_cards/20141216155251_add_more_following_cards.rb +10 -10
- data/db/migrate_core_cards/20150202143810_import_bootstrap_layout.rb +10 -12
- data/db/migrate_core_cards/20150220134731_following_to_follow_rule.rb +4 -4
- data/db/migrate_core_cards/20150317162412_bootstrap_themes.rb +3 -3
- data/db/migrate_core_cards/20150326205655_bootswatch_themes.rb +7 -7
- data/db/migrate_core_cards/20150429090551_search_card_context.rb +18 -20
- data/db/migrate_core_cards/20150508212032_menu_compatibility.rb +3 -7
- data/db/migrate_core_cards/20150510031118_fix_skin_images.rb +2 -3
- data/db/migrate_core_cards/20150528084659_add_session_cardtype.rb +3 -3
- data/db/migrate_core_cards/20150601133433_add_recent_setting_session_card.rb +4 -4
- data/db/migrate_core_cards/20150610171702_add_debugger_session_card.rb +4 -4
- data/db/migrate_core_cards/20150610180019_add_recaptcha_key_and_admin_info_cards.rb +5 -11
- data/db/migrate_core_cards/20150724123438_update_file_and_image_cards.rb +29 -35
- data/db/migrate_core_cards/20150824135418_update_file_history.rb +10 -14
- data/db/migrate_core_cards/20150903130006_attachment_upload_cards.rb +1 -1
- data/db/schema.rb +92 -94
- data/db/seed/new/card_actions.yml +461 -469
- data/db/seed/new/card_acts.yml +154 -172
- data/db/seed/new/card_changes.yml +4076 -4031
- data/db/seed/new/card_references.yml +1584 -1927
- data/db/seed/new/cards.yml +2095 -2112
- data/db/seed/test/fixtures/card_actions.yml +1497 -1505
- data/db/seed/test/fixtures/card_acts.yml +454 -472
- data/db/seed/test/fixtures/card_changes.yml +7309 -7263
- data/db/seed/test/fixtures/card_references.yml +2263 -2613
- data/db/seed/test/fixtures/cards.yml +3298 -3316
- data/db/seed/test/seed.rb +3 -0
- data/lib/card.rb +17 -9
- data/lib/card/active_record_ext.rb +6 -8
- data/lib/card/active_record_helper.rb +42 -32
- data/lib/card/auth.rb +3 -3
- data/lib/card/cache.rb +4 -4
- data/lib/card/cache/persistent.rb +9 -5
- data/lib/card/cache/temporary.rb +5 -5
- data/lib/card/chunk.rb +1 -1
- data/lib/card/codename.rb +3 -2
- data/lib/card/content.rb +62 -57
- data/lib/card/core_ext.rb +20 -30
- data/lib/card/diff.rb +88 -76
- data/lib/card/director_register.rb +66 -0
- data/lib/card/env.rb +14 -17
- data/lib/card/exceptions.rb +7 -9
- data/lib/card/format.rb +18 -367
- data/lib/card/format/nest.rb +183 -0
- data/lib/card/format/permission.rb +63 -0
- data/lib/card/format/render.rb +140 -0
- data/lib/card/loader.rb +17 -26
- data/lib/card/location.rb +6 -6
- data/lib/card/mailer.rb +4 -7
- data/lib/card/migration.rb +1 -1
- data/lib/card/name.rb +3 -6
- data/lib/card/query.rb +8 -8
- data/lib/card/query/attributes.rb +6 -6
- data/lib/card/query/clause.rb +10 -10
- data/lib/card/query/join.rb +7 -9
- data/lib/card/query/reference.rb +17 -19
- data/lib/card/query/sql_statement.rb +2 -2
- data/lib/card/query/value.rb +15 -16
- data/lib/card/set.rb +106 -209
- data/lib/card/set/event.rb +126 -0
- data/lib/card/set_pattern.rb +42 -29
- data/lib/card/simplecov_helper.rb +19 -19
- data/lib/card/spec_helper.rb +40 -16
- data/lib/card/stage.rb +72 -0
- data/lib/card/stage_director.rb +231 -0
- data/lib/card/subcards.rb +56 -24
- data/lib/card/subdirector_array.rb +31 -0
- data/lib/card/success.rb +15 -18
- data/lib/card/version.rb +1 -2
- data/lib/card/view_cache.rb +4 -4
- data/lib/card/view_name.rb +10 -8
- data/lib/cardio.rb +1 -1
- data/lib/generators/card.rb +2 -4
- data/lib/generators/card/format/format_generator.rb +4 -4
- data/lib/generators/card/migration/migration_generator.rb +6 -6
- data/lib/generators/card/set/set_generator.rb +5 -6
- data/mod/01_core/chunk/include.rb +2 -1
- data/mod/01_core/chunk/link.rb +2 -2
- data/mod/01_core/chunk/literal.rb +6 -9
- data/mod/01_core/chunk/query_reference.rb +1 -1
- data/mod/01_core/chunk/reference.rb +2 -2
- data/mod/01_core/chunk/uri.rb +52 -63
- data/mod/01_core/format/html_format.rb +8 -12
- data/mod/01_core/format/text_format.rb +1 -1
- data/mod/01_core/set/all/actify.rb +96 -0
- data/mod/01_core/set/all/active_card.rb +7 -7
- data/mod/01_core/set/all/collection.rb +19 -20
- data/mod/01_core/set/all/content.rb +9 -7
- data/mod/01_core/set/all/erb.rb +5 -5
- data/mod/01_core/set/all/event.rb +60 -0
- data/mod/01_core/set/all/fetch.rb +13 -19
- data/mod/01_core/set/all/haml.rb +1 -1
- data/mod/01_core/set/all/initialize.rb +35 -41
- data/mod/01_core/set/all/location_history.rb +3 -5
- data/mod/01_core/set/all/name.rb +19 -68
- data/mod/01_core/set/all/name_validations.rb +56 -0
- data/mod/01_core/set/all/pattern.rb +2 -2
- data/mod/01_core/set/all/permissions.rb +14 -20
- data/mod/01_core/set/all/phases.rb +9 -200
- data/mod/01_core/set/all/references.rb +10 -10
- data/mod/01_core/set/all/rules.rb +3 -4
- data/mod/01_core/set/all/stages.rb +24 -0
- data/mod/01_core/set/all/states.rb +4 -4
- data/mod/01_core/set/all/subcards.rb +16 -26
- data/mod/01_core/set/all/templating.rb +1 -3
- data/mod/01_core/set/all/tracked_attributes.rb +47 -48
- data/mod/01_core/set/all/trash.rb +10 -10
- data/mod/01_core/set/all/type.rb +9 -8
- data/mod/01_core/set/all/utils.rb +10 -14
- data/mod/01_core/set/all/view_cache.rb +2 -2
- data/mod/01_core/set_pattern/01_all.rb +3 -3
- data/mod/01_core/set_pattern/02_all_plus.rb +3 -3
- data/mod/01_core/set_pattern/03_type.rb +2 -2
- data/mod/01_core/set_pattern/04_star.rb +3 -3
- data/mod/01_core/set_pattern/05_rstar.rb +3 -3
- data/mod/01_core/set_pattern/06_right.rb +2 -2
- data/mod/01_core/set_pattern/07_type_plus_right.rb +2 -2
- data/mod/01_core/set_pattern/08_self.rb +1 -1
- data/mod/01_core/spec/chunk/literal_spec.rb +7 -8
- data/mod/01_core/spec/chunk/uri_spec.rb +140 -142
- data/mod/01_core/spec/format/html_format_spec.rb +72 -57
- data/mod/01_core/spec/set/all/collection_spec.rb +63 -43
- data/mod/01_core/spec/set/all/content_spec.rb +4 -4
- data/mod/01_core/spec/set/all/fetch_spec.rb +12 -3
- data/mod/01_core/spec/set/all/name_spec.rb +3 -4
- data/mod/01_core/spec/set/all/pattern_spec.rb +32 -35
- data/mod/01_core/spec/set/all/permissions_spec.rb +17 -5
- data/mod/01_core/spec/set/all/phases_spec.rb +0 -1
- data/mod/01_core/spec/set/all/references_spec.rb +1 -1
- data/mod/01_core/spec/set/all/rules2_spec.rb +79 -91
- data/mod/01_core/spec/set/all/rules_spec.rb +63 -56
- data/mod/01_core/spec/set/all/templating_spec.rb +0 -1
- data/mod/01_core/spec/set/all/tracked_attributes_spec.rb +4 -5
- data/mod/01_core/spec/set/all/trash_spec.rb +23 -1
- data/mod/01_core/spec/set/all/type_spec.rb +2 -5
- data/mod/01_history/lib/card/action.rb +8 -10
- data/mod/01_history/set/all/actions.rb +2 -4
- data/mod/01_history/set/all/content_history.rb +38 -32
- data/mod/01_history/set/all/history.rb +20 -17
- data/mod/02_basic_types/format/rss_format.rb +0 -1
- data/mod/02_basic_types/set/all/all_css.rb +9 -13
- data/mod/02_basic_types/set/all/all_csv.rb +14 -17
- data/mod/02_basic_types/set/all/all_js.rb +3 -4
- data/mod/02_basic_types/set/all/base.rb +2 -2
- data/mod/02_basic_types/set/all/file.rb +2 -5
- data/mod/02_basic_types/set/all/json.rb +19 -18
- data/mod/02_basic_types/set/all/rss.rb +3 -3
- data/mod/02_basic_types/set/all/text.rb +1 -3
- data/mod/02_basic_types/set/type/html.rb +4 -8
- data/mod/02_basic_types/set/type/plain_text.rb +2 -3
- data/mod/02_basic_types/set/type/pointer.rb +82 -92
- data/mod/02_basic_types/spec/set/all/all_css_spec.rb +2 -2
- data/mod/02_basic_types/spec/set/all/all_csv_spec.rb +6 -4
- data/mod/02_basic_types/spec/set/all/base_spec.rb +6 -6
- data/mod/02_basic_types/spec/set/all/json_spec.rb +8 -8
- data/mod/02_basic_types/spec/set/type/plain_text_spec.rb +3 -3
- data/mod/02_basic_types/spec/set/type/pointer_spec.rb +29 -32
- data/mod/03_machines/lib/card/machine.rb +95 -81
- data/mod/03_machines/lib/card/machine_input.rb +35 -34
- data/mod/03_machines/set/right/machine_input.rb +1 -1
- data/mod/03_machines/set/self/script_ace.rb +2 -3
- data/mod/03_machines/set/self/script_card_menu.rb +2 -3
- data/mod/03_machines/set/self/script_jquery_helper.rb +2 -2
- data/mod/03_machines/set/self/script_slot.rb +2 -2
- data/mod/03_machines/set/self/style_bootstrap_compatible.rb +1 -1
- data/mod/03_machines/set/self/style_cards.rb +1 -1
- data/mod/03_machines/set/self/style_jquery_ui_smoothness.rb +0 -1
- data/mod/03_machines/set/type/coffee_script.rb +9 -13
- data/mod/03_machines/set/type/css.rb +12 -13
- data/mod/03_machines/set/type/java_script.rb +6 -8
- data/mod/03_machines/set/type/scss.rb +4 -5
- data/mod/03_machines/set/type/skin.rb +3 -6
- data/mod/03_machines/spec/lib/shared_machine_examples.rb +31 -38
- data/mod/03_machines/spec/lib/shared_machine_input_examples.rb +7 -8
- data/mod/03_machines/spec/set/type/coffeescript_spec.rb +19 -13
- data/mod/03_machines/spec/set/type/css_spec.rb +22 -16
- data/mod/03_machines/spec/set/type/scss_spec.rb +28 -21
- data/mod/03_machines/spec/set/type/skin_spec.rb +28 -30
- data/mod/04_settings/lib/card/setting.rb +4 -4
- data/mod/04_settings/set/abstract/permission.rb +30 -37
- data/mod/04_settings/set/right/add_help.rb +3 -3
- data/mod/04_settings/set/right/script.rb +4 -5
- data/mod/04_settings/set/right/structure.rb +3 -4
- data/mod/04_settings/set/right/style.rb +3 -3
- data/mod/04_settings/set/self/add_help.rb +1 -1
- data/mod/04_settings/set/self/input.rb +1 -1
- data/mod/04_settings/set/self/on_create.rb +1 -1
- data/mod/04_settings/set/self/options.rb +1 -1
- data/mod/04_settings/set/self/options_label.rb +1 -1
- data/mod/04_settings/set/type/setting.rb +29 -44
- data/mod/04_settings/spec/set/right/comment_spec.rb +9 -12
- data/mod/04_settings/spec/set/right/script_spec.rb +7 -7
- data/mod/04_settings/spec/set/right/structure_spec.rb +13 -12
- data/mod/04_settings/spec/set/right/style_spec.rb +13 -13
- data/mod/04_settings/spec/set/type/setting_spec.rb +1 -1
- data/mod/05_email/format/email_html_format.rb +1 -1
- data/mod/05_email/format/email_text_format.rb +2 -2
- data/mod/05_email/lib/card/follow_option.rb +12 -15
- data/mod/05_email/set/all/email_html.rb +2 -3
- data/mod/05_email/set/all/email_text.rb +3 -3
- data/mod/05_email/set/all/follow.rb +14 -22
- data/mod/05_email/set/all/notify.rb +11 -11
- data/mod/05_email/set/all/observer.rb +7 -8
- data/mod/05_email/set/right/bcc.rb +4 -9
- data/mod/05_email/set/right/follow.rb +26 -39
- data/mod/05_email/set/right/follow_fields.rb +2 -2
- data/mod/05_email/set/right/followers.rb +3 -1
- data/mod/05_email/set/right/following.rb +13 -16
- data/mod/05_email/set/self/always.rb +1 -2
- data/mod/05_email/set/self/created.rb +4 -6
- data/mod/05_email/set/self/edited.rb +3 -7
- data/mod/05_email/set/self/follow_defaults.rb +11 -12
- data/mod/05_email/set/self/never.rb +2 -4
- data/mod/05_email/set/type/email_template.rb +40 -27
- data/mod/05_email/set/type_plus_right/user/follow.rb +159 -157
- data/mod/05_email/spec/set/all/follow_spec.rb +28 -37
- data/mod/05_email/spec/set/all/notify_spec.rb +21 -26
- data/mod/05_email/spec/set/all/observer_spec.rb +58 -37
- data/mod/05_email/spec/set/right/followers_spec.rb +9 -14
- data/mod/05_email/spec/set/right/following_spec.rb +1 -1
- data/mod/05_email/spec/set/self/follow_defaults_spec.rb +1 -1
- data/mod/05_standard/lib/carrier_wave/cardmount.rb +9 -9
- data/mod/05_standard/lib/file_uploader.rb +8 -13
- data/mod/05_standard/lib/image_uploader.rb +8 -9
- data/mod/05_standard/set/abstract/attachment.rb +26 -43
- data/mod/05_standard/set/all/account.rb +2 -2
- data/mod/05_standard/set/all/comment.rb +11 -13
- data/mod/05_standard/set/all/error.rb +18 -18
- data/mod/05_standard/set/all/event_viz.rb +16 -29
- data/mod/05_standard/set/all/links.rb +35 -34
- data/mod/05_standard/set/all/list_changes.rb +10 -12
- data/mod/05_standard/set/all/rich_html/content.rb +13 -13
- data/mod/05_standard/set/all/rich_html/editing.rb +5 -5
- data/mod/05_standard/set/all/rich_html/form.rb +22 -26
- data/mod/05_standard/set/all/rich_html/header.rb +18 -25
- data/mod/05_standard/set/all/rich_html/menu.rb +20 -22
- data/mod/05_standard/set/all/rich_html/modal.rb +3 -3
- data/mod/05_standard/set/all/rich_html/toolbar.rb +49 -58
- data/mod/05_standard/set/all/rich_html/wrapper.rb +40 -41
- data/mod/05_standard/set/right/account.rb +26 -14
- data/mod/05_standard/set/right/email.rb +2 -2
- data/mod/05_standard/set/right/password.rb +6 -5
- data/mod/05_standard/set/right/salt.rb +2 -2
- data/mod/05_standard/set/right/stats.rb +17 -20
- data/mod/05_standard/set/right/token.rb +1 -1
- data/mod/05_standard/set/right/when_created.rb +1 -1
- data/mod/05_standard/set/right/when_last_edited.rb +1 -1
- data/mod/05_standard/set/rstar/rules.rb +3 -3
- data/mod/05_standard/set/rstar/rules_editor.rb +39 -39
- data/mod/05_standard/set/self/account_links.rb +21 -22
- data/mod/05_standard/set/self/admin_info.rb +5 -5
- data/mod/05_standard/set/self/alerts.rb +1 -1
- data/mod/05_standard/set/self/all.rb +1 -1
- data/mod/05_standard/set/self/foot.rb +1 -1
- data/mod/05_standard/set/self/head.rb +19 -22
- data/mod/05_standard/set/self/navbox.rb +3 -7
- data/mod/05_standard/set/self/now.rb +1 -1
- data/mod/05_standard/set/self/recent.rb +19 -25
- data/mod/05_standard/set/self/search.rb +2 -4
- data/mod/05_standard/set/self/signin.rb +6 -6
- data/mod/05_standard/set/self/stats.rb +31 -38
- data/mod/05_standard/set/self/version.rb +1 -2
- data/mod/05_standard/set/type/basic.rb +15 -17
- data/mod/05_standard/set/type/cardtype.rb +3 -3
- data/mod/05_standard/set/type/date.rb +1 -2
- data/mod/05_standard/set/type/file.rb +22 -33
- data/mod/05_standard/set/type/image.rb +30 -23
- data/mod/05_standard/set/type/layout_type.rb +4 -4
- data/mod/05_standard/set/type/list.rb +32 -38
- data/mod/05_standard/set/type/listed_by.rb +11 -13
- data/mod/05_standard/set/type/number.rb +5 -6
- data/mod/05_standard/set/type/phrase.rb +1 -1
- data/mod/05_standard/set/type/search_type.rb +25 -23
- data/mod/05_standard/set/type/session.rb +2 -3
- data/mod/05_standard/set/type/set.rb +46 -51
- data/mod/05_standard/set/type/signup.rb +18 -19
- data/mod/05_standard/set/type/toggle.rb +5 -5
- data/mod/05_standard/set/type/user.rb +6 -6
- data/mod/05_standard/spec/chunk/include_spec.rb +115 -98
- data/mod/05_standard/spec/chunk/link_spec.rb +58 -31
- data/mod/05_standard/spec/chunk/query_reference_spec.rb +12 -14
- data/mod/05_standard/spec/set/all/email_html_spec.rb +3 -3
- data/mod/05_standard/spec/set/all/error_spec.rb +3 -3
- data/mod/05_standard/spec/set/all/history_spec.rb +52 -38
- data/mod/05_standard/spec/set/all/links_spec.rb +2 -2
- data/mod/05_standard/spec/set/all/rich_html/editing_spec.rb +0 -1
- data/mod/05_standard/spec/set/all/rich_html/form_spec.rb +11 -11
- data/mod/05_standard/spec/set/all/rich_html/wrapper_spec.rb +4 -4
- data/mod/05_standard/spec/set/right/email_spec.rb +1 -4
- data/mod/05_standard/spec/set/right/password_spec.rb +4 -7
- data/mod/05_standard/spec/set/right/stats_spec.rb +2 -3
- data/mod/05_standard/spec/set/right/when_created_spec.rb +1 -1
- data/mod/05_standard/spec/set/right/when_last_edited_spec.rb +1 -1
- data/mod/05_standard/spec/set/rstar/rules_spec.rb +6 -6
- data/mod/05_standard/spec/set/self/all_spec.rb +11 -13
- data/mod/05_standard/spec/set/self/head_spec.rb +1 -3
- data/mod/05_standard/spec/set/self/navbox_spec.rb +1 -1
- data/mod/05_standard/spec/set/self/now_spec.rb +2 -2
- data/mod/05_standard/spec/set/self/signin_spec.rb +1 -1
- data/mod/05_standard/spec/set/self/stats_spec.rb +1 -1
- data/mod/05_standard/spec/set/self/version_spec.rb +2 -2
- data/mod/05_standard/spec/set/type/cardtype_spec.rb +3 -4
- data/mod/05_standard/spec/set/type/date_spec.rb +1 -1
- data/mod/05_standard/spec/set/type/email_template_spec.rb +5 -5
- data/mod/05_standard/spec/set/type/file_spec.rb +50 -28
- data/mod/05_standard/spec/set/type/html_spec.rb +12 -7
- data/mod/05_standard/spec/set/type/image_spec.rb +55 -45
- data/mod/05_standard/spec/set/type/layout_type_spec.rb +2 -2
- data/mod/05_standard/spec/set/type/listed_by_spec.rb +2 -2
- data/mod/05_standard/spec/set/type/number_spec.rb +1 -1
- data/mod/05_standard/spec/set/type/phrase_spec.rb +1 -1
- data/mod/05_standard/spec/set/type/search_type_spec.rb +15 -16
- data/mod/05_standard/spec/set/type/set_spec.rb +16 -17
- data/mod/05_standard/spec/set/type/signup_spec.rb +7 -5
- data/mod/05_standard/spec/set/type/toggle_spec.rb +4 -4
- data/mod/05_standard/spec/set/type/uri_spec.rb +11 -11
- data/mod/05_standard/spec/set/type/user_spec.rb +0 -1
- data/mod/06_bootstrap/set/all/bootstrap/form.rb +9 -10
- data/mod/06_bootstrap/set/all/bootstrap/helper.rb +22 -27
- data/mod/06_bootstrap/set/all/bootstrap/wrapper.rb +1 -2
- data/mod/06_bootstrap/set/all/rich_bootstrap.rb +1 -3
- data/mod/06_bootstrap/set/self/bootstrap_cards.rb +2 -2
- data/mod/06_bootstrap/set/self/bootstrap_js.rb +2 -2
- data/mod/06_bootstrap/set/self/bootswatch_shared.rb +19 -19
- data/mod/06_bootstrap/set/self/smartmenu_css.rb +2 -2
- data/mod/06_bootstrap/set/self/smartmenu_js.rb +3 -3
- data/mod/06_bootstrap/spec/set/all/bootstrap/form_spec.rb +5 -5
- data/spec/lib/card/action_spec.rb +4 -4
- data/spec/lib/card/cache_spec.rb +3 -5
- data/spec/lib/card/chunk_spec.rb +6 -8
- data/spec/lib/card/codename_spec.rb +4 -6
- data/spec/lib/card/content_spec.rb +12 -17
- data/spec/lib/card/diff_spec.rb +59 -61
- data/spec/lib/card/format_spec.rb +55 -34
- data/spec/lib/card/loader_spec.rb +35 -37
- data/spec/lib/card/name_spec.rb +159 -145
- data/spec/lib/card/query_spec.rb +4 -4
- data/spec/lib/card/reference_spec.rb +24 -24
- data/spec/lib/card/set_pattern_spec.rb +3 -3
- data/spec/lib/card/stage_director_spec.rb +218 -0
- data/spec/lib/card/subcards_spec.rb +12 -16
- data/spec/lib/card/success_spec.rb +16 -18
- data/spec/lib/card/view_cache_spec.rb +1 -1
- data/spec/mailers/mailer_spec.rb +3 -5
- data/spec/models/card/cardtype_spec.rb +40 -51
- data/spec/models/card/create_spec.rb +58 -39
- data/spec/models/card/trash_spec.rb +23 -32
- data/spec/models/card/type_transition_spec.rb +41 -32
- data/spec/models/card/validation_spec.rb +13 -15
- data/spec/models/card_spec.rb +48 -59
- data/spec/spec_helper.rb +26 -31
- metadata +16 -2
@@ -17,25 +17,25 @@ module CarrierWave
|
|
17
17
|
super
|
18
18
|
|
19
19
|
class_eval <<-RUBY, __FILE__, __LINE__ + 1
|
20
|
-
event :store_#{column}_event,
|
20
|
+
event :store_#{column}_event, :finalize, on: :save do
|
21
21
|
store_#{column}!
|
22
22
|
end
|
23
23
|
|
24
24
|
# remove files only if card has no history
|
25
|
-
event :remove_#{column}_event,
|
26
|
-
on: :delete,
|
25
|
+
event :remove_#{column}_event, :finalize,
|
26
|
+
on: :delete, when: proc { |c| !c.history? } do
|
27
27
|
remove_#{column}!
|
28
28
|
end
|
29
|
-
event :mark_remove_#{column}_false_event,
|
30
|
-
on: :update
|
29
|
+
event :mark_remove_#{column}_false_event, :finalize,
|
30
|
+
on: :update do
|
31
31
|
mark_remove_#{column}_false
|
32
32
|
end
|
33
|
-
event :store_previous_model_for_#{column}_event,
|
34
|
-
on: :update,
|
33
|
+
event :store_previous_model_for_#{column}_event, :store,
|
34
|
+
on: :update, when: proc { |c| !c.history? } do
|
35
35
|
store_previous_model_for_#{column}
|
36
36
|
end
|
37
|
-
event :remove_previously_stored_#{column}_event,
|
38
|
-
on: :update,
|
37
|
+
event :remove_previously_stored_#{column}_event, :store,
|
38
|
+
on: :update, when: proc { |c| !c.history?} do
|
39
39
|
if @previous_model_for_#{column}
|
40
40
|
@previous_model_for_#{column}.include_set_modules
|
41
41
|
end
|
@@ -60,25 +60,22 @@ class FileUploader < CarrierWave::Uploader::Base
|
|
60
60
|
|
61
61
|
# generate identifier that gets stored in the card's db_content field
|
62
62
|
def db_content opts={}
|
63
|
-
|
64
|
-
|
65
|
-
end
|
63
|
+
return '' unless file.present?
|
64
|
+
model.load_from_mod = opts[:mod] if opts[:mod] && !model.load_from_mod
|
66
65
|
'%s/%s' % [file_dir, url_filename(opts)]
|
67
66
|
end
|
68
67
|
|
69
68
|
def url_filename opts={}
|
70
|
-
if opts[:mod] && !model.load_from_mod
|
71
|
-
model.load_from_mod = opts[:mod]
|
72
|
-
end
|
69
|
+
model.load_from_mod = opts[:mod] if opts[:mod] && !model.load_from_mod
|
73
70
|
|
74
71
|
basename = if (mod = mod_file?)
|
75
|
-
|
76
|
-
|
77
|
-
|
72
|
+
"#{mod}#{extension}"
|
73
|
+
else
|
74
|
+
"#{action_id}#{extension}"
|
78
75
|
end
|
79
76
|
end
|
80
77
|
|
81
|
-
def url opts
|
78
|
+
def url opts={}
|
82
79
|
'%s/%s/%s' % [card_path(Card.config.files_web_path), file_dir,
|
83
80
|
full_filename(url_filename(opts))]
|
84
81
|
end
|
@@ -115,9 +112,7 @@ class FileUploader < CarrierWave::Uploader::Base
|
|
115
112
|
end
|
116
113
|
|
117
114
|
def tmp_path
|
118
|
-
|
119
|
-
Dir.mkdir model.tmp_upload_dir
|
120
|
-
end
|
115
|
+
Dir.mkdir model.tmp_upload_dir unless Dir.exist? model.tmp_upload_dir
|
121
116
|
File.join model.tmp_upload_dir, filename
|
122
117
|
end
|
123
118
|
|
@@ -3,28 +3,29 @@ require 'mini_magick'
|
|
3
3
|
class ImageUploader < FileUploader
|
4
4
|
include CarrierWave::MiniMagick
|
5
5
|
|
6
|
-
def path
|
6
|
+
def path version=nil
|
7
7
|
(version && version != :original) ? versions[version].path : super()
|
8
8
|
end
|
9
9
|
|
10
10
|
version :icon, if: :create_versions?, from_version: :small do
|
11
|
-
process resize_and_pad: [16,16]
|
11
|
+
process resize_and_pad: [16, 16]
|
12
12
|
end
|
13
13
|
version :small, if: :create_versions?, from_version: :medium do
|
14
|
-
process resize_to_fit: [75,75]
|
14
|
+
process resize_to_fit: [75, 75]
|
15
15
|
end
|
16
16
|
version :medium, if: :create_versions? do
|
17
|
-
process resize_to_fit: [200,200]
|
17
|
+
process resize_to_fit: [200, 200]
|
18
18
|
end
|
19
19
|
version :large, if: :create_versions? do
|
20
|
-
process resize_to_fit: [500,500]
|
20
|
+
process resize_to_fit: [500, 500]
|
21
21
|
end
|
22
22
|
|
23
23
|
def identifier
|
24
24
|
full_filename(super())
|
25
25
|
end
|
26
|
+
|
26
27
|
# add 'original' if no version is given
|
27
|
-
def full_filename
|
28
|
+
def full_filename for_file
|
28
29
|
name = super(for_file)
|
29
30
|
if version_name
|
30
31
|
name
|
@@ -33,6 +34,4 @@ class ImageUploader < FileUploader
|
|
33
34
|
"#{parts.shift}-original.#{parts.join('.')}"
|
34
35
|
end
|
35
36
|
end
|
36
|
-
|
37
|
-
|
38
|
-
end
|
37
|
+
end
|
@@ -8,8 +8,8 @@ event :select_file_revision, after: :select_action do
|
|
8
8
|
attachment.retrieve_from_store!(attachment.identifier)
|
9
9
|
end
|
10
10
|
|
11
|
-
event :upload_attachment,
|
12
|
-
|
11
|
+
event :upload_attachment, :prepare_to_validate,
|
12
|
+
on: :save, when: proc { |c| c.preliminary_upload? } do
|
13
13
|
save_original_filename # save original filename as comment in action
|
14
14
|
write_identifier # set db_content
|
15
15
|
# (needs original filename to determine extension)
|
@@ -27,9 +27,8 @@ event :upload_attachment, before: :validate_name, on: :save,
|
|
27
27
|
abort :success
|
28
28
|
end
|
29
29
|
|
30
|
-
event :assign_attachment_on_create,
|
31
|
-
after: :
|
32
|
-
on: :create,
|
30
|
+
event :assign_attachment_on_create, :initialize,
|
31
|
+
after: :assign_action, on: :create,
|
33
32
|
when: proc { |c| c.save_preliminary_upload? } do
|
34
33
|
if (action = Card::Action.fetch(@action_id_of_cached_upload))
|
35
34
|
upload_cache_card.selected_action_id = action.id
|
@@ -38,15 +37,14 @@ event :assign_attachment_on_create,
|
|
38
37
|
end
|
39
38
|
end
|
40
39
|
|
41
|
-
event :assign_attachment_on_update,
|
42
|
-
after: :
|
43
|
-
on: :update,
|
40
|
+
event :assign_attachment_on_update, :initialize,
|
41
|
+
after: :assign_action, on: :update,
|
44
42
|
when: proc { |c| c.save_preliminary_upload? } do
|
45
43
|
if (action = Card::Action.fetch(@action_id_of_cached_upload))
|
46
44
|
uploaded_file =
|
47
|
-
|
48
|
-
|
49
|
-
|
45
|
+
with_selected_action_id(action.id) do
|
46
|
+
attachment.file
|
47
|
+
end
|
50
48
|
assign_attachment uploaded_file, action.comment
|
51
49
|
end
|
52
50
|
end
|
@@ -59,7 +57,7 @@ end
|
|
59
57
|
|
60
58
|
# we need a card id for the path so we have to update db_content when we have
|
61
59
|
# an id
|
62
|
-
event :correct_identifier,
|
60
|
+
event :correct_identifier, :finalize, on: :create do
|
63
61
|
update_column(:db_content, attachment.db_content(mod: load_from_mod))
|
64
62
|
expire
|
65
63
|
end
|
@@ -71,16 +69,14 @@ def file_ready_to_save?
|
|
71
69
|
attachment_changed?
|
72
70
|
end
|
73
71
|
|
74
|
-
event :save_original_filename,
|
75
|
-
|
72
|
+
event :save_original_filename, :prepare_to_store,
|
73
|
+
when: proc { |c| c.file_ready_to_save? } do
|
76
74
|
return unless @current_action
|
77
75
|
@current_action.update_attributes! comment: original_filename
|
78
76
|
end
|
79
77
|
|
80
|
-
event :delete_cached_upload_file_on_create,
|
81
|
-
|
82
|
-
on: :create,
|
83
|
-
when: proc { |c| c.save_preliminary_upload? } do
|
78
|
+
event :delete_cached_upload_file_on_create, :integrate,
|
79
|
+
on: :create, when: proc { |c| c.save_preliminary_upload? } do
|
84
80
|
if (action = Card::Action.fetch(@action_id_of_cached_upload))
|
85
81
|
upload_cache_card.delete_files_for_action action
|
86
82
|
action.delete
|
@@ -88,17 +84,15 @@ event :delete_cached_upload_file_on_create,
|
|
88
84
|
clear_upload_cache_dir_for_new_cards
|
89
85
|
end
|
90
86
|
|
91
|
-
event :delete_cached_upload_file_on_update,
|
92
|
-
|
93
|
-
on: :update,
|
94
|
-
when: proc { |c| c.save_preliminary_upload? } do
|
87
|
+
event :delete_cached_upload_file_on_update, :integrate,
|
88
|
+
on: :update, when: proc { |c| c.save_preliminary_upload? } do
|
95
89
|
if (action = Card::Action.fetch(@action_id_of_cached_upload))
|
96
90
|
delete_files_for_action action
|
97
91
|
action.delete
|
98
92
|
end
|
99
93
|
end
|
100
94
|
|
101
|
-
event :validate_file_exist,
|
95
|
+
event :validate_file_exist, :validate, on: :create do
|
102
96
|
unless attachment.file.present? || empty_ok?
|
103
97
|
errors.add attachment_name, 'is missing'
|
104
98
|
end
|
@@ -142,17 +136,11 @@ def upload_cache_card
|
|
142
136
|
end
|
143
137
|
|
144
138
|
# action id of the cached upload
|
145
|
-
|
146
|
-
@action_id_of_cached_upload = value
|
147
|
-
end
|
139
|
+
attr_writer :action_id_of_cached_upload
|
148
140
|
|
149
|
-
|
150
|
-
@action_id_of_cached_upload
|
151
|
-
end
|
141
|
+
attr_reader :action_id_of_cached_upload
|
152
142
|
|
153
|
-
|
154
|
-
@empty_ok = value
|
155
|
-
end
|
143
|
+
attr_writer :empty_ok
|
156
144
|
|
157
145
|
def empty_ok?
|
158
146
|
@empty_ok
|
@@ -203,9 +191,7 @@ def mod_dir
|
|
203
191
|
mod = @mod || mod_file?
|
204
192
|
Card.paths['mod'].to_a.each do |mod_path|
|
205
193
|
dir = File.join(mod_path, mod, 'file', codename)
|
206
|
-
if Dir.exist? dir
|
207
|
-
return dir
|
208
|
-
end
|
194
|
+
return dir if Dir.exist? dir
|
209
195
|
end
|
210
196
|
end
|
211
197
|
|
@@ -215,7 +201,7 @@ def mod_file?
|
|
215
201
|
# when db_content was changed assume that it's no longer a mod file
|
216
202
|
elsif !db_content_changed? && content.present?
|
217
203
|
case content
|
218
|
-
when %r{^:[^/]+/([^.]+)} then
|
204
|
+
when %r{^:[^/]+/([^.]+)} then Regexp.last_match(1) # current mod_file format
|
219
205
|
when /^\~/ then false # current id file format
|
220
206
|
else
|
221
207
|
if (lines = content.split("\n")) && (lines.size == 4)
|
@@ -236,16 +222,13 @@ end
|
|
236
222
|
|
237
223
|
def clear_upload_cache_dir_for_new_cards
|
238
224
|
Dir.entries(tmp_upload_dir).each do |filename|
|
239
|
-
if filename
|
240
|
-
path = File.join(tmp_upload_dir, filename
|
241
|
-
if Card.older_than_five_days? File.ctime(path)
|
242
|
-
FileUtils.rm path
|
243
|
-
end
|
225
|
+
if filename =~ /^\d+/
|
226
|
+
path = File.join(tmp_upload_dir, filename)
|
227
|
+
FileUtils.rm path if Card.older_than_five_days? File.ctime(path)
|
244
228
|
end
|
245
229
|
end
|
246
230
|
end
|
247
231
|
|
248
|
-
|
249
232
|
def delete_files_for_action action
|
250
233
|
with_selected_action_id(action.id) do
|
251
234
|
FileUtils.rm attachment.file.path
|
@@ -278,7 +261,7 @@ end
|
|
278
261
|
|
279
262
|
def attachment_format ext
|
280
263
|
if ext.present? && attachment && (original_ext = attachment.extension)
|
281
|
-
if['file', original_ext].member? ext
|
264
|
+
if ['file', original_ext].member? ext
|
282
265
|
original_ext
|
283
266
|
elsif (exts = MIME::Types[attachment.content_type])
|
284
267
|
if exts.find { |mt| mt.extensions.member? ext }
|
@@ -51,7 +51,7 @@ def fetch_roles
|
|
51
51
|
Auth.as_bot do
|
52
52
|
role_trait = fetch trait: :roles
|
53
53
|
next [Card::AnyoneSignedInID] unless role_trait
|
54
|
-
[Card::AnyoneSignedInID] +
|
54
|
+
[Card::AnyoneSignedInID] + role_trait.item_ids
|
55
55
|
end
|
56
56
|
end
|
57
57
|
|
@@ -59,7 +59,7 @@ event :generate_token do
|
|
59
59
|
Digest::SHA1.hexdigest "--#{Time.zone.now.to_f}--#{rand 10}--"
|
60
60
|
end
|
61
61
|
|
62
|
-
event :set_stamper,
|
62
|
+
event :set_stamper, :prepare_to_validate do
|
63
63
|
self.updater_id = Auth.current_id
|
64
64
|
self.creator_id = updater_id if new_card?
|
65
65
|
end
|
@@ -1,4 +1,5 @@
|
|
1
|
-
event :add_comment,
|
1
|
+
event :add_comment, :prepare_to_store,
|
2
|
+
on: :save, when: proc { |c| c.comment } do
|
2
3
|
cleaned_comment =
|
3
4
|
comment.split(/\n/).map do |line|
|
4
5
|
"<p>#{line.strip.empty? ? ' ' : line}</p>"
|
@@ -12,18 +13,18 @@ event :add_comment, after: :approve, on: :save, when: proc { |c| c.comment } do
|
|
12
13
|
"#{comment_author} (Not signed in)"
|
13
14
|
end
|
14
15
|
|
15
|
-
self.content = %
|
16
|
+
self.content = %(
|
16
17
|
#{content}
|
17
18
|
#{'<hr>' unless content.blank?}
|
18
19
|
#{cleaned_comment}
|
19
20
|
<div class="w-comment-author">--#{signature}.....#{Time.zone.now}</div>
|
20
|
-
|
21
|
+
)
|
21
22
|
end
|
22
23
|
|
23
24
|
format do
|
24
25
|
view :comment_box,
|
25
26
|
denial: :blank, tags: :unknown_ok,
|
26
|
-
perms:
|
27
|
+
perms: ->(r) { r.card.ok? :comment } do |_args|
|
27
28
|
<<-HTML
|
28
29
|
<div class="comment-box nodblclick">#{comment_form}</div>
|
29
30
|
HTML
|
@@ -31,28 +32,25 @@ format do
|
|
31
32
|
|
32
33
|
def comment_form
|
33
34
|
card_form :update do
|
34
|
-
%
|
35
|
-
#{hidden_field_tag('card[name]', card.name) if card.new_card?
|
36
|
-
# FIXME: wish we had more generalized solution for names.
|
35
|
+
%(
|
36
|
+
#{hidden_field_tag('card[name]', card.name) if card.new_card? # FIXME: wish we had more generalized solution for names.
|
37
37
|
# without this, nonexistent cards will often take left's linkname.
|
38
38
|
# (needs test)
|
39
39
|
}
|
40
40
|
#{text_area :comment, rows: 3}
|
41
41
|
#{comment_buttons}
|
42
|
-
|
42
|
+
)
|
43
43
|
end
|
44
44
|
end
|
45
45
|
|
46
46
|
def comment_buttons
|
47
47
|
<<-HTML
|
48
48
|
<div class="comment-buttons">
|
49
|
-
#{
|
50
|
-
unless Auth.signed_in?
|
49
|
+
#{unless Auth.signed_in?
|
51
50
|
card.comment_author = session[:comment_author] ||
|
52
51
|
params[:comment_author] || 'Anonymous' # ENGLISH
|
53
|
-
%
|
54
|
-
end
|
55
|
-
}
|
52
|
+
%(<label>My Name is:</label> #{text_field :comment_author})
|
53
|
+
end}
|
56
54
|
#{submit_button text: 'Comment', type: :submit,
|
57
55
|
disable_with: 'Commenting'}
|
58
56
|
</div>
|
@@ -19,15 +19,15 @@ format do
|
|
19
19
|
|
20
20
|
view :not_found, perms: :none, error_code: 404 do |_args|
|
21
21
|
error_name = card.name.present? ? card.name : 'the card requested'
|
22
|
-
%
|
22
|
+
%( Could not find #{error_name}. )
|
23
23
|
end
|
24
24
|
|
25
25
|
view :server_error, perms: :none, error_code: 500 do
|
26
|
-
%
|
26
|
+
%(
|
27
27
|
Wagn Hitch! Server Error. Yuck, sorry about that.
|
28
28
|
To tell us more and follow the fix,
|
29
29
|
add a support ticket at http://wagn.org/new/Support_Ticket
|
30
|
-
|
30
|
+
)
|
31
31
|
end
|
32
32
|
|
33
33
|
view :denial, perms: :none, error_code: 403 do
|
@@ -35,15 +35,15 @@ format do
|
|
35
35
|
end
|
36
36
|
|
37
37
|
view :bad_address, perms: :none, error_code: 404 do
|
38
|
-
%
|
38
|
+
%( 404: Bad Address )
|
39
39
|
end
|
40
40
|
|
41
41
|
view :too_deep, perms: :none, closed: true do
|
42
|
-
%{ Man, you're too deep. (Too many levels of
|
42
|
+
%{ Man, you're too deep. (Too many levels of nests at a time) }
|
43
43
|
end
|
44
44
|
|
45
45
|
view :too_slow, perms: :none, closed: true do
|
46
|
-
%
|
46
|
+
%( Timed out! #{showname} took too long to load. )
|
47
47
|
end
|
48
48
|
end
|
49
49
|
|
@@ -86,12 +86,12 @@ format :html do
|
|
86
86
|
end
|
87
87
|
|
88
88
|
view :unsupported_view, perms: :none, tags: :unknown_ok do |args|
|
89
|
-
%
|
89
|
+
%(
|
90
90
|
<strong>
|
91
91
|
view <em>#{args[:unsupported_view]}</em>
|
92
92
|
not supported for <em>#{error_cardname}</em>
|
93
93
|
</strong>
|
94
|
-
|
94
|
+
)
|
95
95
|
end
|
96
96
|
|
97
97
|
view :message, perms: :none, tags: :unknown_ok do |args|
|
@@ -115,7 +115,7 @@ format :html do
|
|
115
115
|
end
|
116
116
|
|
117
117
|
view :closed_missing, perms: :none do
|
118
|
-
%
|
118
|
+
%(<span class="faint"> #{showname} </span>)
|
119
119
|
end
|
120
120
|
|
121
121
|
view :conflict, error_code: 409 do |args|
|
@@ -125,13 +125,13 @@ format :html do
|
|
125
125
|
end
|
126
126
|
wrap args.merge(slot_class: 'error-view') do # ENGLISH below
|
127
127
|
alert 'warning' do
|
128
|
-
%
|
128
|
+
%(
|
129
129
|
<strong>Conflict!</strong>
|
130
130
|
<span class="new-current-revision-id">#{card.last_action_id}</span>
|
131
131
|
<div>#{actor_link} has also been making changes.</div>
|
132
132
|
<div>Please examine below, resolve above, and re-submit.</div>
|
133
133
|
#{expanded_act}
|
134
|
-
|
134
|
+
)
|
135
135
|
end
|
136
136
|
end
|
137
137
|
end
|
@@ -157,14 +157,14 @@ format :html do
|
|
157
157
|
|
158
158
|
view :not_found do |args| # ug. bad name.
|
159
159
|
sign_in_or_up_links =
|
160
|
-
|
160
|
+
unless Auth.signed_in?
|
161
161
|
signin_link = card_link :signin, text: 'Sign in'
|
162
162
|
signup_link = link_to 'Sign up', card_path('new/:signup')
|
163
|
-
%
|
163
|
+
%(<div>#{signin_link} or #{signup_link} to create it.</div>)
|
164
164
|
end
|
165
165
|
frame args.merge(title: 'Not Found', optional_menu: :never) do
|
166
166
|
card_label = card.name.present? ? "<em>#{card.name}</em>" : 'that'
|
167
|
-
%
|
167
|
+
%(<h2>Could not find #{card_label}.</h2> #{sign_in_or_up_links})
|
168
168
|
end
|
169
169
|
end
|
170
170
|
|
@@ -172,11 +172,11 @@ format :html do
|
|
172
172
|
task = args[:denied_task]
|
173
173
|
to_task = task ? "to #{task} this." : 'to do that.'
|
174
174
|
if !focal?
|
175
|
-
%
|
175
|
+
%(
|
176
176
|
<span class="denied">
|
177
177
|
<!-- Sorry, you don't have permission #{to_task} -->
|
178
178
|
</span>
|
179
|
-
|
179
|
+
)
|
180
180
|
else
|
181
181
|
frame args do # ENGLISH below
|
182
182
|
message =
|
@@ -195,10 +195,10 @@ format :html do
|
|
195
195
|
"Please #{signin_link} #{or_signup_link} #{to_task}"
|
196
196
|
end
|
197
197
|
|
198
|
-
%
|
198
|
+
%(
|
199
199
|
<h1>Sorry!</h1>
|
200
200
|
<div>#{message}</div>
|
201
|
-
|
201
|
+
)
|
202
202
|
end
|
203
203
|
end
|
204
204
|
end
|