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
@@ -1,6 +1,6 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-require 'image_spec'
|
2
2
|
|
3
|
-
describe Card::Set::Type::Image do
|
3
|
+
RSpec.describe Card::Set::Type::Image do
|
4
4
|
it "has special editor" do
|
5
5
|
assert_view_select render_editor("Image"), 'div[class="choose-file"]' do
|
6
6
|
assert_select 'input[class~="file-upload slotter"]'
|
@@ -96,17 +96,17 @@ describe Card::Set::Type::Image do
|
|
96
96
|
end
|
97
97
|
end
|
98
98
|
|
99
|
-
describe "
|
100
|
-
subject { Card[:
|
99
|
+
describe "mod image" do
|
100
|
+
subject { Card[:cerulean_skin_image] }
|
101
101
|
|
102
102
|
it "exists" do
|
103
103
|
expect(subject.image.size).to be > 0
|
104
104
|
end
|
105
105
|
it "has correct url" do
|
106
|
-
expect(subject.image.url).to eq "/files/:
|
106
|
+
expect(subject.image.url).to eq "/files/:cerulean_skin_image/bootstrap-original.png"
|
107
107
|
end
|
108
108
|
it "has correct url as content" do
|
109
|
-
expect(subject.content).to eq ":#{subject.codename}/
|
109
|
+
expect(subject.content).to eq ":#{subject.codename}/bootstrap.png"
|
110
110
|
end
|
111
111
|
|
112
112
|
it "becomes a regular file when changed" do
|
@@ -129,7 +129,7 @@ describe Card::Set::Type::Image do
|
|
129
129
|
describe "source view" do
|
130
130
|
it "renders url with original version" do
|
131
131
|
expect(subject.format.render_source)
|
132
|
-
.to eq "/files/:#{subject.codename}/
|
132
|
+
.to eq "/files/:#{subject.codename}/bootstrap-medium.png"
|
133
133
|
end
|
134
134
|
end
|
135
135
|
end
|
data/mod/core/chunk/nest.rb
CHANGED
@@ -56,7 +56,7 @@ class Card
|
|
56
56
|
if key == :item
|
57
57
|
options_hash[:items] ||= {}
|
58
58
|
options_hash[:items][:view] = value
|
59
|
-
elsif Card::View::Options.
|
59
|
+
elsif Card::View::Options.shark_keys.include? key
|
60
60
|
options_hash[key] = value
|
61
61
|
# else
|
62
62
|
# handle other keys
|
@@ -92,6 +92,14 @@ class Card
|
|
92
92
|
end
|
93
93
|
end
|
94
94
|
|
95
|
+
def main?
|
96
|
+
nest_name == "_main"
|
97
|
+
end
|
98
|
+
|
99
|
+
def nest_name
|
100
|
+
options&.dig :nest_name
|
101
|
+
end
|
102
|
+
|
95
103
|
private
|
96
104
|
|
97
105
|
def each_option attr_string
|
@@ -4,20 +4,18 @@ require_dependency "card/content/diff"
|
|
4
4
|
|
5
5
|
class Card
|
6
6
|
class Format
|
7
|
+
# Main Format class for formatting card views in HTML
|
7
8
|
class HtmlFormat < Format
|
8
9
|
register :html
|
9
10
|
|
10
11
|
attr_accessor :options_need_save, :start_time, :skip_autosave
|
11
12
|
|
12
|
-
# TODO: use CodeFile cards for these
|
13
|
-
# builtin layouts allow for rescue / testing
|
14
|
-
LAYOUTS = Mod::Loader.load_layouts.merge "none" => "{{_main}}"
|
15
|
-
|
16
13
|
def main?
|
17
14
|
!@main.nil?
|
18
15
|
end
|
19
16
|
|
20
|
-
|
17
|
+
# is the current card the requested card?
|
18
|
+
def focal?
|
21
19
|
show_layout? ? main? : depth.zero?
|
22
20
|
end
|
23
21
|
|
@@ -27,51 +25,17 @@ class Card
|
|
27
25
|
end
|
28
26
|
|
29
27
|
def default_item_view
|
30
|
-
:
|
31
|
-
end
|
32
|
-
|
33
|
-
# helper methods for layout view
|
34
|
-
def get_layout_content requested_layout
|
35
|
-
Auth.as_bot do
|
36
|
-
if requested_layout
|
37
|
-
layout_from_card_or_code requested_layout
|
38
|
-
else
|
39
|
-
layout_from_rule
|
40
|
-
end
|
41
|
-
end
|
42
|
-
end
|
43
|
-
|
44
|
-
def layout_from_rule
|
45
|
-
if (rule = card.rule_card :layout) &&
|
46
|
-
(rule.type_id == Card::PointerID) &&
|
47
|
-
(layout_name = rule.item_name)
|
48
|
-
layout_from_card_or_code layout_name
|
49
|
-
end
|
50
|
-
end
|
51
|
-
|
52
|
-
def layout_from_card_or_code name
|
53
|
-
layout_card = Card.quick_fetch name
|
54
|
-
if layout_card && layout_card.ok?(:read)
|
55
|
-
layout_card.content
|
56
|
-
elsif (hardcoded_layout = LAYOUTS[name])
|
57
|
-
hardcoded_layout
|
58
|
-
else
|
59
|
-
content_tag(:h1, I18n.t(:unknown_layout, scope: "mod.core.format.html_format",
|
60
|
-
name: name)) +
|
61
|
-
I18n.t(:built_in, scope: "mod.core.format.html_format",
|
62
|
-
built_in_layouts: LAYOUTS.keys.join(', '))
|
63
|
-
end
|
64
|
-
end
|
65
|
-
|
66
|
-
def html_escape_except_quotes s
|
67
|
-
# to be used inside single quotes (makes for readable json attributes)
|
68
|
-
s.to_s.gsub(/&/, "&").gsub(/\'/, "'")
|
69
|
-
.gsub(/>/, ">").gsub(/</, "<")
|
28
|
+
:mini_bar
|
70
29
|
end
|
71
30
|
|
72
31
|
def mime_type
|
73
32
|
"text/html"
|
74
33
|
end
|
34
|
+
|
35
|
+
def final_render_call method
|
36
|
+
rendered = super
|
37
|
+
rendered.is_a?(Array) ? output(rendered) : rendered
|
38
|
+
end
|
75
39
|
end
|
76
40
|
end
|
77
41
|
end
|
data/mod/core/layout/blank.html
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
1
|
+
<body>
|
2
|
+
{{_main}}
|
3
|
+
</body>
|
4
|
+
|
5
|
+
|
@@ -1,10 +1,12 @@
|
|
1
|
-
<!DOCTYPE HTML>
|
2
1
|
<html>
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
</
|
2
|
+
<head>
|
3
|
+
myhead
|
4
|
+
</head>
|
5
|
+
|
6
|
+
<body class="right-sidebar">
|
7
|
+
<header>{{*header|core}}</header>
|
8
|
+
<article>{{_main|open}}</article>
|
9
|
+
<aside>{{*sidebar|core}}</aside>
|
10
|
+
<footer>{{*footer|core}}</footer>
|
11
|
+
</body>
|
10
12
|
</html>
|
data/mod/core/layout/noside.html
CHANGED
@@ -1,9 +1,6 @@
|
|
1
|
-
|
2
|
-
<
|
3
|
-
<
|
4
|
-
<
|
5
|
-
|
6
|
-
|
7
|
-
<footer>{{*footer|core}}</footer>
|
8
|
-
</body>
|
9
|
-
</html>
|
1
|
+
<body>
|
2
|
+
<header>{{*header|core}}</header>
|
3
|
+
<article>{{_main|open}}</article>
|
4
|
+
<footer>{{*footer|core}}</footer>
|
5
|
+
</body>
|
6
|
+
|
data/mod/core/layout/pre.html
CHANGED
@@ -1,2 +1 @@
|
|
1
|
-
|
2
|
-
<html> <body><pre>{{_main|raw}}</pre></body> </html>
|
1
|
+
<body><pre>{{_main|raw}}</pre></body>
|
data/mod/core/layout/simple.html
CHANGED
data/mod/core/set/all/cache.rb
CHANGED
@@ -38,11 +38,13 @@ def collection?
|
|
38
38
|
item_cards != [self]
|
39
39
|
end
|
40
40
|
|
41
|
-
format
|
41
|
+
format do
|
42
42
|
view :count do
|
43
43
|
card.item_names.size
|
44
44
|
end
|
45
|
+
end
|
45
46
|
|
47
|
+
format :html do
|
46
48
|
view :carousel do
|
47
49
|
bs_carousel unique_id, 0 do
|
48
50
|
nest_item_array.each do |rendered_item|
|
@@ -1,5 +1,5 @@
|
|
1
1
|
def event_applies? event
|
2
|
-
return unless set_condition_applies? event.set_module
|
2
|
+
return unless set_condition_applies? event.set_module, event.opts.key?(:changing)
|
3
3
|
|
4
4
|
Card::Set::Event::CONDITIONS.all? do |key|
|
5
5
|
send "#{key}_condition_applies?", event, event.opts[key]
|
@@ -8,9 +8,14 @@ end
|
|
8
8
|
|
9
9
|
private
|
10
10
|
|
11
|
-
|
12
|
-
|
13
|
-
|
11
|
+
# existing card is being changed in a way that alters its sets
|
12
|
+
def updating_sets?
|
13
|
+
@action == :update && real? && (type_id_is_changing? || name_is_changing?)
|
14
|
+
end
|
15
|
+
|
16
|
+
def set_condition_applies? set_module, old_sets
|
17
|
+
return true if set_module == Card
|
18
|
+
set_condition_card(old_sets).singleton_class.include? set_module
|
14
19
|
end
|
15
20
|
|
16
21
|
def on_condition_applies? _event, actions
|
@@ -19,12 +24,39 @@ def on_condition_applies? _event, actions
|
|
19
24
|
actions.include? @action
|
20
25
|
end
|
21
26
|
|
27
|
+
# if changing name/type, the old card has no-longer-applicable set modules, so we create
|
28
|
+
# a new card to determine whether events apply.
|
29
|
+
# (note: cached condition card would ideally be cleared after all
|
30
|
+
# conditions are reviewed)
|
31
|
+
# @param old_sets [True/False] whether to use the old_sets
|
32
|
+
def set_condition_card old_sets
|
33
|
+
return self if old_sets || no_current_action?
|
34
|
+
@set_condition_card ||=
|
35
|
+
updating_sets? ? set_condition_card_with_new_set_modules : self
|
36
|
+
end
|
37
|
+
|
38
|
+
# prevents locking in set_condition_card
|
39
|
+
def no_current_action?
|
40
|
+
return false if @current_action
|
41
|
+
|
42
|
+
@set_condition_card = nil
|
43
|
+
true
|
44
|
+
end
|
45
|
+
|
46
|
+
def set_condition_card_with_new_set_modules
|
47
|
+
cc = Card.find id
|
48
|
+
cc.name = name
|
49
|
+
cc.type_id = type_id
|
50
|
+
cc.include_set_modules
|
51
|
+
end
|
52
|
+
|
22
53
|
def changed_condition_applies? _event, db_columns
|
23
54
|
return true unless @action == :update
|
24
55
|
db_columns = Array(db_columns).compact
|
25
56
|
return true if db_columns.empty?
|
26
57
|
db_columns.any? { |col| single_changed_condition_applies? col }
|
27
58
|
end
|
59
|
+
alias_method :changing_condition_applies?, :changed_condition_applies?
|
28
60
|
|
29
61
|
def when_condition_applies? _event, block
|
30
62
|
case block
|
data/mod/core/set/all/export.rb
CHANGED
@@ -51,7 +51,7 @@ format :json do
|
|
51
51
|
|
52
52
|
def items_for_export
|
53
53
|
nest_chunks.map do |chunk|
|
54
|
-
next if
|
54
|
+
next if chunk.try :main?
|
55
55
|
chunk.referee_card
|
56
56
|
end.compact
|
57
57
|
end
|
@@ -65,13 +65,4 @@ format :json do
|
|
65
65
|
def valid_export_card? ecard
|
66
66
|
ecard.real? && !@exported_keys.include?(ecard.key)
|
67
67
|
end
|
68
|
-
|
69
|
-
def main_nest_chunk? chunk
|
70
|
-
chunk_nest_name(chunk) == "_main"
|
71
|
-
end
|
72
|
-
|
73
|
-
def chunk_nest_name chunk
|
74
|
-
return unless chunk.respond_to? :options
|
75
|
-
chunk.options&.dig :nest_name
|
76
|
-
end
|
77
68
|
end
|
data/mod/core/set/all/haml.rb
CHANGED
@@ -58,10 +58,11 @@ format do
|
|
58
58
|
haml_to_html(*args)
|
59
59
|
end
|
60
60
|
|
61
|
-
def process_haml_template template_name,
|
61
|
+
def process_haml_template template_name, *args
|
62
|
+
locals = args.first || {}
|
62
63
|
path = identify_template_path template_name, locals
|
63
64
|
with_template_path path do
|
64
|
-
haml_to_html ::File.read(path),
|
65
|
+
haml_to_html ::File.read(path), *args
|
65
66
|
end
|
66
67
|
# rescue => e
|
67
68
|
# raise Card::Error, "HAML error #{template_name}: #{e.message}\n#{e.backtrace}"
|
@@ -0,0 +1,34 @@
|
|
1
|
+
format :html do
|
2
|
+
attr_reader :interior
|
3
|
+
|
4
|
+
def layout_nest
|
5
|
+
wrap_main { interior }
|
6
|
+
end
|
7
|
+
|
8
|
+
layout :pre do # {{_main|raw}}
|
9
|
+
wrap_with :pre do
|
10
|
+
layout_nest
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
layout :simple do
|
15
|
+
layout_nest
|
16
|
+
end
|
17
|
+
|
18
|
+
layout :no_side do # {{_main|open}}
|
19
|
+
<<-HTML.strip_heredoc
|
20
|
+
<header>#{nest :header, view: :core}</header>
|
21
|
+
<article>#{layout_nest}</article>
|
22
|
+
<footer>{nest :footer, view: :core}</footer>
|
23
|
+
HTML
|
24
|
+
end
|
25
|
+
|
26
|
+
layout :default do
|
27
|
+
<<-HTML.strip_heredoc
|
28
|
+
<header>#{nest :header, view: :core}</header>
|
29
|
+
<article>#{layout_nest}</article>
|
30
|
+
<aside>#{nest :sidebar, view: :core}</aside>
|
31
|
+
<footer>{nest :footer, view: :core}</footer>
|
32
|
+
HTML
|
33
|
+
end
|
34
|
+
end
|
data/mod/core/set/all/pattern.rb
CHANGED
@@ -16,17 +16,12 @@ def reset_patterns
|
|
16
16
|
true
|
17
17
|
end
|
18
18
|
|
19
|
-
def reset_patterns_if_rule
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
# FIXME: should be in right/read.rb
|
26
|
-
if saving && right.id == Card::ReadID
|
27
|
-
add_to_read_rule_update_queue set.item_cards(limit: 0)
|
28
|
-
end
|
29
|
-
end
|
19
|
+
def reset_patterns_if_rule _saving=false
|
20
|
+
return unless real? && is_rule? && (set = left)
|
21
|
+
|
22
|
+
set.reset_patterns
|
23
|
+
set.include_set_modules
|
24
|
+
set
|
30
25
|
end
|
31
26
|
|
32
27
|
def safe_set_keys
|
data/mod/core/set/all/utils.rb
CHANGED
@@ -32,6 +32,7 @@ module ClassMethods
|
|
32
32
|
# puts "merging #{name}"
|
33
33
|
card = fetch name, new: {}
|
34
34
|
return unless mergeable? card, opts[:pristine]
|
35
|
+
|
35
36
|
resolve_file_attributes! attribs
|
36
37
|
card.safe_update! attribs
|
37
38
|
end
|
@@ -41,17 +42,19 @@ module ClassMethods
|
|
41
42
|
def resolve_file_attributes! attribs
|
42
43
|
%i[image file].each do |attach|
|
43
44
|
next unless attribs[attach] && attribs[attach].is_a?(String)
|
45
|
+
|
44
46
|
attribs[attach] = ::File.open(attribs[attach])
|
45
47
|
end
|
46
48
|
end
|
47
49
|
|
48
50
|
def mergeable? card, pristine_only
|
49
51
|
return true unless pristine_only
|
52
|
+
|
50
53
|
!card.pristine?
|
51
54
|
end
|
52
55
|
end
|
53
56
|
|
54
|
-
#
|
57
|
+
# separate name and other attributes
|
55
58
|
def safe_update! attribs
|
56
59
|
separate_name_update! attribs.delete("name") unless new?
|
57
60
|
update! attribs if attribs.present?
|
@@ -62,3 +65,20 @@ def separate_name_update! new_name
|
|
62
65
|
|
63
66
|
update! name: new_name
|
64
67
|
end
|
68
|
+
|
69
|
+
# rubocop:disable Style/GlobalVars
|
70
|
+
def measure desc
|
71
|
+
$times ||= {}
|
72
|
+
res = nil
|
73
|
+
t = Benchmark.measure do
|
74
|
+
res = yield
|
75
|
+
end
|
76
|
+
$times[desc] = $times.key?(desc) ? t + $times[desc] : t
|
77
|
+
puts "#{desc}: #{t}".red
|
78
|
+
res
|
79
|
+
end
|
80
|
+
# rubocop:enable Style/GlobalVars
|
81
|
+
|
82
|
+
format do
|
83
|
+
delegate :measure, to: :card
|
84
|
+
end
|