card 1.96.8 → 1.97.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/config/initializers/01_core_extensions/hash.rb +7 -7
- data/config/initializers/01_core_extensions/object.rb +8 -4
- data/config/initializers/02_patches/kaminari.rb +0 -6
- data/config/locales/de.yml +7 -4
- data/config/locales/en.yml +46 -39
- data/db/migrate/20110511221913_require_earlier_migrations.rb +1 -0
- data/db/migrate/20120105203350_require_1_8_migrations.rb +1 -0
- data/db/migrate/20190116170824_add_left_key_to_card_virtuals.rb +11 -0
- data/db/migrate/20190131223248_add_codename_index.rb +9 -0
- data/db/migrate_core_cards/20120611203506_rails_inflection_updates.rb +8 -2
- data/db/migrate_core_cards/20180712042655_head_rule.rb +14 -0
- data/db/migrate_core_cards/20180905061536_migrate_layouts.rb +64 -0
- data/db/migrate_core_cards/20190125125150_add_script_rules_card.rb +9 -0
- data/db/migrate_core_cards/20190204195039_add_rule_card.rb +7 -0
- data/db/migrate_core_cards/data/decko_logo.svg +59 -0
- data/db/schema.rb +3 -2
- data/db/seed/new/card_actions.yml +1506 -1458
- data/db/seed/new/card_acts.yml +2 -2
- data/db/seed/new/card_references.yml +633 -633
- data/db/seed/new/cards.yml +1802 -1634
- data/db/seed/new/schema_migrations.yml +4 -0
- data/db/seed/new/schema_migrations_core_cards.yml +28 -2
- data/db/seed/test/fixtures/card_actions.yml +2485 -2533
- data/db/seed/test/fixtures/card_acts.yml +520 -460
- data/db/seed/test/fixtures/card_changes.yml +66 -66
- data/db/seed/test/fixtures/card_references.yml +1533 -1407
- data/db/seed/test/fixtures/cards.yml +3392 -2945
- data/db/seed/test/fixtures/schema_migrations.yml +4 -0
- data/db/seed/test/fixtures/schema_migrations_core_cards.yml +28 -2
- data/db/seed/test/seed.rb +33 -1
- data/db/version.txt +1 -1
- data/db/version_core_cards.txt +1 -1
- data/lib/card.rb +1 -0
- data/lib/card/act_manager.rb +6 -2
- data/lib/card/act_manager/stage.rb +5 -5
- data/lib/card/act_manager/stage_director.rb +11 -7
- data/lib/card/act_manager/stage_director/phases.rb +4 -8
- data/lib/card/auth.rb +1 -0
- data/lib/card/auth/current.rb +1 -1
- data/lib/card/auth/permissions.rb +1 -0
- data/lib/card/auth/proxy.rb +1 -0
- data/lib/card/cache.rb +10 -9
- data/lib/card/cache/persistent.rb +2 -1
- data/lib/card/cache/prepopulate.rb +1 -0
- data/lib/card/cache/temporary.rb +1 -0
- data/lib/card/codename.rb +11 -6
- data/lib/card/content/chunk.rb +24 -9
- data/lib/card/content/clean.rb +4 -2
- data/lib/card/content/diff.rb +4 -4
- data/lib/card/content/diff/lcs.rb +1 -3
- data/lib/card/content/diff/processor.rb +2 -0
- data/lib/card/content/diff/result.rb +3 -0
- data/lib/card/content/parser.rb +2 -1
- data/lib/card/content/truncate.rb +4 -1
- data/lib/card/dirty.rb +3 -2
- data/lib/card/env.rb +11 -2
- data/lib/card/env/location_history.rb +3 -1
- data/lib/card/env/success.rb +3 -1
- data/lib/card/error.rb +42 -8
- data/lib/card/format.rb +22 -9
- data/lib/card/format/content.rb +10 -2
- data/lib/card/format/context_names.rb +4 -2
- data/lib/card/format/error.rb +1 -1
- data/lib/card/format/nest.rb +4 -3
- data/lib/card/format/nesting.rb +2 -0
- data/lib/card/format/nesting/main.rb +11 -5
- data/lib/card/format/nesting/mode.rb +1 -0
- data/lib/card/format/nesting/subformat.rb +12 -0
- data/lib/card/format/permission.rb +3 -0
- data/lib/card/format/registration.rb +7 -3
- data/lib/card/format/render.rb +73 -17
- data/lib/card/mailer.rb +2 -1
- data/lib/card/mark.rb +2 -2
- data/lib/card/migration.rb +115 -113
- data/lib/card/migration/core.rb +1 -0
- data/lib/card/migration/deck_structure.rb +1 -0
- data/lib/card/migration/import.rb +1 -1
- data/lib/card/migration/import/import_data.rb +6 -3
- data/lib/card/migration/import/import_data/card_attributes.rb +56 -54
- data/lib/card/migration/import/import_data/card_content.rb +0 -1
- data/lib/card/mod.rb +4 -1
- data/lib/card/mod/dirs.rb +11 -2
- data/lib/card/mod/load_strategy.rb +4 -4
- data/lib/card/mod/load_strategy/set_binding_magic.rb +9 -5
- data/lib/card/mod/load_strategy/set_tmp_files.rb +1 -1
- data/lib/card/mod/load_strategy/tmp_files.rb +1 -0
- data/lib/card/mod/loader.rb +8 -9
- data/lib/card/mod/loader/set_loader.rb +4 -4
- data/lib/card/mod/loader/set_pattern_loader.rb +2 -2
- data/lib/card/mod/module_template.rb +12 -12
- data/lib/card/model/save_helper.rb +13 -4
- data/lib/card/name.rb +3 -2
- data/lib/card/name/name_variants.rb +3 -3
- data/lib/card/query.rb +19 -12
- data/lib/card/query/abstract_query/query_helper.rb +2 -0
- data/lib/card/query/card_query.rb +1 -0
- data/lib/card/query/card_query/conjunctions.rb +2 -0
- data/lib/card/query/card_query/interpretation.rb +2 -7
- data/lib/card/query/card_query/match_attributes.rb +1 -0
- data/lib/card/query/card_query/reference_attributes.rb +4 -4
- data/lib/card/query/card_query/run.rb +1 -0
- data/lib/card/query/card_query/sorting.rb +1 -0
- data/lib/card/query/clause.rb +14 -12
- data/lib/card/query/join.rb +4 -2
- data/lib/card/query/reference_query.rb +1 -0
- data/lib/card/query/sql_statement.rb +4 -8
- data/lib/card/query/sql_statement/joins.rb +1 -0
- data/lib/card/query/sql_statement/order.rb +7 -6
- data/lib/card/query/sql_statement/where.rb +3 -1
- data/lib/card/query/value.rb +1 -0
- data/lib/card/reference.rb +1 -0
- data/lib/card/set/advanced_api.rb +2 -2
- data/lib/card/set/code_nest.rb +15 -0
- data/lib/card/set/event.rb +4 -3
- data/lib/card/set/event/callbacks.rb +1 -0
- data/lib/card/set/event/delayed_event.rb +7 -6
- data/lib/card/set/event/options.rb +5 -1
- data/lib/card/set/format.rb +21 -0
- data/lib/card/set/format/abstract_format.rb +15 -6
- data/lib/card/set/format/haml_views.rb +1 -1
- data/lib/card/set/format/wrapper.rb +89 -0
- data/lib/card/set/helpers.rb +5 -0
- data/lib/card/set/i18n_scanner.rb +5 -4
- data/lib/card/set/i18n_scope.rb +10 -10
- data/lib/card/set/inheritance.rb +3 -0
- data/lib/card/set/loader.rb +1 -0
- data/lib/card/set/required_field.rb +74 -0
- data/lib/card/set/trait.rb +6 -0
- data/lib/card/set_pattern.rb +8 -4
- data/lib/card/subcards.rb +9 -1
- data/lib/card/subcards/add.rb +1 -3
- data/lib/card/subcards/remove.rb +2 -0
- data/lib/card/tasks/card.rake +2 -0
- data/lib/card/tasks/card/create.rake +2 -1
- data/lib/card/tasks/card/file_card_creator.rb +1 -1
- data/lib/card/tasks/card/file_card_creator/abstract_file_card/migration_file.rb +1 -0
- data/lib/card/tasks/card/migrate.rake +3 -3
- data/lib/card/version.rb +6 -4
- data/lib/card/view.rb +15 -2
- data/lib/card/view/cache.rb +12 -12
- data/lib/card/view/cache_action.rb +11 -14
- data/lib/card/view/classy.rb +168 -0
- data/lib/card/view/layout.rb +14 -0
- data/lib/card/view/options.rb +12 -8
- data/lib/card/view/options/key_lists.rb +4 -4
- data/lib/card/view/options/voo_api.rb +46 -9
- data/lib/card/view/stub.rb +2 -2
- data/lib/card/view/visibility.rb +4 -5
- data/lib/card/view/wrapper.rb +28 -0
- data/lib/cardio.rb +2 -1
- data/mod/Modfile +2 -0
- data/mod/account/set/right/account.rb +4 -6
- data/mod/account/set/right/password.rb +2 -2
- data/mod/account/set/self/signin.rb +16 -9
- data/mod/account/set/type/signup.rb +1 -1
- data/mod/account/spec/set/right/password_spec.rb +26 -19
- data/mod/account/spec/set/type/signup_spec.rb +1 -1
- data/mod/basic_formats/set/self/head.rb +4 -0
- data/mod/bootstrap/lib/javascript/script_load_select2.js.coffee +2 -0
- data/mod/bootstrap/lib/stylesheets/style_bootstrap_cards.scss +76 -21
- data/mod/bootstrap/lib/stylesheets/style_select2_bootstrap.scss +24 -6
- data/mod/bootstrap/set/abstract/bootswatch_theme/html_views.rb +2 -1
- data/mod/bootstrap/set/type/customized_bootswatch_skin/core.haml +2 -2
- data/mod/bootstrap/set/type/customized_bootswatch_skin/html_views.rb +14 -14
- data/mod/bootstrap/set/type_plus_right/customized_bootswatch_skin/colors.rb +4 -0
- data/mod/bootstrap/set/type_plus_right/customized_bootswatch_skin/colors/core.haml +10 -0
- data/mod/carrierwave/lib/carrier_wave/file_card_uploader.rb +2 -2
- data/mod/carrierwave/set/abstract/attachment.rb +1 -1
- data/mod/carrierwave/set/type/file.rb +4 -0
- data/mod/carrierwave/set/type/image.rb +13 -0
- data/mod/carrierwave/spec/lib/carrier_wave/file_card_uploader_spec.rb +2 -2
- data/mod/carrierwave/spec/set/type/file_spec.rb +4 -4
- data/mod/carrierwave/spec/set/type/image_spec.rb +6 -6
- data/mod/core/chunk/nest.rb +9 -1
- data/mod/core/format/html_format.rb +9 -45
- data/mod/core/layout/blank.html +5 -5
- data/mod/core/layout/default.html +10 -8
- data/mod/core/layout/noside.html +6 -9
- data/mod/core/layout/pre.html +1 -2
- data/mod/core/layout/simple.html +1 -5
- data/mod/core/set/abstract/code_file.rb +1 -1
- data/mod/core/set/all/cache.rb +0 -2
- data/mod/core/set/all/codename.rb +2 -0
- data/mod/core/set/all/collection.rb +3 -1
- data/mod/core/set/all/event_conditions.rb +36 -4
- data/mod/core/set/all/export.rb +1 -10
- data/mod/core/set/all/haml.rb +3 -2
- data/mod/core/set/all/layouts.rb +34 -0
- data/mod/core/set/all/name_events.rb +1 -1
- data/mod/core/set/all/pattern.rb +6 -11
- data/mod/core/set/all/subcards.rb +4 -0
- data/mod/core/set/all/utils.rb +21 -1
- data/mod/core/set_pattern/07_type_plus_right.rb +1 -1
- data/mod/core/set_pattern/08_rule.rb +17 -0
- data/mod/core/set_pattern/{08_self.rb → 09_self.rb} +0 -0
- data/mod/core/spec/format/html_format_spec.rb +6 -99
- data/mod/core/spec/set/all/codename_spec.rb +1 -1
- data/mod/core/spec/set/all/collection_spec.rb +9 -5
- data/mod/core/spec/set/all/event_conditions_spec.rb +91 -0
- data/mod/core/spec/set/all/pattern_spec.rb +17 -10
- data/mod/developer/spec/set/right/debug_spec.rb +1 -1
- data/mod/edit/set/all/bridge.rb +61 -0
- data/mod/edit/set/all/bridge/bridge.haml +6 -0
- data/mod/edit/set/all/bridge/follow_section.rb +37 -0
- data/mod/edit/set/all/bridge/tab_views.rb +75 -0
- data/mod/edit/set/all/bridge/tab_visibility.rb +51 -0
- data/mod/edit/set/all/edit_content.rb +58 -0
- data/mod/edit/set/all/edit_in_place.rb +58 -0
- data/mod/edit/set/all/edit_name.rb +87 -0
- data/mod/edit/set/all/edit_type.rb +28 -0
- data/mod/edit/set/all/editing.rb +79 -0
- data/mod/{standard/set/all/rich_html → edit/set/all}/editor.rb +1 -0
- data/mod/{standard/set/all/rich_html → edit/set/all}/form.rb +17 -10
- data/mod/edit/set/all/form_buttons.rb +52 -0
- data/mod/{standard/set/all/rich_html → edit/set/all}/form_elements.rb +2 -1
- data/mod/{standard/set/all/rich_html → edit/set/all}/formgroup.rb +3 -1
- data/mod/{standard/set/all/rich_html → edit/set/all}/new.rb +0 -2
- data/mod/edit/set/all/toolbar.rb +8 -0
- data/mod/edit/spec/set/all/bridge/tab_views_spec.rb +14 -0
- data/mod/{standard/spec/set/all/rich_html/editing_spec.rb → edit/spec/set/all/bridge_spec.rb} +1 -1
- data/mod/edit/spec/set/all/editing_spec.rb +15 -0
- data/mod/{standard/spec/set/all/rich_html → edit/spec/set/all}/form_elements_spec.rb +10 -8
- data/mod/edit/spec/set/all/form_spec.rb +50 -0
- data/mod/follow/lib/card/follower_stash.rb +5 -0
- data/mod/follow/set/abstract/follow_option.rb +0 -1
- data/mod/follow/set/all/follow/follow_link.rb +42 -54
- data/mod/follow/set/all/follow/follow_link_views.rb +29 -0
- data/mod/follow/set/all/follow/followed_by.rb +3 -0
- data/mod/follow/set/all/follow/follower_ids.rb +5 -0
- data/mod/follow/set/all/follow/start_follow_link.rb +11 -0
- data/mod/follow/set/all/follow/stop_follow_link.rb +12 -0
- data/mod/follow/set/all/notify.rb +4 -0
- data/mod/follow/set/all/notify/base_views.rb +11 -0
- data/mod/follow/set/right/account.rb +2 -1
- data/mod/follow/set/right/follow.rb +4 -0
- data/mod/follow/set/right/follow/follow_status.haml +2 -2
- data/mod/follow/set/right/followers.rb +1 -0
- data/mod/follow/set/right/following.rb +2 -3
- data/mod/follow/set/self/follow_defaults.rb +17 -16
- data/mod/follow/set/type/set.rb +2 -0
- data/mod/follow/set/type/user.rb +1 -0
- data/mod/follow/set/type_plus_right/user/follow.rb +1 -0
- data/mod/follow/set/type_plus_right/user/follow/follow_editor.haml +4 -1
- data/mod/follow/set/type_plus_right/user/follow/follow_editor_helper.rb +6 -0
- data/mod/follow/spec/set/all/follow/follow_link_views_spec.rb +27 -0
- data/mod/follow/spec/set/all/follow/start_follow_link_spec.rb +11 -0
- data/mod/follow/spec/set/all/follow/stop_follow_link_spec.rb +13 -0
- data/mod/follow/spec/set/all/follow_spec.rb +13 -9
- data/mod/follow/spec/set/all/notify_spec.rb +4 -3
- data/mod/follow/spec/set/right/account_spec.rb +29 -31
- data/mod/follow/spec/set/right/following_spec.rb +2 -8
- data/mod/history/lib/card/act.rb +9 -7
- data/mod/history/lib/card/act/act_renderer.rb +12 -9
- data/mod/history/lib/card/act/act_renderer/absolute_act_renderer.rb +2 -2
- data/mod/history/lib/card/act/act_renderer/bridge_act_renderer.rb +53 -0
- data/mod/history/lib/card/act/act_renderer/relative_act_renderer.rb +3 -0
- data/mod/history/lib/card/action.rb +9 -4
- data/mod/history/lib/card/action/action_renderer.rb +5 -3
- data/mod/history/lib/card/action/differ.rb +3 -0
- data/mod/history/set/all/history.rb +2 -1
- data/mod/history/set/all/history/act_listing.rb +11 -8
- data/mod/history/set/all/history/actions.rb +11 -2
- data/mod/history/set/all/history/events.rb +0 -1
- data/mod/history/set/all/history/last.rb +2 -1
- data/mod/history/set/all/history/revision.rb +1 -0
- data/mod/history/set/all/history/selected.rb +1 -1
- data/mod/history/set/all/history/views.rb +0 -1
- data/mod/history/set/all/history_bridge.rb +66 -0
- data/mod/item/set/all/bar.haml +1 -3
- data/mod/item/set/all/bar.rb +39 -21
- data/mod/item/set/all/box.haml +1 -0
- data/mod/item/set/all/box.rb +13 -3
- data/mod/item/set/all/expanded_bar.haml +4 -6
- data/mod/machines/file/all_script_machine_output/file.js +37380 -65
- data/mod/machines/file/all_style_machine_output/file.css +2 -2
- data/mod/machines/file/script_html5shiv_printshiv_machine_output/file.js +1 -1
- data/mod/machines/lib/javascript/decko.js.coffee +2 -17
- data/mod/machines/lib/javascript/decko_bridge.js.coffee +28 -0
- data/mod/machines/lib/javascript/decko_components.js.coffee +21 -0
- data/mod/machines/lib/javascript/decko_filter.js.coffee +3 -1
- data/mod/machines/lib/javascript/decko_mod.js.coffee +7 -64
- data/mod/machines/lib/javascript/decko_modal.js.coffee +108 -0
- data/mod/machines/lib/javascript/decko_navbox.js.coffee +2 -0
- data/mod/machines/lib/javascript/decko_overlay.js.coffee +42 -0
- data/mod/machines/lib/javascript/decko_recaptcha.js.coffee +9 -1
- data/mod/machines/lib/javascript/decko_slot.js.coffee +46 -50
- data/mod/machines/lib/javascript/decko_slotter.js.coffee +204 -63
- data/mod/machines/lib/javascript/script_card_menu.js.coffee +3 -3
- data/mod/machines/lib/stylesheets/style_cards.scss +234 -107
- data/mod/machines/set/abstract/machine.rb +4 -3
- data/mod/machines/set/self/script_slot.rb +2 -2
- data/mod/machines/set/type/css.rb +8 -1
- data/mod/machines/set/type/skin.rb +1 -1
- data/mod/machines/spec/set/type/coffeescript_spec.rb +3 -3
- data/mod/pointer/set/abstract/00_paging_params.rb +2 -0
- data/mod/pointer/set/abstract/01_paging.rb +12 -6
- data/mod/pointer/set/abstract/02_pointer/html_views.rb +25 -0
- data/mod/pointer/set/abstract/02_pointer/html_views/filter.rb +20 -4
- data/mod/pointer/set/abstract/02_pointer/html_views/filter/filter_items.haml +1 -6
- data/mod/pointer/set/abstract/02_pointer/html_views/filter/filtered_list_input.haml +4 -13
- data/mod/pointer/set/type/pointer.rb +9 -0
- data/mod/pointer/spec/set/abstract/pointer/events_spec.rb +6 -0
- data/mod/rules/lib/javascript/script_rules.js.coffee +23 -0
- data/mod/rules/set/rstar/rule_user.rb +8 -0
- data/mod/rules/set/rule/bridge_rules_editor.rb +32 -0
- data/mod/rules/set/rule/editor.rb +144 -0
- data/mod/rules/set/rule/rule_form.rb +57 -0
- data/mod/rules/set/rule/rule_form/buttons.rb +44 -0
- data/mod/rules/set/rule/rule_form/form_elements.rb +52 -0
- data/mod/rules/set/rule/rule_form/rule_form.haml +20 -0
- data/mod/rules/set/rule/rule_form/rule_set_radio.rb +86 -0
- data/mod/rules/set/rule/rule_form/set_selection.rb +46 -0
- data/mod/{standard/set/rstar → rules/set/rule}/rules.rb +5 -9
- data/mod/rules/set/rule/table.rb +27 -0
- data/mod/rules/set/rule/table_row.rb +62 -0
- data/mod/rules/set/self/script_rules.rb +3 -0
- data/mod/{standard → rules}/set/type/set.rb +8 -10
- data/mod/rules/set/type/set/html_views.rb +72 -0
- data/mod/{standard → rules}/set/type/set/html_views/group_panel.haml +0 -0
- data/mod/rules/set/type/set/html_views/rules_bridge.rb +129 -0
- data/mod/rules/set/type/set/html_views/rules_table.haml +11 -0
- data/mod/{standard → rules}/set/type/set/html_views/template.rb +3 -7
- data/mod/{standard → rules}/set/type/set/html_views/template/template_editor.haml +0 -0
- data/mod/rules/spec/set/rule/editor_spec.rb +9 -0
- data/mod/rules/spec/set/rule/table_row_spec.rb +9 -0
- data/mod/rules/spec/set/rule/table_spec.rb +15 -0
- data/mod/rules/spec/set/type/set/html_views_spec.rb +22 -0
- data/mod/{standard → rules}/spec/set/type/set_spec.rb +18 -18
- data/mod/search/set/abstract/00_filter_helper.rb +15 -7
- data/mod/search/set/abstract/01_filter_form_helper.rb +1 -0
- data/mod/search/set/abstract/02_search_params.rb +7 -5
- data/mod/search/set/abstract/03_filter.rb +3 -2
- data/mod/search/set/abstract/04_right_filter_form.rb +1 -2
- data/mod/search/set/abstract/search.rb +1 -1
- data/mod/search/set/abstract/search/views.rb +2 -0
- data/mod/search/set/abstract/wql_search.rb +6 -0
- data/mod/search/set/self/navbox.rb +1 -1
- data/mod/search/set/self/search.rb +2 -2
- data/mod/settings/lib/card/setting.rb +6 -1
- data/mod/settings/set/right/help.rb +4 -0
- data/mod/settings/set/right/read.rb +14 -4
- data/mod/settings/set/right/structure.rb +3 -0
- data/mod/settings/set/right/style.rb +2 -1
- data/mod/settings/set/self/create.rb +2 -1
- data/mod/settings/set/self/default.rb +2 -1
- data/mod/settings/set/self/delete.rb +2 -1
- data/mod/settings/set/self/head.rb +2 -0
- data/mod/settings/set/self/help.rb +2 -1
- data/mod/settings/set/self/input.rb +1 -1
- data/mod/settings/set/self/read.rb +2 -1
- data/mod/settings/set/self/structure.rb +2 -1
- data/mod/settings/set/self/thanks.rb +2 -1
- data/mod/settings/set/self/update.rb +2 -1
- data/mod/settings/set/type/setting.rb +1 -1
- data/mod/solid_cache/set/abstract/solid_cache.rb +2 -2
- data/mod/standard/file/logo/image-original.svg +59 -0
- data/mod/standard/lib/card/layout.rb +79 -0
- data/mod/standard/lib/card/layout/card_layout.rb +44 -0
- data/mod/standard/lib/card/layout/code_layout.rb +9 -0
- data/mod/standard/lib/card/layout/proc_layout.rb +9 -0
- data/mod/standard/lib/card/layout/unknown_layout.rb +20 -0
- data/mod/standard/set/all/links.rb +5 -20
- data/mod/standard/set/all/rich_html.rb +4 -0
- data/mod/standard/set/all/rich_html/alert.rb +23 -0
- data/mod/standard/set/all/rich_html/content.rb +26 -100
- data/mod/standard/set/all/rich_html/error.rb +27 -3
- data/mod/standard/set/all/rich_html/error/debug_server_error.haml +1015 -0
- data/mod/standard/set/all/rich_html/frame.rb +10 -54
- data/mod/standard/set/all/rich_html/header.rb +25 -15
- data/mod/standard/set/all/rich_html/header/header_wrap.haml +2 -1
- data/mod/standard/set/all/rich_html/html_views/help.rb +18 -0
- data/mod/standard/set/all/rich_html/html_views/info.rb +59 -0
- data/mod/standard/set/all/rich_html/html_views/size.rb +17 -0
- data/mod/standard/set/all/rich_html/menu.rb +44 -146
- data/mod/standard/set/all/rich_html/modal.rb +99 -24
- data/mod/standard/set/all/rich_html/modal/modal_dialog.haml +12 -0
- data/mod/standard/set/all/rich_html/overlay.rb +57 -13
- data/mod/standard/set/all/rich_html/process_layout.rb +91 -0
- data/mod/standard/set/all/rich_html/show.rb +37 -0
- data/mod/standard/set/all/rich_html/wrapper.rb +47 -10
- data/mod/standard/set/right/head.rb +11 -0
- data/mod/standard/set/type/cardtype.rb +1 -1
- data/mod/standard/set/type/listed_by.rb +3 -3
- data/mod/standard/spec/set/all/email_html_format_spec.rb +17 -0
- data/mod/standard/spec/set/all/links_spec.rb +1 -22
- data/mod/standard/spec/set/all/rich_html/overlay_spec.rb +18 -0
- data/mod/standard/spec/set/all/rich_html/process_layout/explicit_modal_wrapper_spec.rb +29 -0
- data/mod/standard/spec/set/all/rich_html/process_layout_spec.rb +110 -0
- data/mod/standard/spec/set/all/rich_html/show_spec.rb +9 -0
- data/mod/standard/spec/set/all/rich_html/wrapper_spec.rb +17 -24
- data/mod/standard/spec/set/type/email_template/email_config_spec.rb +9 -5
- data/mod/standard/spec/set/type/layout_type_spec.rb +6 -0
- data/mod/standard/spec/set/type/search_type_spec.rb +1 -1
- data/mod/tinymce_editor/db/migrate_core_cards/20190306172623_update_tinymce_config_to_v5.rb +23 -0
- data/mod/tinymce_editor/lib/javascript/script_tinymce.js +9 -2
- data/mod/tinymce_editor/lib/javascript/script_tinymce_config.js.coffee +3 -2
- data/mod/tinymce_editor/public/assets/tinymce/jquery.tinymce.min.js +92 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/advlist/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/anchor/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/autolink/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/autoresize/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/autosave/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/bbcode/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/charmap/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/code/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/codesample/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/colorpicker/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/contextmenu/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/directionality/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/emoticons/js/emojis.js +9015 -0
- data/mod/tinymce_editor/public/assets/tinymce/plugins/emoticons/js/emojis.min.js +2 -0
- data/mod/tinymce_editor/public/assets/tinymce/plugins/emoticons/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/fullpage/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/fullscreen/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/help/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/hr/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/image/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/imagetools/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/importcss/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/insertdatetime/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/legacyoutput/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/link/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/lists/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/media/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/nonbreaking/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/noneditable/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/pagebreak/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/paste/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/preview/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/print/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/quickbars/plugin.min.js +9 -0
- data/mod/tinymce_editor/public/assets/tinymce/plugins/save/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/searchreplace/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/spellchecker/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/tabfocus/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/table/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/template/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/textcolor/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/textpattern/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/toc/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/visualblocks/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/visualchars/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/plugins/wordcount/plugin.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/skins/content/default/content.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/content/document/content.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/content/writer/content.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide-dark/content.inline.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide-dark/content.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide-dark/skin.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide/content.inline.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide/content.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide/content.mobile.min.css +1 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide/fonts/tinymce-mobile.woff +0 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide/skin.min.css +7 -0
- data/mod/tinymce_editor/public/assets/tinymce/skins/ui/oxide/skin.mobile.min.css +1 -0
- data/mod/tinymce_editor/public/assets/tinymce/themes/mobile/theme.min.js +9 -1
- data/mod/tinymce_editor/public/assets/tinymce/themes/silver/theme.min.js +9 -0
- data/mod/tinymce_editor/public/assets/tinymce/tinymce.min.js +9 -2
- data/mod/utility/spec/set/abstract/media_spec.rb +6 -6
- data/mod/virtual/lib/card/virtual.rb +17 -2
- data/mod/virtual/set/abstract/virtual_cache.rb +1 -1
- data/mod/virtual/spec/set/lib/card/virtual_spec.rb +1 -1
- metadata +121 -42
- data/mod/core/layout/modal.html +0 -9
- data/mod/core/layout/simple_modal.html +0 -3
- data/mod/follow/spec/set/all/follow/follow_link_spec.rb +0 -7
- data/mod/standard/file/logo/image-icon.png +0 -0
- data/mod/standard/file/logo/image-large.png +0 -0
- data/mod/standard/file/logo/image-medium.png +0 -0
- data/mod/standard/file/logo/image-original.png +0 -0
- data/mod/standard/file/logo/image-small.png +0 -0
- data/mod/standard/set/abstract/toolbar_split_button.rb +0 -22
- data/mod/standard/set/all/rich_html/classy.rb +0 -37
- data/mod/standard/set/all/rich_html/editing.rb +0 -176
- data/mod/standard/set/all/rich_html/related.rb +0 -30
- data/mod/standard/set/all/rich_html/toolbar.rb +0 -264
- data/mod/standard/set/rstar/rules_editor.rb +0 -371
- data/mod/standard/set/self/activity_toolbar_button.rb +0 -14
- data/mod/standard/set/self/rules_toolbar_button.rb +0 -44
- data/mod/standard/set/type/set/html_views.rb +0 -155
- data/mod/standard/set/type/set/html_views/rules_table.haml +0 -9
- data/mod/standard/spec/set/all/rich_html/form_spec.rb +0 -47
- data/mod/standard/spec/set/all/rich_html/toolbar_spec.rb +0 -25
- data/mod/standard/spec/set/rstar/rules_spec.rb +0 -26
- data/mod/standard/spec/set/self/activity_toolbar_button_spec.rb +0 -22
- data/mod/standard/spec/set/type/set/html_views_spec.rb +0 -10
data/lib/card/cache/temporary.rb
CHANGED
data/lib/card/codename.rb
CHANGED
@@ -1,12 +1,14 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-
|
2
|
+
|
2
3
|
require_dependency "card/cache"
|
3
4
|
require_dependency "card/name"
|
4
5
|
|
5
6
|
class Card
|
6
|
-
# {Card}'s names can be changed, and therefore _names_ should not be directly mentioned
|
7
|
+
# {Card}'s names can be changed, and therefore _names_ should not be directly mentioned
|
8
|
+
# in code, lest a name change break the application.
|
7
9
|
#
|
8
|
-
# Instead, a {Card} that needs specific code manipulations should be given a {Codename},
|
9
|
-
# does.
|
10
|
+
# Instead, a {Card} that needs specific code manipulations should be given a {Codename},
|
11
|
+
# which will not change even if the card's name does.
|
10
12
|
#
|
11
13
|
# An administrator might add to the Company card via the RESTful web API with a url like
|
12
14
|
#
|
@@ -18,7 +20,8 @@ class Card
|
|
18
20
|
#
|
19
21
|
# Generally speaking, _codenames_ are represented by Symbols.
|
20
22
|
#
|
21
|
-
# The {Codename} class provides a fast cache for this slow-changing data.
|
23
|
+
# The {Codename} class provides a fast cache for this slow-changing data.
|
24
|
+
# Every process maintains a complete cache that is not frequently reset
|
22
25
|
#
|
23
26
|
class Codename
|
24
27
|
class << self
|
@@ -102,6 +105,7 @@ class Card
|
|
102
105
|
# @todo remove duplicate checks here; should be caught upon creation
|
103
106
|
def check_duplicates codehash, codename, card_id
|
104
107
|
return unless codehash.key?(codename) || codehash.key?(card_id)
|
108
|
+
|
105
109
|
Rails.logger.debug "dup codename: #{codename}, "\
|
106
110
|
"ID:#{card_id} (#{codehash[codename]})"
|
107
111
|
end
|
@@ -125,8 +129,8 @@ class Card
|
|
125
129
|
|
126
130
|
def unknown_codename! mark
|
127
131
|
raise Card::Error::CodenameNotFound, I18n.t(:exception_unknown_codename,
|
128
|
-
|
129
|
-
|
132
|
+
scope: "lib.card.codename",
|
133
|
+
codename: mark)
|
130
134
|
end
|
131
135
|
end
|
132
136
|
end
|
@@ -139,6 +143,7 @@ class Card
|
|
139
143
|
# @raise error if codename is missing
|
140
144
|
def self.const_missing const
|
141
145
|
return super unless const.to_s =~ /^([A-Z]\S*)ID$/
|
146
|
+
|
142
147
|
code = Regexp.last_match(1).underscore
|
143
148
|
code_id = Card::Codename.id!(code)
|
144
149
|
const_set const, code_id
|
data/lib/card/content/chunk.rb
CHANGED
@@ -28,6 +28,7 @@ class Card
|
|
28
28
|
prefix_map_by_chunkname[klassname] = { prefix_index => klass.config }
|
29
29
|
raw_list.each do |key, list|
|
30
30
|
next unless list.include? klassname
|
31
|
+
|
31
32
|
prefix_map_by_list[key].merge! prefix_map_by_chunkname[klassname]
|
32
33
|
end
|
33
34
|
end
|
@@ -37,12 +38,14 @@ class Card
|
|
37
38
|
prefix_map_by_list[key] =
|
38
39
|
list.each_with_object({}) do |chunkname, h|
|
39
40
|
next unless (p_map = prefix_map_by_chunkname[chunkname])
|
41
|
+
|
40
42
|
h.merge! p_map
|
41
43
|
end
|
42
|
-
prefix_map_by_list[key]
|
43
44
|
end
|
44
45
|
|
45
46
|
def find_class_by_prefix prefix, chunk_list_key=:default
|
47
|
+
validate_chunk_list_key chunk_list_key
|
48
|
+
|
46
49
|
prefix_map = prefix_map_by_list[chunk_list_key]
|
47
50
|
config = prefix_map[prefix[0, 1]] ||
|
48
51
|
prefix_map[prefix[-1, 1]] ||
|
@@ -53,13 +56,25 @@ class Card
|
|
53
56
|
config[:class]
|
54
57
|
end
|
55
58
|
|
56
|
-
def
|
57
|
-
prefix_regexp_by_list[chunk_list_key] ||=
|
58
|
-
|
59
|
+
def prefix_regexp chunk_list_key
|
60
|
+
prefix_regexp_by_list[chunk_list_key] ||=
|
61
|
+
build_prefix_regexp chunk_list_key
|
62
|
+
end
|
63
|
+
|
64
|
+
def build_prefix_regexp chunk_list_key
|
65
|
+
validate_chunk_list_key chunk_list_key
|
66
|
+
|
67
|
+
prefix_res =
|
68
|
+
raw_list[chunk_list_key].map do |chunkname|
|
59
69
|
chunk_class = const_get chunkname
|
60
70
|
chunk_class.config[:prefix_re]
|
61
71
|
end
|
62
|
-
|
72
|
+
/(?:#{ prefix_res * '|' })/m
|
73
|
+
end
|
74
|
+
|
75
|
+
def validate_chunk_list_key chunk_list_key
|
76
|
+
unless raw_list.key? chunk_list_key
|
77
|
+
raise ArgumentError, "invalid chunk list key: #{chunk_list_key}"
|
63
78
|
end
|
64
79
|
end
|
65
80
|
end
|
@@ -67,10 +82,10 @@ class Card
|
|
67
82
|
# not sure whether this is best place.
|
68
83
|
# Could really happen almost anywhere
|
69
84
|
# (even before chunk classes are loaded).
|
70
|
-
register_list :default, [
|
71
|
-
|
85
|
+
register_list :default, %i[
|
86
|
+
URI HostURI EmailURI EscapedLiteral Nest Link
|
72
87
|
]
|
73
|
-
register_list :references, [
|
88
|
+
register_list :references, %i[EscapedLiteral Nest Link]
|
74
89
|
register_list :nest_only, [:Nest]
|
75
90
|
register_list :query, [:QueryReference]
|
76
91
|
register_list :stub, [:ViewStub]
|
@@ -133,7 +148,7 @@ class Card
|
|
133
148
|
|
134
149
|
def as_json _options={}
|
135
150
|
@process_chunk || @processed ||
|
136
|
-
"not rendered #{self.class}, #{card
|
151
|
+
"not rendered #{self.class}, #{card&.name}"
|
137
152
|
end
|
138
153
|
end
|
139
154
|
end
|
data/lib/card/content/clean.rb
CHANGED
@@ -3,10 +3,10 @@ class Card
|
|
3
3
|
# tools for cleaning content, especially for restricing unwanted HTML
|
4
4
|
module Clean
|
5
5
|
allowed_tags = {}
|
6
|
-
%w
|
6
|
+
%w[
|
7
7
|
br i b pre cite caption strong em ins sup sub del ol hr ul li p
|
8
8
|
div h1 h2 h3 h4 h5 h6 span table tr td th tbody thead tfoot
|
9
|
-
|
9
|
+
].each { |tag| allowed_tags[tag] = [] }
|
10
10
|
|
11
11
|
# allowed attributes
|
12
12
|
allowed_tags.merge!(
|
@@ -61,6 +61,7 @@ class Card
|
|
61
61
|
|
62
62
|
def process_attribute attrib, all_attributes
|
63
63
|
return ['"', nil] unless all_attributes =~ /\b#{attrib}\s*=\s*(?=(.))/i
|
64
|
+
|
64
65
|
q = '"'
|
65
66
|
rest_value = $'
|
66
67
|
if (idx = %w[' "].index Regexp.last_match(1))
|
@@ -74,6 +75,7 @@ class Card
|
|
74
75
|
# NOTE allows classes beginning with "w-" (deprecated)
|
75
76
|
def process_attribute_match rest_value, reg_exp, attrib
|
76
77
|
return rest_value unless (match = rest_value.match reg_exp)
|
78
|
+
|
77
79
|
rest_value = match[0]
|
78
80
|
if attrib == "class"
|
79
81
|
rest_value.split(/\s+/).select { |s| s =~ /^w-/i }.join(" ")
|
data/lib/card/content/diff.rb
CHANGED
@@ -34,10 +34,10 @@ class Card
|
|
34
34
|
# summary: {length: <number> , joint: <string> }
|
35
35
|
def initialize old_version, new_version, opts={}
|
36
36
|
@result = Result.new opts[:summary]
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
37
|
+
return unless new_version
|
38
|
+
|
39
|
+
lcs_opts = lcs_opts_for_format opts[:diff_format]
|
40
|
+
LCS.new(lcs_opts).run(old_version, new_version, @result)
|
41
41
|
end
|
42
42
|
|
43
43
|
def red?
|
@@ -34,9 +34,7 @@ class Card
|
|
34
34
|
processor.run @result
|
35
35
|
else
|
36
36
|
list = split_and_preprocess(new_text)
|
37
|
-
if @exclude_pattern
|
38
|
-
list = list.reject { |word| word.match @exclude_pattern }
|
39
|
-
end
|
37
|
+
list = list.reject { |word| word.match @exclude_pattern } if @exclude_pattern
|
40
38
|
# CAUTION: postproces and added_chunk changed order
|
41
39
|
# and no longer postprocess for summary
|
42
40
|
@result.write_added_chunk list.join
|
@@ -102,18 +102,21 @@ class Card
|
|
102
102
|
|
103
103
|
def truncate_overlap
|
104
104
|
return unless @remaining_chars < 0
|
105
|
+
|
105
106
|
process_ellipsis
|
106
107
|
|
107
108
|
index = @chunks.size - 1
|
108
109
|
while @remaining_chars < @joint.size && index >= 0
|
109
110
|
overlap_size = @remaining_chars + @chunks[index][:text].size
|
110
111
|
break if process_overlap overlap_size, index
|
112
|
+
|
111
113
|
index -= 1
|
112
114
|
end
|
113
115
|
end
|
114
116
|
|
115
117
|
def process_ellipsis
|
116
118
|
return unless @chunks.last[:action] == :ellipsis
|
119
|
+
|
117
120
|
@chunks.pop
|
118
121
|
@content_omitted = true
|
119
122
|
@remaining_chars += @joint.size
|
data/lib/card/content/parser.rb
CHANGED
@@ -21,6 +21,7 @@ class Card
|
|
21
21
|
@content = content
|
22
22
|
@chunks = []
|
23
23
|
return @chunks unless content.is_a? String
|
24
|
+
|
24
25
|
@position = @last_position = 0
|
25
26
|
@interval_string = ""
|
26
27
|
parse_chunks
|
@@ -30,7 +31,7 @@ class Card
|
|
30
31
|
private
|
31
32
|
|
32
33
|
def parse_chunks
|
33
|
-
prefix_regexp = Chunk.
|
34
|
+
prefix_regexp = Chunk.prefix_regexp @chunk_list
|
34
35
|
match_prefices prefix_regexp
|
35
36
|
handle_remainder
|
36
37
|
end
|
@@ -6,6 +6,7 @@ class Card
|
|
6
6
|
|
7
7
|
def smart_truncate input, words=25
|
8
8
|
return if input.nil?
|
9
|
+
|
9
10
|
truncated, wordstring = truncate input, words
|
10
11
|
# nuke partial tags at end of snippet
|
11
12
|
wordstring.gsub!(/(<[^\>]+)$/, "")
|
@@ -18,7 +19,7 @@ class Card
|
|
18
19
|
def truncate input, words
|
19
20
|
wordlist = input.to_s.split
|
20
21
|
l = words.to_i - 1
|
21
|
-
l = 0 if l
|
22
|
+
l = 0 if l.negative?
|
22
23
|
truncating = wordlist.length > l
|
23
24
|
wordstring = truncating ? wordlist[0..l].join(" ") : input.to_s
|
24
25
|
[truncating, wordstring]
|
@@ -48,11 +49,13 @@ class Card
|
|
48
49
|
# match tags with self closing and mark them as closed
|
49
50
|
wordstring.scan(%r{\<([^\>\s/]+)[^\>]*?/\>}).each do |t|
|
50
51
|
next unless (x = tags.index(t[0]))
|
52
|
+
|
51
53
|
tags.slice!(x)
|
52
54
|
end
|
53
55
|
# match close tags
|
54
56
|
wordstring.scan(%r{\</([^\>\s/]+)[^\>]*?\>}).each do |t|
|
55
57
|
next unless (x = tags.rindex(t[0]))
|
58
|
+
|
56
59
|
tags.slice!(x)
|
57
60
|
end
|
58
61
|
tags
|
data/lib/card/dirty.rb
CHANGED
@@ -9,7 +9,7 @@ class Card
|
|
9
9
|
end
|
10
10
|
end
|
11
11
|
|
12
|
-
[
|
12
|
+
%i[name db_content trash type_id].each do |field|
|
13
13
|
define_dirty_methods field
|
14
14
|
end
|
15
15
|
|
@@ -25,7 +25,8 @@ class Card
|
|
25
25
|
end
|
26
26
|
end
|
27
27
|
|
28
|
-
def not_in_callback?
|
28
|
+
def not_in_callback?
|
29
|
+
# or in integrate_with_delay stage
|
29
30
|
mutations_before_last_save.equal?(mutations_from_database)
|
30
31
|
end
|
31
32
|
|
data/lib/card/env.rb
CHANGED
@@ -9,14 +9,15 @@ class Card
|
|
9
9
|
module Env
|
10
10
|
extend LocationHistory
|
11
11
|
|
12
|
-
SERIALIZABLE_ATTRIBUTES = ::Set.new [
|
13
|
-
|
12
|
+
SERIALIZABLE_ATTRIBUTES = ::Set.new %i[
|
13
|
+
main_name params ip ajax html host protocol salt
|
14
14
|
]
|
15
15
|
|
16
16
|
class << self
|
17
17
|
def reset args={}
|
18
18
|
@env = { main_name: nil }
|
19
19
|
return self unless (c = args[:controller])
|
20
|
+
|
20
21
|
self[:controller] = c
|
21
22
|
self[:session] = c.request.session
|
22
23
|
self[:params] = c.params
|
@@ -44,11 +45,19 @@ class Card
|
|
44
45
|
# FIXME: upgrade to safe parameters
|
45
46
|
self[:slot_opts] ||= begin
|
46
47
|
opts = params[:slot] || {}
|
48
|
+
opts.merge shortcut_slot_opts
|
47
49
|
opts = opts.to_unsafe_h if opts.is_a? ActionController::Parameters
|
48
50
|
opts.deep_symbolize_keys
|
49
51
|
end
|
50
52
|
end
|
51
53
|
|
54
|
+
def shortcut_slot_opts
|
55
|
+
opts = {}
|
56
|
+
opts[:size] = params[:size].to_sym if params[:size]
|
57
|
+
opts[:items] = { view: params[:item].to_sym } if params[:item].present?
|
58
|
+
opts
|
59
|
+
end
|
60
|
+
|
52
61
|
def session
|
53
62
|
self[:session] ||= {}
|
54
63
|
end
|
@@ -11,6 +11,7 @@ class Card
|
|
11
11
|
|
12
12
|
def save_location card
|
13
13
|
return unless save_location?(card)
|
14
|
+
|
14
15
|
discard_locations_for card
|
15
16
|
session[:previous_location] =
|
16
17
|
Env::Location.card_path card.name.url_key
|
@@ -23,6 +24,7 @@ class Card
|
|
23
24
|
|
24
25
|
def previous_location
|
25
26
|
return unless location_history
|
27
|
+
|
26
28
|
session[:previous_location] ||= location_history.last
|
27
29
|
end
|
28
30
|
|
@@ -45,7 +47,7 @@ class Card
|
|
45
47
|
end
|
46
48
|
|
47
49
|
def url_key_for_location location
|
48
|
-
|
50
|
+
%r{/([^/]*$)} =~ location ? Regexp.last_match[1] : nil
|
49
51
|
end
|
50
52
|
end
|
51
53
|
end
|
data/lib/card/env/success.rb
CHANGED
@@ -4,7 +4,9 @@ class Card
|
|
4
4
|
class Success
|
5
5
|
include Card::Env::Location
|
6
6
|
|
7
|
-
attr_accessor :
|
7
|
+
attr_accessor :redirect, :name, :name_context
|
8
|
+
attr_writer :params, :card
|
9
|
+
attr_reader :id
|
8
10
|
|
9
11
|
def initialize name_context=nil, success_args=nil
|
10
12
|
@name_context = name_context
|
data/lib/card/error.rb
CHANGED
@@ -6,6 +6,7 @@ class Card
|
|
6
6
|
class Error < StandardError
|
7
7
|
cattr_accessor :current
|
8
8
|
class_attribute :status_code, :view
|
9
|
+
attr_writer :backtrace
|
9
10
|
|
10
11
|
self.view = :errors
|
11
12
|
self.status_code = 422
|
@@ -25,6 +26,10 @@ class Card
|
|
25
26
|
scope: %i[lib card error], cardname: card.name, message: card_message_text
|
26
27
|
end
|
27
28
|
|
29
|
+
def backtrace
|
30
|
+
@backtrace || super
|
31
|
+
end
|
32
|
+
|
28
33
|
def report
|
29
34
|
Rails.logger.info "exception = #{self.class}: #{message}"
|
30
35
|
end
|
@@ -35,8 +40,15 @@ class Card
|
|
35
40
|
|
36
41
|
# error attributable to code (as opposed to card configuration)
|
37
42
|
class ServerError < Error
|
38
|
-
self.view
|
39
|
-
|
43
|
+
def self.view
|
44
|
+
Card[:debugger]&.content =~ /on/ ? :debug_server_error : :server_error
|
45
|
+
end
|
46
|
+
|
47
|
+
def self.status_code
|
48
|
+
# Errors with status code 900 are displayed as modal instead of inside
|
49
|
+
# the "card-notice" div``
|
50
|
+
Card[:debugger]&.content =~ /on/ ? 900 : 500
|
51
|
+
end
|
40
52
|
|
41
53
|
def report
|
42
54
|
super
|
@@ -52,6 +64,11 @@ class Card
|
|
52
64
|
class BadQuery < UserError
|
53
65
|
end
|
54
66
|
|
67
|
+
class BadAddress < UserError
|
68
|
+
self.status_code = 404
|
69
|
+
self.view = :bad_address
|
70
|
+
end
|
71
|
+
|
55
72
|
# card not found
|
56
73
|
class NotFound < UserError
|
57
74
|
self.status_code = 404
|
@@ -81,6 +98,10 @@ class Card
|
|
81
98
|
class Abort < StandardError
|
82
99
|
attr_reader :status
|
83
100
|
|
101
|
+
def report
|
102
|
+
Rails.logger.debug "aborting: #{message}"
|
103
|
+
end
|
104
|
+
|
84
105
|
def initialize status, msg=""
|
85
106
|
@status = status
|
86
107
|
super msg
|
@@ -92,13 +113,24 @@ class Card
|
|
92
113
|
KEY_MAP = { permission_denied: PermissionDenied,
|
93
114
|
conflict: EditConflict }.freeze
|
94
115
|
|
116
|
+
def report exception, card
|
117
|
+
e = cardify_exception exception, card
|
118
|
+
self.current = e
|
119
|
+
e.report
|
120
|
+
e
|
121
|
+
end
|
122
|
+
|
95
123
|
def cardify_exception exception, card
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
124
|
+
card_exception =
|
125
|
+
if exception.is_a? Card::Error
|
126
|
+
exception
|
127
|
+
else
|
128
|
+
card_error_class(exception, card).new exception.message
|
129
|
+
end
|
130
|
+
card_exception.card ||= card
|
131
|
+
card_exception.backtrace ||= exception.backtrace
|
132
|
+
add_card_errors card, card_exception if card.errors.empty?
|
133
|
+
card_exception
|
102
134
|
end
|
103
135
|
|
104
136
|
def add_card_errors card, exception
|
@@ -107,6 +139,8 @@ class Card
|
|
107
139
|
end
|
108
140
|
|
109
141
|
def card_error_class exception, card
|
142
|
+
# "simple" error messages are visible to end users and are generally not
|
143
|
+
# treated as software bugs (though they may be "shark" bugs)
|
110
144
|
case exception
|
111
145
|
when ActiveRecord::RecordInvalid
|
112
146
|
invalid_card_error_class card
|