card 1.101.0 → 1.101.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (287) hide show
  1. checksums.yaml +4 -4
  2. data/VERSION +1 -1
  3. data/config/i18n-tasks.yml +0 -5
  4. data/config/initializers/01_core_extensions/array.rb +2 -1
  5. data/config/initializers/01_core_extensions/hash.rb +1 -0
  6. data/config/initializers/01_core_extensions/object.rb +15 -11
  7. data/config/initializers/02_patches/active_job.rb +1 -1
  8. data/config/initializers/02_patches/active_record.rb +2 -4
  9. data/config/initializers/02_patches/better_errors.rb +1 -3
  10. data/config/initializers/02_patches/kaminari.rb +2 -2
  11. data/config/initializers/deck_config.rb +1 -1
  12. data/config/initializers/inflections.rb +1 -0
  13. data/config/initializers/internationalization.rb +23 -21
  14. data/config/initializers/mime_types.rb +1 -0
  15. data/config/initializers/notification.rb +1 -0
  16. data/config/initializers/patches.rb +6 -5
  17. data/config/locales/en.yml +137 -525
  18. data/db/migrate/20110511221913_require_earlier_migrations.rb +1 -0
  19. data/db/migrate/20121111025347_require_1_10_migrations.rb +1 -0
  20. data/db/migrate/20121118114000_split_link_type.rb +1 -0
  21. data/db/migrate/20121118115000_update_link_type.rb +1 -0
  22. data/db/migrate/20130106052640_table_cleanup.rb +2 -2
  23. data/db/migrate/20130109015336_trunk_left.rb +1 -0
  24. data/db/migrate/20130411210957_update_codenames.rb +1 -0
  25. data/db/migrate/20140822073704_create_new_revision_tables.rb +1 -0
  26. data/db/migrate/20141001105348_move_revisions_to_actions.rb +9 -3
  27. data/db/migrate/20141216053032_better_index_names.rb +9 -6
  28. data/db/migrate/20170908114442_create_delayed_jobs.rb +1 -1
  29. data/db/migrate/20170908114452_increase_text_size_for_delayed_jobs.rb +1 -1
  30. data/db/migrate/20180514152037_add_card_virtuals_table.rb +1 -1
  31. data/db/migrate_core_cards/20120611203506_rails_inflection_updates.rb +3 -2
  32. data/db/migrate_core_cards/20130411191151_renaming_for_menu.rb +9 -9
  33. data/db/migrate_core_cards/20130419215612_import_help_text.rb +3 -2
  34. data/db/migrate_core_cards/20130823192433_add_style_cards.rb +5 -5
  35. data/db/migrate_core_cards/20130910183318_move_styles_to_content.rb +3 -2
  36. data/db/migrate_core_cards/20130920291703_update_stylesheets.rb +2 -4
  37. data/db/migrate_core_cards/20131016172445_common_css_patch.rb +1 -3
  38. data/db/migrate_core_cards/20140110193325_reset_account_request_type.rb +1 -3
  39. data/db/migrate_core_cards/20140307231621_user_data_to_cards.rb +12 -8
  40. data/db/migrate_core_cards/20140317035504_account_requests_to_signups.rb +2 -4
  41. data/db/migrate_core_cards/20140512155840_add_script_cards.rb +16 -9
  42. data/db/migrate_core_cards/20140629222005_add_email_cards.rb +19 -11
  43. data/db/migrate_core_cards/20140725180118_config_card_updates.rb +1 -1
  44. data/db/migrate_core_cards/20141115034214_config_descriptions_etc.rb +1 -1
  45. data/db/migrate_core_cards/20141119001955_make_symlinks_relative.rb +1 -1
  46. data/db/migrate_core_cards/20141204061304_watchers_to_following.rb +2 -0
  47. data/db/migrate_core_cards/20141216155251_add_more_following_cards.rb +4 -2
  48. data/db/migrate_core_cards/20150202143810_import_bootstrap_layout.rb +2 -2
  49. data/db/migrate_core_cards/20150220134731_following_to_follow_rule.rb +3 -4
  50. data/db/migrate_core_cards/20150317162412_bootstrap_themes.rb +8 -4
  51. data/db/migrate_core_cards/20150326205655_bootswatch_themes.rb +14 -7
  52. data/db/migrate_core_cards/20150429090551_search_card_context.rb +6 -4
  53. data/db/migrate_core_cards/20150508212032_menu_compatibility.rb +4 -2
  54. data/db/migrate_core_cards/20150510031118_fix_skin_codenames.rb +2 -1
  55. data/db/migrate_core_cards/20150601133433_add_recent_setting_session_card.rb +3 -3
  56. data/db/migrate_core_cards/20150610171702_add_debugger_session_card.rb +2 -1
  57. data/db/migrate_core_cards/20150610180019_add_recaptcha_key_and_admin_info_cards.rb +4 -3
  58. data/db/migrate_core_cards/20150724123438_update_file_and_image_cards.rb +6 -2
  59. data/db/migrate_core_cards/20150807205221_create_references_for_search_cards.rb +1 -1
  60. data/db/migrate_core_cards/20150824135418_update_file_history.rb +2 -0
  61. data/db/migrate_core_cards/20160804112510_reorganize_scripts.rb +1 -1
  62. data/db/migrate_core_cards/20160811115836_rename_stats_to_admin.rb +1 -0
  63. data/db/migrate_core_cards/20160914132636_fix_mod_files.rb +2 -0
  64. data/db/migrate_core_cards/20161102202156_tweak_recaptcha_setting_cards.rb +6 -6
  65. data/db/migrate_core_cards/20161103154836_update_keys.rb +2 -1
  66. data/db/migrate_core_cards/20170209132834_email_test_context.rb +2 -0
  67. data/db/migrate_core_cards/20170314175313_add_notification_event_card.rb +3 -3
  68. data/db/migrate_core_cards/20170515101262_add_advanced_edit_cards.rb +1 -1
  69. data/db/migrate_core_cards/20170608200649_add_input_options_codename.rb +1 -1
  70. data/db/migrate_core_cards/20180712042655_head_rule.rb +3 -4
  71. data/db/migrate_core_cards/20180905061537_migrate_layouts.rb +4 -4
  72. data/db/migrate_core_cards/20181120200937_update_layout.rb +1 -1
  73. data/db/migrate_core_cards/20190320091257_upgrade_recaptcha_to_v3.rb +7 -7
  74. data/db/migrate_core_cards/20190424100531_update_credit_image.rb +1 -0
  75. data/db/migrate_core_cards/20190502130029_add_shark_and_help_desk_role.rb +15 -14
  76. data/db/migrate_core_cards/20190503122739_update_pristine_data.rb +1 -1
  77. data/db/migrate_core_cards/20190625153616_pointer_overhaul.rb +9 -5
  78. data/db/migrate_core_cards/20190718140126_add_guides.rb +3 -3
  79. data/db/migrate_core_cards/20190822093633_move_help_text_to_code.rb +1 -2
  80. data/db/migrate_core_cards/20190823220018_cleanup_for_decko_1_0.rb +1 -1
  81. data/db/migrate_core_cards/20190829093961_cardtype_grouping.rb +7 -7
  82. data/db/migrate_core_cards/20190902193208_input_type.rb +1 -3
  83. data/db/migrate_core_cards/20190909104250_add_cardtype_input_types.rb +2 -2
  84. data/db/migrate_core_cards/20191028135243_add_link_editor_to_tiny_mce_config.rb +1 -0
  85. data/db/migrate_core_cards/20191115160748_history_cleanup.rb +0 -1
  86. data/db/migrate_core_cards/20191118145629_codename_fixes.rb +1 -2
  87. data/db/migrate_core_cards/20200821231558_add_nest_list_type.rb +1 -1
  88. data/db/migrate_core_cards/data/decko_logo.svg +1 -59
  89. data/db/seed/new/card_actions.yml +2153 -2145
  90. data/db/seed/new/card_acts.yml +3 -3
  91. data/db/seed/new/card_references.yml +900 -858
  92. data/db/seed/new/cards.yml +4869 -4848
  93. data/db/seed/new/schema_migrations_deck_cards.yml +2 -0
  94. data/db/seed/test/fixtures/card_actions.yml +3563 -3547
  95. data/db/seed/test/fixtures/card_acts.yml +675 -675
  96. data/db/seed/test/fixtures/card_changes.yml +103 -103
  97. data/db/seed/test/fixtures/card_references.yml +2165 -2123
  98. data/db/seed/test/fixtures/cards.yml +7862 -7751
  99. data/db/seed/test/fixtures/rails.gif +0 -0
  100. data/db/seed/test/fixtures/schema_migrations_deck_cards.yml +2 -0
  101. data/db/test_seed.rb +33 -34
  102. data/lib/card.rb +18 -1
  103. data/lib/card/auth.rb +5 -2
  104. data/lib/card/auth/current.rb +39 -100
  105. data/lib/card/auth/proxy.rb +36 -16
  106. data/lib/card/auth/token.rb +8 -2
  107. data/lib/card/cache.rb +2 -1
  108. data/lib/card/cache/all.rb +88 -0
  109. data/lib/card/cache/card_class.rb +44 -0
  110. data/lib/card/cache/persistent.rb +3 -34
  111. data/lib/card/cache/persistent_class.rb +28 -0
  112. data/lib/card/codename.rb +3 -4
  113. data/lib/card/content.rb +20 -10
  114. data/lib/card/content/all.rb +59 -0
  115. data/lib/card/content/chunk.rb +1 -1
  116. data/lib/card/content/clean.rb +4 -3
  117. data/lib/card/content/diff.rb +3 -2
  118. data/lib/card/content/diff/l_c_s/processor.rb +1 -1
  119. data/lib/card/content/diff/result.rb +41 -29
  120. data/lib/card/content/parser.rb +2 -2
  121. data/lib/card/content/truncate.rb +6 -6
  122. data/lib/card/director.rb +1 -1
  123. data/lib/card/director/act_direction.rb +4 -0
  124. data/lib/card/director/all.rb +61 -0
  125. data/lib/card/director/card_class.rb +18 -0
  126. data/lib/card/director/card_methods.rb +1 -0
  127. data/lib/card/director/event_delay.rb +4 -6
  128. data/lib/card/director/phases.rb +0 -1
  129. data/lib/card/director/run.rb +2 -0
  130. data/lib/card/director/stages.rb +3 -2
  131. data/lib/card/dirty.rb +13 -3
  132. data/lib/card/env.rb +2 -2
  133. data/lib/card/env/location.rb +4 -3
  134. data/lib/card/env/success.rb +46 -103
  135. data/lib/card/env/success/target.rb +73 -0
  136. data/lib/card/error.rb +1 -2
  137. data/lib/card/fetch.rb +7 -4
  138. data/lib/card/fetch/all.rb +33 -0
  139. data/lib/card/fetch/card_class.rb +155 -0
  140. data/lib/card/fetch/results.rb +9 -0
  141. data/lib/card/fetch/retrieve.rb +2 -0
  142. data/lib/card/fetch/store.rb +1 -0
  143. data/lib/card/format.rb +1 -2
  144. data/lib/card/format/content.rb +1 -3
  145. data/lib/card/format/error.rb +8 -4
  146. data/lib/card/format/method_delegation.rb +10 -2
  147. data/lib/card/format/nest.rb +3 -2
  148. data/lib/card/format/nest/fetch.rb +3 -2
  149. data/lib/card/format/nesting/mode.rb +1 -1
  150. data/lib/card/format/nesting/subformat.rb +2 -1
  151. data/lib/card/format/render.rb +2 -2
  152. data/lib/card/format/wrapper.rb +1 -1
  153. data/lib/card/lexicon.rb +5 -4
  154. data/lib/card/mark.rb +17 -15
  155. data/lib/card/model/save_helper.rb +18 -184
  156. data/lib/card/model/save_helper/save_arguments.rb +94 -0
  157. data/lib/card/model/save_helper/save_helper_helper.rb +93 -0
  158. data/lib/card/name.rb +10 -9
  159. data/lib/card/name/all.rb +136 -0
  160. data/lib/card/name/all/descendants.rb +48 -0
  161. data/lib/card/name/all/parts.rb +67 -0
  162. data/lib/card/name/card_class.rb +28 -0
  163. data/lib/card/name/fields_and_traits.rb +4 -2
  164. data/lib/card/name/name_variants.rb +0 -1
  165. data/lib/card/query.rb +24 -19
  166. data/lib/card/query/card_query/interpretation.rb +3 -2
  167. data/lib/card/query/card_query/match_attributes.rb +2 -1
  168. data/lib/card/query/card_query/normalization.rb +1 -0
  169. data/lib/card/query/card_query/reference_attributes.rb +1 -1
  170. data/lib/card/query/card_query/sorting.rb +12 -4
  171. data/lib/card/query/join.rb +1 -1
  172. data/lib/card/query/sql_statement.rb +1 -1
  173. data/lib/card/query/value/match_value.rb +1 -0
  174. data/lib/card/reference/all.rb +136 -0
  175. data/lib/card/rule/all.rb +76 -0
  176. data/lib/card/rule/cache.rb +2 -0
  177. data/lib/card/set/advanced_api.rb +8 -4
  178. data/lib/card/set/event.rb +2 -2
  179. data/lib/card/set/event/all.rb +101 -0
  180. data/lib/card/set/event/delayed_event.rb +6 -6
  181. data/lib/card/set/event/options.rb +14 -5
  182. data/lib/card/set/event/skip_and_trigger.rb +89 -0
  183. data/lib/card/set/format.rb +16 -9
  184. data/lib/card/set/format/abstract_format/view_definition.rb +1 -0
  185. data/lib/card/set/format/abstract_format/view_opts.rb +1 -0
  186. data/lib/card/set/i18n_scope.rb +18 -13
  187. data/lib/card/set/inheritance.rb +8 -6
  188. data/lib/card/set/loader.rb +24 -13
  189. data/lib/card/set/pattern/all.rb +63 -0
  190. data/lib/card/set/pattern/base.rb +4 -74
  191. data/lib/card/set/pattern/class_methods.rb +75 -0
  192. data/lib/card/set/required_field.rb +4 -1
  193. data/lib/card/set/trait.rb +11 -8
  194. data/lib/card/setting.rb +13 -12
  195. data/lib/card/subcards.rb +3 -4
  196. data/lib/card/subcards/add.rb +3 -24
  197. data/lib/card/subcards/all.rb +103 -0
  198. data/lib/card/subcards/args.rb +42 -0
  199. data/lib/card/tasks/card/file_card_creator/abstract_file_card/ruby_file.rb +1 -1
  200. data/lib/card/tasks/card/file_card_creator/output_helper.rb +17 -14
  201. data/lib/card/tasks/card/migrate.rake +2 -2
  202. data/lib/card/view/cache.rb +6 -8
  203. data/lib/card/view/cache/cache_action.rb +1 -2
  204. data/lib/card/view/cache/stub.rb +1 -1
  205. data/lib/card/view/options.rb +5 -4
  206. data/lib/card/view/permission.rb +15 -3
  207. data/lib/cardio.rb +10 -67
  208. data/lib/cardio/defaults.yml +70 -0
  209. data/lib/cardio/migration.rb +2 -2
  210. data/lib/cardio/migration/deck_structure.rb +2 -4
  211. data/lib/cardio/migration/import.rb +3 -3
  212. data/lib/cardio/migration/import/import_data.rb +1 -0
  213. data/lib/cardio/mod.rb +1 -0
  214. data/lib/cardio/mod/dirs.rb +2 -2
  215. data/lib/cardio/mod/load_strategy.rb +2 -4
  216. data/lib/cardio/mod/loader/set_loader.rb +2 -1
  217. data/lib/cardio/mod/loader/set_pattern_loader.rb +0 -1
  218. data/lib/cardio/mod/module_template.rb +1 -0
  219. data/lib/cardio/modfiles.rb +2 -4
  220. data/lib/cardio/schema.rb +2 -4
  221. data/lib/cardio/utils.rb +9 -0
  222. data/lib/generators/card/format/format_generator.rb +1 -1
  223. data/lib/generators/card/migration/migration_generator.rb +2 -1
  224. data/lib/generators/card/mod/mod_generator.rb +3 -2
  225. data/lib/generators/card/set/set_generator.rb +3 -3
  226. data/lib/generators/card/template/template_generator.rb +1 -1
  227. data/mod/admin/set/self/admin.rb +6 -3
  228. data/mod/admin/set/self/admin_info.rb +3 -8
  229. data/mod/admin/set/self/trash.rb +3 -2
  230. data/mod/admin/spec/set/self/admin_spec.rb +4 -4
  231. data/mod/core/set/all/abort.rb +5 -5
  232. data/mod/core/set/all/assign_attributes.rb +12 -28
  233. data/mod/core/set/all/autoname.rb +17 -0
  234. data/mod/core/set/all/codename.rb +3 -2
  235. data/mod/core/set/all/collection.rb +4 -6
  236. data/mod/core/set/all/content.rb +55 -99
  237. data/mod/core/set/all/contextual_content.rb +2 -4
  238. data/mod/core/set/all/initialize.rb +9 -9
  239. data/mod/core/set/all/name_events.rb +78 -58
  240. data/mod/core/set/all/reference_events.rb +69 -0
  241. data/mod/core/set/all/states.rb +5 -5
  242. data/mod/core/set/all/subcards.rb +1 -101
  243. data/mod/core/set/all/trash.rb +16 -14
  244. data/mod/core/set/all/type.rb +11 -11
  245. data/mod/core/set/all/utils.rb +4 -1
  246. data/mod/{settings → core}/set/right/autoname.rb +0 -0
  247. data/mod/{settings → core}/set/self/autoname.rb +0 -0
  248. data/mod/core/set/type/cardtype.rb +28 -0
  249. data/mod/core/set_pattern/06_rule.rb +1 -1
  250. data/mod/core/spec/set/all/assign_attributes_spec.rb +10 -9
  251. data/mod/core/spec/set/all/{rules2_spec.rb → clean_me_spec.rb} +19 -4
  252. data/mod/core/spec/set/all/collection_spec.rb +1 -1
  253. data/mod/core/spec/set/all/export_spec.rb +1 -0
  254. data/mod/core/spec/set/all/initialize_spec.rb +11 -11
  255. data/mod/core/spec/set/all/name_events_spec.rb +204 -0
  256. data/mod/{standard → core}/spec/set/type/cardtype_spec.rb +3 -24
  257. data/mod/standard/file/logo/image-original.svg +1 -59
  258. metadata +50 -61
  259. data/config/initializers/uuid_state_file.rb +0 -3
  260. data/lib/card/mod_inflector.rb +0 -16
  261. data/mod/Modfile +0 -4
  262. data/mod/core/set/all/actify.rb +0 -68
  263. data/mod/core/set/all/cache.rb +0 -109
  264. data/mod/core/set/all/event_conditions.rb +0 -172
  265. data/mod/core/set/all/fetch.rb +0 -122
  266. data/mod/core/set/all/fetch_helper.rb +0 -35
  267. data/mod/core/set/all/i18n.rb +0 -11
  268. data/mod/core/set/all/name.rb +0 -229
  269. data/mod/core/set/all/pattern.rb +0 -54
  270. data/mod/core/set/all/references.rb +0 -191
  271. data/mod/core/set/all/rename.rb +0 -33
  272. data/mod/core/set/all/rules.rb +0 -81
  273. data/mod/core/spec/set/all/actify_spec.rb +0 -58
  274. data/mod/core/spec/set/all/content_spec.rb +0 -15
  275. data/mod/core/spec/set/all/event_conditions_spec.rb +0 -217
  276. data/mod/core/spec/set/all/fetch_helper_spec.rb +0 -65
  277. data/mod/core/spec/set/all/fetch_spec.rb +0 -338
  278. data/mod/core/spec/set/all/i18n_spec.rb +0 -17
  279. data/mod/core/spec/set/all/name_spec.rb +0 -11
  280. data/mod/core/spec/set/all/pattern_spec.rb +0 -101
  281. data/mod/core/spec/set/all/permissions/reader_rules_spec.rb +0 -166
  282. data/mod/core/spec/set/all/references_spec.rb +0 -62
  283. data/mod/core/spec/set/all/rename_spec.rb +0 -189
  284. data/mod/core/spec/set/all/rules_spec.rb +0 -100
  285. data/mod/core/spec/set/all/subcards_spec.rb +0 -102
  286. data/mod/standard/set/all/rich_html/html_views/info.rb +0 -84
  287. data/mod/standard/set/type/cardtype.rb +0 -119
@@ -4,6 +4,7 @@ class Card
4
4
  module Results
5
5
  def results
6
6
  return if card.nil?
7
+
7
8
  card.new_card? ? new_result_card : finalize_result_card
8
9
  end
9
10
 
@@ -34,6 +35,7 @@ class Card
34
35
 
35
36
  def renew
36
37
  return if new_opts.blank?
38
+
37
39
  # Rails.logger.info "renewing: #{mark}, #{new_opts}"
38
40
  @card = card.dup
39
41
  @card.newish newish_opts
@@ -59,6 +61,7 @@ class Card
59
61
 
60
62
  def update_supercard
61
63
  return unless (sc = new_opts[:supercard])
64
+
62
65
  @card.supercard = sc
63
66
  @card.update_superleft @card.name
64
67
  end
@@ -67,6 +70,7 @@ class Card
67
70
  return true if new_opts.blank?
68
71
  return false if type_change? || name_change?
69
72
  return false if fancy_renew?
73
+
70
74
  quick_content
71
75
  true
72
76
  end
@@ -84,19 +88,23 @@ class Card
84
88
 
85
89
  def quick_content
86
90
  return unless (content = assignable_content(new_opts[:default_content]))
91
+
87
92
  @card.content = content
88
93
  end
89
94
 
90
95
  def name_change?
91
96
  return false unless (new_name = new_opts[:name]&.to_name)
92
97
  return false if new_name.relative? && mark.name? && mark.absolute?
98
+
93
99
  new_name.to_s != @card.name.to_s
94
100
  end
95
101
 
96
102
  def type_change?
97
103
  return true if @card.type_id.nil?
104
+
98
105
  type_id = type_id_from_new_opts
99
106
  return true if !type_id && supercard_might_change_type?
107
+
100
108
  type_id && (type_id != @card.type_id)
101
109
  end
102
110
 
@@ -118,6 +126,7 @@ class Card
118
126
  def assign_name_from_mark
119
127
  return if opts[:local_only]
120
128
  return unless mark&.to_s != card.name
129
+
121
130
  card.name = mark.to_s
122
131
  end
123
132
  end
@@ -5,6 +5,7 @@ class Card
5
5
  # look for card in cache. if that doesn't work, look in database
6
6
  def retrieve_existing
7
7
  return unless mark.present?
8
+
8
9
  retrieve_from_cache || retrieve_from_db
9
10
  end
10
11
 
@@ -26,6 +27,7 @@ class Card
26
27
 
27
28
  def retrieval_from_db_query
28
29
  return unless (query = retrieval_from_db_query_base)
30
+
29
31
  query[:trash] = false unless look_in_trash?
30
32
  query
31
33
  end
@@ -20,6 +20,7 @@ class Card
20
20
  # instantiate a card as a cache placeholder
21
21
  def new_for_cache
22
22
  return unless new_for_cache?
23
+
23
24
  args = { name: mark, skip_modules: true }
24
25
  args[:type_lookup] = :skip if skip_type_lookup?
25
26
  args.merge! new_opts.slice(:type, :type_id, :type_code) if eager_caching?
data/lib/card/format.rb CHANGED
@@ -47,8 +47,7 @@ class Card
47
47
  def require_card_to_initialize!
48
48
  return if @card
49
49
 
50
- msg = I18n.t :exception_init_without_card, scope: "lib.card.format"
51
- raise Card::Error, msg
50
+ raise Card::Error, Cardio.t(:lib_exception_init_without_card)
52
51
  end
53
52
 
54
53
  def include_set_format_modules
@@ -2,7 +2,7 @@ class Card
2
2
  class Format
3
3
  module Content
4
4
  def process_content override_content=nil, content_opts=nil, &block
5
- content_obj = content_object override_content , content_opts
5
+ content_obj = content_object override_content, content_opts
6
6
  content_obj.process_chunks(&block)
7
7
  content_obj.to_s
8
8
  end
@@ -82,8 +82,6 @@ class Card
82
82
  content ||= render_raw || ""
83
83
  Card::Content.new content, self, content_opts
84
84
  end
85
-
86
-
87
85
  end
88
86
  end
89
87
  end
@@ -8,6 +8,7 @@ class Card
8
8
 
9
9
  def anyone_can? task
10
10
  return false unless task.is_a? Symbol
11
+
11
12
  @anyone_can ||= {}
12
13
  @anyone_can[task] = card.anyone_can? task if @anyone_can[task].nil?
13
14
  @anyone_can[task]
@@ -29,7 +30,11 @@ class Card
29
30
  end
30
31
 
31
32
  def monitor_depth
32
- raise Card::Error::UserError, tr(:too_deep) if depth >= Card.config.max_depth
33
+ if depth >= Card.config.max_depth
34
+ raise Card::Error::UserError,
35
+ t(:format_too_deep)
36
+ end
37
+
33
38
  yield
34
39
  end
35
40
 
@@ -42,7 +47,7 @@ class Card
42
47
  if card&.name.present?
43
48
  safe_name
44
49
  else
45
- I18n.t :no_cardname, scope: %i[lib card format error]
50
+ Cardio.t :lib_no_cardname
46
51
  end
47
52
  end
48
53
 
@@ -71,8 +76,7 @@ class Card
71
76
  if exception.is_a? Card::Error::UserError
72
77
  exception.message
73
78
  else
74
- tr :error_rendering, scope: %i[lib card format error],
75
- cardname: error_cardname(exception), view: view
79
+ t :lib_error_rendering, cardname: error_cardname(exception), view: view
76
80
  end
77
81
  end
78
82
  end
@@ -46,12 +46,20 @@ class Card
46
46
 
47
47
  def render_args underscore, bang, opts
48
48
  # opts is a list; args is a hash. we're using various inputs to build the hash
49
- (opts[0] ? opts.shift.clone : {}).tap do |args|
50
- args[:optional] = (opts.shift || args[:optional] || :show) unless bang
49
+ interpret_render_opts opts do |args|
50
+ args[:optional] = optional_render_opt opts, args unless bang
51
51
  args[:skip_perms] = true if underscore
52
52
  end
53
53
  end
54
54
 
55
+ def interpret_render_opts opts, &block
56
+ (opts[0] ? opts.shift.clone : {}).tap(&block)
57
+ end
58
+
59
+ def optional_render_opt opts, args
60
+ opts.shift || args[:optional] || :show
61
+ end
62
+
55
63
  def new_action_view
56
64
  CardActionView.new(controller).tap do |t|
57
65
  t.extend CardController._helpers
@@ -2,16 +2,17 @@ class Card
2
2
  class Format
3
3
  # processing nests
4
4
  class Nest
5
- include Fetch
5
+ include Nest::Fetch
6
6
 
7
7
  attr_accessor :format, :card, :view, :view_opts, :format_opts
8
+
8
9
  def initialize format, cardish, view_opts={}, format_opts={}
9
10
  @format = format
10
11
  @view_opts = view_opts
11
12
  @format_opts = format_opts.clone
12
13
  @override = @format_opts.delete(:override) != false
13
14
  @card ||= fetch_card cardish
14
- # note: fetch_card can alter view and view_opts[:nest_name]
15
+ # NOTE: fetch_card can alter view and view_opts[:nest_name]
15
16
  end
16
17
 
17
18
  def prepare
@@ -24,8 +24,7 @@ class Card
24
24
  end
25
25
 
26
26
  def not_found_codename_error codename
27
- ::I18n.t :exception_unknown_codename, codename: codename,
28
- scope: "lib.card.codename"
27
+ Cardio.t :lib_exception_unknown_codename, codename: codename
29
28
  end
30
29
 
31
30
  def new_card cardish
@@ -44,12 +43,14 @@ class Card
44
43
  def new_supercard_args
45
44
  # special case. gets absolutized incorrectly. fix in name?
46
45
  return {} if view_opts[:nest_name].strip.blank?
46
+
47
47
  { supercard: format.context_card }
48
48
  end
49
49
 
50
50
  def new_main_args
51
51
  nest_name = view_opts[:nest_name]
52
52
  return {} unless nest_name =~ /main/
53
+
53
54
  { name: nest_name.gsub(/^_main\+/, "+"),
54
55
  supercard: format.root.card }
55
56
  end
@@ -41,7 +41,7 @@ class Card
41
41
  # @param view [Symbol]
42
42
  # @return [Symbol ] viewname
43
43
  def modal_nest_view view
44
- # Note: the subformat always has the same nest_mode as its parent format
44
+ # NOTE: the subformat always has the same nest_mode as its parent format
45
45
  case nest_mode
46
46
  when :edit then view_in_edit_mode(view)
47
47
  when :template then :template_nest
@@ -3,7 +3,7 @@ class Card
3
3
  module Nesting
4
4
  # Formats can have subformats. Lineage can be retraced through "parent" format.
5
5
  module Subformat
6
- # note: while it is possible to have a subformat of a different class,
6
+ # NOTE: while it is possible to have a subformat of a different class,
7
7
  # the :format_class value takes precedence over :format.
8
8
  def subformat subcard, opts={}
9
9
  subcard = subformat_card subcard
@@ -56,6 +56,7 @@ class Card
56
56
 
57
57
  def subformat_card subcard
58
58
  return subcard if subcard.is_a? Card
59
+
59
60
  Card.fetch subcard, new: {}
60
61
  end
61
62
  end
@@ -65,8 +65,8 @@ class Card
65
65
  end
66
66
 
67
67
  def pretty_path source_location
68
- source_location.first.gsub(%r{^.+mod\d+-([^/]+)}, '\1: ') + ":" +
69
- source_location.second.to_s
68
+ "#{source_location.first.gsub(%r{^.+mod\d+-([^/]+)},
69
+ '\1: ')}:#{source_location.second}"
70
70
  end
71
71
 
72
72
  # :standard, :always, :never
@@ -46,4 +46,4 @@ class Card
46
46
  end
47
47
  end
48
48
  end
49
- end
49
+ end
data/lib/card/lexicon.rb CHANGED
@@ -36,16 +36,17 @@ class Card
36
36
 
37
37
  def update card
38
38
  add card
39
- cache.delete cache_key(card.old_lex)
39
+ cache.delete cache_key(card.lex_before_act)
40
40
  end
41
41
 
42
42
  # def delete card
43
43
  # cache.delete card.id.to_s
44
- # cache.delete cache_key(card.old_lex)
44
+ # cache.delete cache_key(card.lex_before_act)
45
45
  # end
46
46
 
47
47
  def lex_to_name lex
48
- return lex unless lex&.is_a? Array
48
+ return lex unless lex.is_a? Array
49
+
49
50
  lex.map { |side_id| name side_id or return }.join(Card::Name.joint).to_name
50
51
  end
51
52
 
@@ -83,7 +84,7 @@ class Card
83
84
  end
84
85
 
85
86
  def cache_key lex
86
- "L-" + (lex.is_a?(Array) ? lex.join("-") : lex.to_name.key)
87
+ "L-#{lex.is_a?(Array) ? lex.join('-') : lex.to_name.key}"
87
88
  end
88
89
  end
89
90
  end
data/lib/card/mark.rb CHANGED
@@ -23,16 +23,7 @@ class Card
23
23
  def id_or_name parts
24
24
  mark = parts.flatten
25
25
  mark = mark.first if mark.size <= 1
26
- id_from_mark(mark) || name_from_mark(mark)
27
- end
28
-
29
- def id_from_mark mark
30
- case mark
31
- when Integer then mark
32
- when Symbol then Card::Codename.id! mark
33
- when String then id_from_string mark
34
- when Card then mark.id
35
- end
26
+ id_from_mark(mark) || Card::Name[mark]
36
27
  end
37
28
 
38
29
  # translates string identifiers into an id:
@@ -48,20 +39,31 @@ class Card
48
39
  end
49
40
  end
50
41
 
51
- def bad_mark mark
52
- case mark
42
+ def name_from_id_from_string id, string
43
+ fetch_name(id) { bad_mark string }
44
+ end
45
+
46
+ private
47
+
48
+ def bad_mark string
49
+ case string
53
50
  when ID_MARK_RE
54
51
  raise Card::Error::NotFound, "id doesn't exist: #{Regexp.last_match[:id]}"
55
52
  when CODENAME_MARK_RE
56
53
  raise Card::Error::CodenameNotFound,
57
54
  "codename doesn't exist: #{Regexp.last_match[:codename]}"
58
55
  else
59
- raise Card::Error, "invalid mark: #{mark}"
56
+ raise Card::Error, "invalid mark: #{string}"
60
57
  end
61
58
  end
62
59
 
63
- def name_from_mark mark
64
- Card::Name[mark]
60
+ def id_from_mark mark
61
+ case mark
62
+ when Integer then mark
63
+ when Symbol then Card::Codename.id! mark
64
+ when String then id_from_string mark
65
+ when Card then mark.id
66
+ end
65
67
  end
66
68
  end
67
69
  end
@@ -9,22 +9,34 @@ class Card
9
9
  # All !-methods in this module rename existing cards
10
10
  # to resolve name conflicts)
11
11
  module SaveHelper
12
- def with_user user_name
13
- Card::Auth.with current_id: Card.fetch_id(user_name) do
14
- yield
15
- end
12
+ include SaveHelperHelper
13
+ include SaveArguments
14
+
15
+ def with_user user_name, &block
16
+ Card::Auth.with(current_id: Card.fetch_id(user_name), &block)
16
17
  end
17
18
 
18
19
  def create_card name_or_args, content_or_args=nil
19
20
  Card.create! create_args(name_or_args, content_or_args)
20
21
  end
21
22
 
23
+ # if card with same name exists move it out of the way
24
+ def create_card! name_or_args, content_or_args=nil
25
+ args = standardize_args name_or_args, content_or_args
26
+ create_card args.reverse_merge(rename_if_conflict: :old)
27
+ end
28
+
22
29
  def update_card name, content_or_args
23
30
  args = standardize_update_args name, content_or_args
24
31
  resolve_name_conflict args
25
32
  Card[name]&.update! args
26
33
  end
27
34
 
35
+ def update_card! name, content_or_args
36
+ args = standardize_update_args name, content_or_args
37
+ update_card name, args.reverse_merge(rename_if_conflict: :new)
38
+ end
39
+
28
40
  def create_or_update_card name_or_args, content_or_args=nil
29
41
  name = name_from_args name_or_args
30
42
 
@@ -51,12 +63,6 @@ class Card
51
63
  card.delete!
52
64
  end
53
65
 
54
- def delete_code_card? name
55
- return false if name.is_a?(Symbol) && !Codename.exist?(name)
56
-
57
- Card.exist? name
58
- end
59
-
60
66
  # create if card doesn't exist
61
67
  # updates existing card only if given attributes are different except the
62
68
  # name
@@ -77,10 +83,6 @@ class Card
77
83
  ensure_card_simplified name, args
78
84
  end
79
85
 
80
- def codename_from_name name
81
- name.downcase.tr(" ", "_").tr(":*", "")
82
- end
83
-
84
86
  # create if card doesn't exist
85
87
  # updates existing card only if given attributes are different including
86
88
  # the name
@@ -112,33 +114,14 @@ class Card
112
114
  ensure_card [trait, :right, setting], card_args
113
115
  end
114
116
 
115
- # if card with same name exists move it out of the way
116
- def create_card! name_or_args, content_or_args=nil
117
- args = standardize_args name_or_args, content_or_args
118
- create_card args.reverse_merge(rename_if_conflict: :old)
119
- end
120
-
121
- def update_card! name, content_or_args
122
- args = standardize_update_args name, content_or_args
123
- update_card name, args.reverse_merge(rename_if_conflict: :new)
124
- end
125
-
126
117
  def create_or_update_card! name_or_args, content_or_args=nil
127
118
  args = standardize_args name_or_args, content_or_args
128
119
  create_or_update args.reverse_merge(rename_if_conflict: :new)
129
120
  end
130
121
 
131
- def add_style name, opts={}
132
- name.sub!(/^style\:?\s?/, "") # in case name is given with prefix
133
- # remove it so that we don't double it
134
-
135
- add_coderule_item name, "style",
136
- opts[:type_id] || Card::ScssID,
137
- opts[:to] || "*all+*style"
138
- end
139
-
122
+ # TODO: this is too specific for this
140
123
  def add_script name, opts={}
141
- name.sub!(/^script\:?\s?/, "") # in case name is given with prefix
124
+ name.sub!(/^script:?\s?/, "") # in case name is given with prefix
142
125
  # remove it so that we don't double it
143
126
 
144
127
  add_coderule_item name, "script",
@@ -146,15 +129,6 @@ class Card
146
129
  opts[:to] || "*all+*script"
147
130
  end
148
131
 
149
- def add_coderule_item name, prefix, type_id, to
150
- codename = "#{prefix}_#{name.tr(' ', '_').underscore}"
151
- name = "#{prefix}: #{name}"
152
-
153
- ensure_card name, type_id: type_id,
154
- codename: codename
155
- Card[to].add_item! name
156
- end
157
-
158
132
  alias_method :create, :create_card
159
133
  alias_method :update, :update_card
160
134
  alias_method :create_or_update, :create_or_update_card
@@ -164,146 +138,6 @@ class Card
164
138
  alias_method :ensure, :ensure_card
165
139
  alias_method :ensure!, :ensure_card!
166
140
  alias_method :delete, :delete_card
167
-
168
- def method_missing method, *args
169
- method_name, cardtype_card = extract_cardtype_from_method_name method
170
- return super unless method_name
171
-
172
- sargs = standardize_args(*args)
173
- send "#{method_name}_card", sargs.merge(type_id: cardtype_card.id)
174
- end
175
-
176
- def respond_to_missing? method, _include_private=false
177
- extract_cardtype_from_method_name(method) || super
178
- end
179
-
180
- def extract_cardtype_from_method_name method
181
- return unless method =~ /^(?<method_name>create|ensure)_(?<type>.+?)(?:_card)?$/
182
-
183
- type = Regexp.last_match[:type]
184
- cardtype_card = Card::Codename[type.to_sym] ? Card[type.to_sym] : Card[type]
185
- return unless cardtype_card&.type_id == Card::CardtypeID ||
186
- cardtype_card&.id == Card::SetID
187
-
188
- [Regexp.last_match[:method_name], cardtype_card]
189
- end
190
-
191
- private
192
-
193
- def ensure_card_simplified name, args
194
- ensure_card_update(name, args) || Card.create!(add_name(name, args))
195
- end
196
-
197
- def ensure_card_update name, args
198
- card = Card[name]
199
- return unless card
200
-
201
- ensure_attributes card, args
202
- card
203
- rescue Card::Error::CodenameNotFound => _e
204
- false
205
- end
206
-
207
- def validate_setting setting
208
- unless Card::Codename.exist?(setting) &&
209
- Card.fetch_type_id(setting) == Card::SettingID
210
- raise ArgumentError, "not a valid setting: #{setting}"
211
- end
212
- end
213
-
214
- def normalize_trait_rule_args setting, value
215
- return value if value.is_a? Hash
216
-
217
- if Card.fetch_type_id([setting, :right, :default]) == Card::PointerID
218
- value = Array(value).to_pointer_content
219
- end
220
- { content: value }
221
- end
222
-
223
- # @return args
224
- def standardize_args name_or_args, content_or_args=nil, _ignore=nil
225
- if name_or_args.is_a?(Hash)
226
- name_or_args
227
- else
228
- add_name name_or_args, content_or_args || {}
229
- end
230
- end
231
-
232
- def hashify value_or_hash, key
233
- if value_or_hash.is_a?(Hash)
234
- value_or_hash
235
- elsif value_or_hash.nil?
236
- {}
237
- else
238
- { key => value_or_hash }
239
- end
240
- end
241
-
242
- def standardize_ensure_args name_or_args, content_or_args
243
- name = name_or_args.is_a?(Hash) ? name_or_args[:name] : name_or_args
244
- args = if name_or_args.is_a?(Hash)
245
- name_or_args
246
- else
247
- hashify content_or_args, :content
248
- end
249
- [name, args]
250
- end
251
-
252
- def standardize_update_args name_or_args, content_or_args
253
- return name_or_args if name_or_args.is_a?(Hash)
254
-
255
- hashify content_or_args, :content
256
- end
257
-
258
- def create_args name_or_args, content_or_args=nil
259
- args = standardize_args name_or_args, content_or_args
260
- resolve_name_conflict args
261
- args
262
- end
263
-
264
- def name_from_args name_or_args
265
- name_or_args.is_a?(Hash) ? name_or_args[:name] : name_or_args
266
- end
267
-
268
- def add_name name, content_or_args
269
- if content_or_args.is_a?(Hash)
270
- content_or_args.reverse_merge name: name
271
- else
272
- { content: content_or_args, name: name }
273
- end
274
- end
275
-
276
- def resolve_name_conflict args
277
- rename = args.delete :rename_if_conflict
278
- return unless args[:name] && rename
279
-
280
- args[:name] = Card.uniquify_name args[:name], rename
281
- end
282
-
283
- def ensure_attributes card, args
284
- subcards = card.extract_subcard_args! args
285
- update_args = changing_args card, args
286
-
287
- return if update_args.empty? && subcards.empty?
288
-
289
- # FIXME: use ensure_attributes for subcards
290
- card.update! update_args.merge(subcards: subcards, skip: :validate_renaming)
291
- end
292
-
293
- def changing_args card, args
294
- args.select do |key, value|
295
- if key =~ /^\+/
296
- subfields[key] = value
297
- false
298
- elsif key.to_sym == :name
299
- card.name.to_s != value
300
- elsif value.is_a? ::File
301
- # NOOP
302
- else
303
- card.send(key) != value
304
- end
305
- end
306
- end
307
141
  end
308
142
  end
309
143
  end