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
@@ -59,6 +59,7 @@ end
|
|
59
59
|
RSpec.describe Card::Set::All::Notify do
|
60
60
|
# typically notifications are not sent on non-web-requests
|
61
61
|
before { described_class.force_notifications = true }
|
62
|
+
|
62
63
|
after { described_class.force_notifications = false }
|
63
64
|
|
64
65
|
def notification_email_for card_name, followed_set: "#{card_name}+*self"
|
@@ -67,7 +68,7 @@ RSpec.describe Card::Set::All::Notify do
|
|
67
68
|
Card[:follower_notification_email].format.mail(
|
68
69
|
context, { to: follower.email }, auth: follower,
|
69
70
|
active_notice: { follower: follower.name,
|
70
|
-
followed_set:
|
71
|
+
followed_set: followed_set,
|
71
72
|
follow_option: "*always" }
|
72
73
|
).text_part.body.raw_source
|
73
74
|
end
|
@@ -128,8 +129,8 @@ RSpec.describe Card::Set::All::Notify do
|
|
128
129
|
end
|
129
130
|
|
130
131
|
it "creates well formatted text message" do
|
131
|
-
path = File.expand_path "
|
132
|
-
email = notification_email_for("card with fields").
|
132
|
+
path = File.expand_path "notify_email.txt", __dir__
|
133
|
+
email = notification_email_for("card with fields").delete "\r"
|
133
134
|
expect(email).to eq(File.read(path))
|
134
135
|
end
|
135
136
|
end
|
@@ -1,43 +1,41 @@
|
|
1
|
-
|
2
|
-
describe "#send_change_notice" do
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
Card.fetch("A", look_in_trash: true),
|
7
|
-
{ to: "joe@user.com" },
|
1
|
+
RSpec.describe Card::Set::Right::Account do
|
2
|
+
describe "#send_change_notice" do
|
3
|
+
subject(:mail) do
|
4
|
+
follower = Card["Joe User"]
|
5
|
+
Card[:follower_notification_email].format.mail(
|
6
|
+
Card.fetch("A", look_in_trash: true), { to: "joe@user.com" },
|
8
7
|
auth: follower,
|
9
|
-
active_notice: {
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
)
|
15
|
-
end
|
8
|
+
active_notice: { follower: follower,
|
9
|
+
followed_set: Card[:all],
|
10
|
+
follow_option: Card[:always] }
|
11
|
+
)
|
12
|
+
end
|
16
13
|
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
14
|
+
it "works for deleted card" do
|
15
|
+
delete "A"
|
16
|
+
expect(mail.subject).to eq 'Joe User deleted "A"'
|
17
|
+
end
|
21
18
|
|
22
|
-
|
23
|
-
|
24
|
-
|
19
|
+
it "sends multipart email" do
|
20
|
+
expect(mail.content_type).to include("multipart/alternative")
|
21
|
+
end
|
25
22
|
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
23
|
+
context "when denied access" do
|
24
|
+
it "excludes protected subcards" do
|
25
|
+
skip
|
26
|
+
Card.create(name: "A+B+*self+*read", type: "Pointer", content: "[[u1]]")
|
30
27
|
|
31
|
-
|
32
|
-
|
28
|
+
u2 = Card.fetch "u2+*following", new: { type: "Pointer" }
|
29
|
+
u2.add_item "A"
|
33
30
|
|
34
|
-
|
31
|
+
a = Card.fetch "A"
|
35
32
|
a.update content: "new content",
|
36
33
|
subcards: { "+B" => { content: "hidden content" } }
|
37
|
-
|
34
|
+
end
|
38
35
|
|
39
|
-
|
40
|
-
|
36
|
+
it "sends no email if changes not visible" do
|
37
|
+
skip
|
38
|
+
end
|
41
39
|
end
|
42
40
|
end
|
43
41
|
end
|
@@ -1,17 +1,11 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-
|
2
2
|
|
3
|
-
describe Card::Set::Right::Following do
|
3
|
+
RSpec.describe Card::Set::Right::Following do
|
4
4
|
context "when admin is following" do
|
5
5
|
def card_subject
|
6
6
|
Card.fetch "Joe Admin", :following
|
7
7
|
end
|
8
8
|
|
9
|
-
|
10
|
-
end
|
11
|
-
|
12
|
-
specify "view core" do
|
13
|
-
expect_view(:core).to have_tag("div.card-slot") do
|
14
|
-
with_tag "div.menu-slot.nodblclick"
|
15
|
-
end
|
9
|
+
check_html_views_for_errors
|
16
10
|
end
|
17
11
|
end
|
data/mod/history/lib/card/act.rb
CHANGED
@@ -58,6 +58,12 @@ class Card
|
|
58
58
|
def cache
|
59
59
|
Card::Cache[Card::Act]
|
60
60
|
end
|
61
|
+
|
62
|
+
# used by rails time_ago
|
63
|
+
# timestamp is set by rails on create
|
64
|
+
def timestamp_attributes_for_create
|
65
|
+
super << "acted_at"
|
66
|
+
end
|
61
67
|
end
|
62
68
|
|
63
69
|
def actor
|
@@ -68,7 +74,8 @@ class Card
|
|
68
74
|
# @return [Card]
|
69
75
|
def card
|
70
76
|
res = Card.fetch card_id, look_in_trash: true, skip_modules: true
|
71
|
-
return res unless res
|
77
|
+
return res unless res&.type_id&.in?([FileID, ImageID])
|
78
|
+
|
72
79
|
res.include_set_modules
|
73
80
|
end
|
74
81
|
|
@@ -76,6 +83,7 @@ class Card
|
|
76
83
|
# @return [Array]
|
77
84
|
def actions cached=true
|
78
85
|
return ar_actions unless cached
|
86
|
+
|
79
87
|
self.class.cache.fetch("#{id}-actions") { ar_actions.find_all.to_a }
|
80
88
|
end
|
81
89
|
|
@@ -120,11 +128,5 @@ class Card
|
|
120
128
|
def assign_actor
|
121
129
|
self.actor_id ||= Auth.current_id
|
122
130
|
end
|
123
|
-
|
124
|
-
# used by rails time_ago
|
125
|
-
# timestamp is set by rails on create
|
126
|
-
def self.timestamp_attributes_for_create
|
127
|
-
super << "acted_at"
|
128
|
-
end
|
129
131
|
end
|
130
132
|
end
|
@@ -26,6 +26,7 @@ class Card
|
|
26
26
|
|
27
27
|
def render
|
28
28
|
return "" unless @act_card
|
29
|
+
|
29
30
|
act_accordion
|
30
31
|
end
|
31
32
|
|
@@ -56,9 +57,10 @@ class Card
|
|
56
57
|
|
57
58
|
def summary
|
58
59
|
%i[create update delete draft].map do |type|
|
59
|
-
next unless count_types[type]
|
60
|
-
|
61
|
-
|
60
|
+
next unless count_types[type].positive?
|
61
|
+
|
62
|
+
"#{@format.action_icon type}<small> #{count_types[type]}</small>"
|
63
|
+
end.compact.join "<small class='text-muted'> | </small>"
|
62
64
|
end
|
63
65
|
|
64
66
|
def act_links
|
@@ -80,7 +82,7 @@ class Card
|
|
80
82
|
end
|
81
83
|
|
82
84
|
def approved_actions
|
83
|
-
@approved_actions ||= actions
|
85
|
+
@approved_actions ||= actions # .select { |a| a.card && a.card.ok?(:read) }
|
84
86
|
# FIXME: should not need to test for presence of card here.
|
85
87
|
end
|
86
88
|
|
@@ -101,6 +103,7 @@ class Card
|
|
101
103
|
|
102
104
|
def edited_ago
|
103
105
|
return "" unless @act.acted_at
|
106
|
+
|
104
107
|
"#{time_ago_in_words(@act.acted_at)} ago"
|
105
108
|
end
|
106
109
|
|
@@ -171,9 +174,9 @@ class Card
|
|
171
174
|
# not current, not deletion
|
172
175
|
def rollback_link
|
173
176
|
return unless card.ok? :update
|
174
|
-
wrap_with :div, class: "act-link collapse #{collapse_id} float-right" do
|
175
|
-
revert_link
|
176
177
|
|
178
|
+
wrap_with :div, class: "act-link collapse #{collapse_id} float-right" do
|
179
|
+
content_tag(:small, revert_link)
|
177
180
|
|
178
181
|
# link_to "Save as current",
|
179
182
|
# class: "slotter", remote: true,
|
@@ -186,10 +189,11 @@ class Card
|
|
186
189
|
|
187
190
|
def revert_link
|
188
191
|
revert_actions_link "revert to this", revert_to: :this,
|
189
|
-
|
192
|
+
slot_selector: ".card-slot.history-view"
|
190
193
|
end
|
191
194
|
|
192
|
-
def revert_actions_link link_text,
|
195
|
+
def revert_actions_link link_text,
|
196
|
+
revert_to: :this, slot_selector: nil, html_args: {}
|
193
197
|
@format.revert_actions_link @act, link_text,
|
194
198
|
revert_to: revert_to,
|
195
199
|
slot_selector: slot_selector,
|
@@ -208,7 +212,6 @@ class Card
|
|
208
212
|
wrap_with :div, class: "act-link" do
|
209
213
|
@format.link_to_view(
|
210
214
|
:act, "#{@args[:hide_diff] ? 'Show' : 'Hide'} changes",
|
211
|
-
class: "slotter",
|
212
215
|
path: { act_id: @args[:act].id, act_seq: @args[:act_seq],
|
213
216
|
hide_diff: !@args[:hide_diff], action_view: :expanded,
|
214
217
|
act_context: @args[:act_context], look_in_trash: true }
|
@@ -19,8 +19,8 @@ class Card
|
|
19
19
|
end
|
20
20
|
|
21
21
|
def revert_link
|
22
|
-
revert_actions_link "revert to previous version",
|
23
|
-
slot_selector: "#main > .card-slot"
|
22
|
+
revert_actions_link "revert to previous version",
|
23
|
+
revert_to: :previous, slot_selector: "#main > .card-slot"
|
24
24
|
end
|
25
25
|
|
26
26
|
def actions
|
@@ -0,0 +1,53 @@
|
|
1
|
+
class Card
|
2
|
+
class Act
|
3
|
+
class ActRenderer
|
4
|
+
# Used for the bridge
|
5
|
+
class BridgeActRenderer < RelativeActRenderer
|
6
|
+
def title
|
7
|
+
wrap_with(:div, left_title, class: "mr-2") +
|
8
|
+
wrap_with(:div, right_title, class: "ml-auto")
|
9
|
+
end
|
10
|
+
|
11
|
+
def left_title
|
12
|
+
["##{@args[:act_seq]}", @act.actor.name, wrap_with(:small, edited_ago)].join " "
|
13
|
+
end
|
14
|
+
|
15
|
+
def right_title
|
16
|
+
summary
|
17
|
+
end
|
18
|
+
|
19
|
+
def render
|
20
|
+
return "" unless @act_card
|
21
|
+
|
22
|
+
details
|
23
|
+
end
|
24
|
+
|
25
|
+
def bridge_link
|
26
|
+
opts = @format.bridge_link_opts(
|
27
|
+
path: { act_id: @act.id, view: :bridge_act, act_seq: @args[:act_seq] },
|
28
|
+
"data-toggle": "pill"
|
29
|
+
)
|
30
|
+
add_class opts, "d-flex nav-link"
|
31
|
+
opts[:path].delete :layout
|
32
|
+
link_to_card @card, title, opts
|
33
|
+
end
|
34
|
+
|
35
|
+
def overlay_title
|
36
|
+
wrap_with :div do
|
37
|
+
[left_title, summary,
|
38
|
+
subtitle.present? ? subtitle : nil,
|
39
|
+
rollback_or_edit_link].compact.join " | "
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
def rollback_or_edit_link
|
44
|
+
if @act.draft?
|
45
|
+
autosaved_draft_link text: "continue editing"
|
46
|
+
elsif show_rollback_link?
|
47
|
+
revert_link
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
@@ -14,11 +14,13 @@ class Card
|
|
14
14
|
|
15
15
|
def subtitle
|
16
16
|
return "" unless @act.card_id != @format.card.id
|
17
|
+
|
17
18
|
wrap_with :small, "act on #{absolute_title}"
|
18
19
|
end
|
19
20
|
|
20
21
|
def act_links
|
21
22
|
return unless (content = rollback_or_edit_link)
|
23
|
+
|
22
24
|
wrap_with :small, content
|
23
25
|
end
|
24
26
|
|
@@ -37,6 +39,7 @@ class Card
|
|
37
39
|
|
38
40
|
def current_act?
|
39
41
|
return unless @format.card.last_act && @act
|
42
|
+
|
40
43
|
@act.id == @format.card.last_act.id
|
41
44
|
end
|
42
45
|
|
@@ -106,6 +106,7 @@ class Card
|
|
106
106
|
# @return [Symbol]
|
107
107
|
def action_type
|
108
108
|
return :draft if draft
|
109
|
+
|
109
110
|
TYPE_OPTIONS[read_attribute(:action_type)]
|
110
111
|
end
|
111
112
|
|
@@ -118,6 +119,7 @@ class Card
|
|
118
119
|
# @see #interpret_value #interpret_value for return values
|
119
120
|
def value field
|
120
121
|
return unless (change = change field)
|
122
|
+
|
121
123
|
interpret_value field, change.value
|
122
124
|
end
|
123
125
|
|
@@ -127,6 +129,7 @@ class Card
|
|
127
129
|
def previous_value field
|
128
130
|
return if action_type == :create
|
129
131
|
return unless (previous_change = previous_change field)
|
132
|
+
|
130
133
|
interpret_value field, previous_change.value
|
131
134
|
end
|
132
135
|
|
@@ -142,8 +145,9 @@ class Card
|
|
142
145
|
# @return [Change]
|
143
146
|
def previous_change field
|
144
147
|
return nil if action_type == :create
|
148
|
+
|
145
149
|
field = interpret_field field
|
146
|
-
if @previous_changes
|
150
|
+
if @previous_changes&.key?(field)
|
147
151
|
@previous_changes[field]
|
148
152
|
else
|
149
153
|
@previous_changes ||= {}
|
@@ -172,7 +176,7 @@ class Card
|
|
172
176
|
|
173
177
|
# all changed values in hash form. { field1: new_value }
|
174
178
|
def changed_values
|
175
|
-
@changed_values ||= changes.each_with_object({}) do |(key,change), h|
|
179
|
+
@changed_values ||= changes.each_with_object({}) do |(key, change), h|
|
176
180
|
h[key] = change.value
|
177
181
|
end
|
178
182
|
end
|
@@ -180,6 +184,7 @@ class Card
|
|
180
184
|
# @return [Hash]
|
181
185
|
def current_changes
|
182
186
|
return {} unless card
|
187
|
+
|
183
188
|
@current_changes ||=
|
184
189
|
Card::Change::TRACKED_FIELDS.each_with_object({}) do |field, hash|
|
185
190
|
hash[field.to_sym] = Card::Change.new field: field,
|
@@ -209,10 +214,10 @@ class Card
|
|
209
214
|
def interpret_value field, value
|
210
215
|
case field.to_sym
|
211
216
|
when :type_id
|
212
|
-
value
|
217
|
+
value&.to_i
|
213
218
|
when :cardtype
|
214
219
|
type_card = value && Card.quick_fetch(value.to_i)
|
215
|
-
type_card
|
220
|
+
type_card&.name&.capitalize
|
216
221
|
else value
|
217
222
|
end
|
218
223
|
end
|
@@ -24,10 +24,11 @@ class Card
|
|
24
24
|
end
|
25
25
|
|
26
26
|
def render
|
27
|
+
classes = @format.classy("action-list")
|
27
28
|
bs_layout container: true, fluid: true do
|
28
29
|
row do
|
29
30
|
html <<-HTML
|
30
|
-
<ul class="
|
31
|
+
<ul class="#{classes} w-100">
|
31
32
|
<li class="#{action.action_type}">
|
32
33
|
#{action_panel}
|
33
34
|
</li>
|
@@ -58,8 +59,6 @@ class Card
|
|
58
59
|
link_to_view(
|
59
60
|
:related, name_changes,
|
60
61
|
path: { slot: { items: { view: "history", nest_name: @action.card.name } } },
|
61
|
-
remote: true,
|
62
|
-
class: "slotter",
|
63
62
|
# "data-slot-selector" => ".card-slot.history-view"
|
64
63
|
)
|
65
64
|
end
|
@@ -67,16 +66,19 @@ class Card
|
|
67
66
|
|
68
67
|
def content_diff
|
69
68
|
return @action.raw_view if @action.action_type == :delete
|
69
|
+
|
70
70
|
@format.subformat(@action.card).render_action_summary action_id: @action.id
|
71
71
|
end
|
72
72
|
|
73
73
|
def type_diff
|
74
74
|
return "" unless @action.new_type?
|
75
|
+
|
75
76
|
@hide_diff ? @action.value(:cardtype) : @action.cardtype_diff
|
76
77
|
end
|
77
78
|
|
78
79
|
def name_changes
|
79
80
|
return old_name unless @action.new_name?
|
81
|
+
|
80
82
|
@hide_diff ? new_name : Card::Content::Diff.complete(old_name, new_name)
|
81
83
|
end
|
82
84
|
|
@@ -6,6 +6,7 @@ class Card
|
|
6
6
|
# @return [rendered diff]
|
7
7
|
def name_diff opts={}
|
8
8
|
return unless new_name?
|
9
|
+
|
9
10
|
diff_object(:name, opts).complete
|
10
11
|
end
|
11
12
|
|
@@ -19,6 +20,7 @@ class Card
|
|
19
20
|
# compare action's cardtype value with previous cardtype value
|
20
21
|
def cardtype_diff opts={}
|
21
22
|
return unless new_type?
|
23
|
+
|
22
24
|
diff_object(:cardtype, opts).complete
|
23
25
|
end
|
24
26
|
|
@@ -32,6 +34,7 @@ class Card
|
|
32
34
|
# compare action's content value with previous content value
|
33
35
|
def content_diff diff_type=:expanded, opts=nil
|
34
36
|
return unless new_content?
|
37
|
+
|
35
38
|
dobj = content_diff_object(opts)
|
36
39
|
diff_type == :summary ? dobj.summary : dobj.complete
|
37
40
|
end
|