card 1.21.0 → 1.91
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/card.gemspec +18 -6
- data/config/initializers/internationalization.rb +5 -5
- data/config/locales/en.yml +4 -4
- data/db/migrate_core_cards/20170719163708_update_bootswatch_themes.rb +80 -0
- data/db/migrate_core_cards/20170720093738_update_layout.rb +7 -0
- data/db/migrate_core_cards/20170726111053_add_bootstrap_mixins.rb +11 -0
- data/db/migrate_core_cards/20170726145012_select2.rb +21 -0
- data/db/migrate_core_cards/data/1.12_stylesheets/classic_cards.scss +6 -6
- data/db/migrate_core_cards/data/1.12_stylesheets/common.scss +9 -9
- data/db/migrate_core_cards/data/1.12_stylesheets/traditional.scss +2 -2
- data/db/migrate_core_cards/data/b4_themes/bootstrap_default/_bootswatch.scss +0 -0
- data/db/migrate_core_cards/data/b4_themes/bootstrap_default/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/cerulean/_bootswatch.scss +67 -0
- data/db/migrate_core_cards/data/b4_themes/cerulean/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/cerulean/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/cosmo/_bootswatch.scss +45 -0
- data/db/migrate_core_cards/data/b4_themes/cosmo/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/cosmo/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/cyborg/_bootswatch.scss +141 -0
- data/db/migrate_core_cards/data/b4_themes/cyborg/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/cyborg/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/darkly/_bootswatch.scss +142 -0
- data/db/migrate_core_cards/data/b4_themes/darkly/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/darkly/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/flatly/_bootswatch.scss +107 -0
- data/db/migrate_core_cards/data/b4_themes/flatly/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/flatly/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/journal/_bootswatch.scss +69 -0
- data/db/migrate_core_cards/data/b4_themes/journal/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/journal/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/litera/_bootswatch.scss +130 -0
- data/db/migrate_core_cards/data/b4_themes/litera/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/litera/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/lumen/_bootswatch.scss +294 -0
- data/db/migrate_core_cards/data/b4_themes/lumen/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/lumen/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/lux/_bootswatch.scss +111 -0
- data/db/migrate_core_cards/data/b4_themes/lux/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/lux/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/materia/_bootswatch.scss +610 -0
- data/db/migrate_core_cards/data/b4_themes/materia/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/materia/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/minty/_bootswatch.scss +85 -0
- data/db/migrate_core_cards/data/b4_themes/minty/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/minty/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/paper/_bootswatch.scss +607 -0
- data/db/migrate_core_cards/data/b4_themes/paper/_variables.scss +861 -0
- data/db/migrate_core_cards/data/b4_themes/pulse/_bootswatch.scss +122 -0
- data/db/migrate_core_cards/data/b4_themes/pulse/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/pulse/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/readable/_bootswatch.scss +174 -0
- data/db/migrate_core_cards/data/b4_themes/readable/_variables.scss +861 -0
- data/db/migrate_core_cards/data/b4_themes/sandstone/_bootswatch.scss +152 -0
- data/db/migrate_core_cards/data/b4_themes/sandstone/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/sandstone/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/simplex/_bootswatch.scss +103 -0
- data/db/migrate_core_cards/data/b4_themes/simplex/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/simplex/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/slate/_bootswatch.scss +274 -0
- data/db/migrate_core_cards/data/b4_themes/slate/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/slate/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/solar/_bootswatch.scss +45 -0
- data/db/migrate_core_cards/data/b4_themes/solar/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/solar/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/spacelab/_bootswatch.scss +125 -0
- data/db/migrate_core_cards/data/b4_themes/spacelab/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/spacelab/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/superhero/_bootswatch.scss +136 -0
- data/db/migrate_core_cards/data/b4_themes/superhero/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/superhero/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/united/_bootswatch.scss +32 -0
- data/db/migrate_core_cards/data/b4_themes/united/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/united/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/b4_themes/yeti/_bootswatch.scss +304 -0
- data/db/migrate_core_cards/data/b4_themes/yeti/_full.scss +9921 -0
- data/db/migrate_core_cards/data/b4_themes/yeti/_variables.scss +961 -0
- data/db/migrate_core_cards/data/b4_themes/yeti/thumbnail.png +0 -0
- data/db/migrate_core_cards/data/cards.yml +11 -0
- data/db/migrate_core_cards/data/cards/*header +16 -0
- data/db/migrate_core_cards/data/cards/*main_menu +2 -0
- data/db/seeds.rb +3 -3
- data/lib/card.rb +3 -1
- data/lib/card/act_manager/stage.rb +1 -1
- data/lib/card/act_manager/stage_director.rb +3 -0
- data/lib/card/auth/current.rb +9 -3
- data/lib/card/codename.rb +1 -2
- data/lib/card/error.rb +1 -1
- data/lib/card/migration.rb +1 -1
- data/lib/card/migration/import.rb +85 -72
- data/lib/card/migration/import/import_data.rb +20 -24
- data/lib/card/migration/import/import_data/card_content.rb +2 -4
- data/lib/card/migration/import/merger.rb +6 -17
- data/lib/card/set/event.rb +1 -1
- data/lib/card/set_pattern.rb +0 -1
- data/lib/card/subcards.rb +4 -3
- data/lib/card/tasks/card.rake +10 -6
- data/lib/card/tasks/card/create.rake +1 -1
- data/lib/cardio.rb +1 -1
- data/mod/account/set/right/password.rb +1 -1
- data/mod/account/set/self/account_links.rb +8 -6
- data/mod/ace_editor/lib/javascript/script_ace_config.js.coffee +8 -8
- data/mod/ace_editor/set/abstract/ace_editor.rb +1 -1
- data/mod/admin/set/self/admin_info.rb +3 -6
- data/mod/basic_formats/set/all/base.rb +11 -1
- data/mod/bootstrap/file/cerulean_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/cerulean_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/cerulean_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/cerulean_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/cerulean_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/cosmo_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/cosmo_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/cosmo_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/cosmo_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/cosmo_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/cyborg_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/cyborg_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/cyborg_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/cyborg_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/cyborg_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/darkly_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/darkly_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/darkly_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/darkly_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/darkly_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/flatly_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/flatly_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/flatly_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/flatly_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/flatly_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/journal_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/journal_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/journal_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/journal_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/journal_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/lumen_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/lumen_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/lumen_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/lumen_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/lumen_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/sandstone_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/sandstone_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/sandstone_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/sandstone_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/sandstone_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/simplex_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/simplex_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/simplex_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/simplex_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/simplex_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/slate_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/slate_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/slate_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/slate_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/slate_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/spacelab_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/spacelab_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/spacelab_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/spacelab_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/spacelab_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/superhero_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/superhero_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/superhero_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/superhero_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/superhero_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/united_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/united_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/united_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/united_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/united_skin_image/image-small.png +0 -0
- data/mod/bootstrap/file/yeti_skin_image/image-icon.png +0 -0
- data/mod/bootstrap/file/yeti_skin_image/image-large.png +0 -0
- data/mod/bootstrap/file/yeti_skin_image/image-medium.png +0 -0
- data/mod/bootstrap/file/yeti_skin_image/image-original.png +0 -0
- data/mod/bootstrap/file/yeti_skin_image/image-small.png +0 -0
- data/mod/bootstrap/lib/bootstrap/component/panel.rb +3 -3
- data/mod/bootstrap/lib/javascript/bootstrap.js +2953 -1735
- data/mod/bootstrap/lib/javascript/bootstrap.min.js +4 -4
- data/mod/bootstrap/lib/javascript/script_load_select2.js.coffee +9 -0
- data/mod/bootstrap/lib/javascript/script_select2.js +5725 -0
- data/mod/bootstrap/lib/javascript/select2.min.js +3 -0
- data/mod/bootstrap/lib/javascript/tether.min.js +1 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap.css +9320 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/.scss-lint.yml +548 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_alert.scss +55 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_badge.scss +77 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_breadcrumb.scss +38 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{_button-groups.scss → scss/_button-group.scss} +46 -87
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_buttons.scss +170 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_card.scss +276 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_carousel.scss +178 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{_close.scss → scss/_close.scss} +7 -12
- data/mod/bootstrap/lib/stylesheets/bootstrap/{_code.scss → scss/_code.scss} +19 -24
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_custom-forms.scss +263 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_custom.scss +4 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_dropdown.scss +161 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_forms.scss +388 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_grid.scss +52 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_images.scss +43 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_input-group.scss +178 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_jumbotron.scss +20 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{_list-group.scss → scss/_list-group.scss} +71 -54
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_media.scss +8 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_mixins.scss +57 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{_modals.scss → scss/_modal.scss} +45 -53
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_nav.scss +119 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_navbar.scss +268 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_normalize.scss +461 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_pagination.scss +67 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_popover.scss +171 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_print.scss +119 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_progress.scss +32 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_reboot.scss +389 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{_responsive-embed.scss → scss/_responsive-embed.scss} +26 -9
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_tables.scss +153 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_tooltip.scss +90 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_transitions.scss +34 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_type.scss +143 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_utilities.scss +13 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/_variables.scss +961 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/bootstrap-grid.scss +43 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/bootstrap-reboot.scss +10 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/bootstrap.scss +54 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{mixins/_alerts.scss → scss/mixins/_alert.scss} +3 -3
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_background-variant.scss +12 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{mixins/_labels.scss → scss/mixins/_badge.scss} +3 -4
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_border-radius.scss +35 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_breakpoints.scss +95 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_buttons.scss +86 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_cards.scss +47 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_clearfix.scss +7 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_float.scss +9 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{mixins → scss/mixins}/_forms.scss +27 -36
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_gradients.scss +37 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_grid-framework.scss +65 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_grid.scss +100 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_hover.scss +60 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_image.scss +36 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{mixins → scss/mixins}/_list-group.scss +5 -8
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_lists.scss +7 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{mixins → scss/mixins}/_nav-divider.scss +1 -1
- data/mod/bootstrap/lib/stylesheets/bootstrap/{mixins/_nav-vertical-align.scss → scss/mixins/_navbar-align.scss} +4 -4
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_pagination.scss +21 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_reset-text.scss +17 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{mixins → scss/mixins}/_resize.scss +0 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_screen-reader.scss +32 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_size.scss +6 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_table-row.scss +30 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_text-emphasis.scss +12 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_text-hide.scss +8 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/{mixins/_text-overflow.scss → scss/mixins/_text-truncate.scss} +3 -3
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_transforms.scss +14 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/mixins/_visibility.scss +5 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_align.scss +6 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_background.scss +19 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_borders.scss +37 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_clearfix.scss +3 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_display.scss +18 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_flex.scss +48 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_float.scss +9 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_position.scss +23 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_screenreaders.scss +11 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_sizing.scss +10 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_spacing.scss +43 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_text.scss +61 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap/scss/utilities/_visibility.scss +55 -0
- data/mod/bootstrap/lib/stylesheets/bootstrap_cards.scss +46 -9
- data/mod/bootstrap/lib/stylesheets/font-awesome.css +2337 -0
- data/mod/bootstrap/lib/stylesheets/material-icons.css +36 -0
- data/mod/bootstrap/lib/stylesheets/select2-boostrap-v4-alpha-6.scss +828 -0
- data/mod/bootstrap/lib/stylesheets/select2.min.css +1 -0
- data/mod/bootstrap/lib/stylesheets/style_select2.css +484 -0
- data/mod/bootstrap/lib/stylesheets/style_select2_bootstrap.scss +828 -0
- data/mod/bootstrap/set/abstract/bootstrap_code_file.rb +39 -0
- data/mod/bootstrap/set/all/bootstrap/helper.rb +65 -9
- data/mod/bootstrap/set/all/bootstrap/navbar.rb +35 -49
- data/mod/bootstrap/set/all/bootstrap/tabs.rb +3 -2
- data/mod/bootstrap/set/all/bootstrap/wrapper.rb +8 -5
- data/mod/bootstrap/set/all/rich_bootstrap.rb +1 -1
- data/mod/bootstrap/set/self/bootstrap_js.rb +1 -1
- data/mod/bootstrap/set/self/bootswatch_shared.rb +21 -33
- data/mod/bootstrap/set/self/script_load_select2.rb +1 -0
- data/mod/bootstrap/set/self/script_select2.rb +1 -0
- data/mod/bootstrap/set/self/style_bootstrap_breakpoints.rb +6 -0
- data/mod/bootstrap/set/self/style_bootstrap_mixins.rb +7 -0
- data/mod/bootstrap/set/self/style_select2.rb +1 -0
- data/mod/carrierwave/set/abstract/attachment/storage_type.rb +11 -2
- data/mod/carrierwave/set/type/file.rb +6 -2
- data/mod/carrierwave/spec/set/type/file_spec.rb +13 -3
- data/mod/core/set/all/content.rb +1 -1
- data/mod/core/spec/format/html_format_spec.rb +35 -48
- data/mod/core/spec/set/all/collection_spec.rb +1 -1
- data/mod/history/lib/card/act/act_renderer.rb +2 -2
- data/mod/history/set/all/act_view.rb +5 -5
- data/mod/history/set/all/action_view.rb +2 -2
- data/mod/history/set/all/history.rb +1 -1
- data/mod/machines/file/all_script_machine_output/file.js +8 -7
- data/mod/machines/lib/javascript/{wagn.js.coffee → decko.js.coffee} +23 -23
- data/mod/machines/lib/javascript/{wagn_editor.js.coffee → decko_editor.js.coffee} +6 -6
- data/mod/machines/lib/javascript/{wagn_layout.js.coffee → decko_layout.js.coffee} +10 -6
- data/mod/machines/lib/javascript/{wagn_mod.js.coffee → decko_mod.js.coffee} +9 -9
- data/mod/machines/lib/javascript/{wagn_navbox.js.coffee → decko_navbox.js.coffee} +8 -8
- data/mod/machines/lib/javascript/{wagn_upload.js.coffee → decko_upload.js.coffee} +4 -4
- data/mod/machines/lib/javascript/script_card_menu.js.coffee +3 -4
- data/mod/machines/lib/stylesheets/style_cards.scss +28 -27
- data/mod/machines/set/self/script_slot.rb +1 -1
- data/mod/notifications/set/all/follow.rb +1 -1
- data/mod/notifications/set/right/following.rb +1 -1
- data/mod/notifications/set/type_plus_right/user/follow.rb +1 -1
- data/mod/pointer/lib/javascript/script_pointer_config.js.coffee +6 -5
- data/mod/pointer/set/abstract/01_paging.rb +2 -3
- data/mod/pointer/set/abstract/02_pointer/edit.rb +13 -0
- data/mod/prosemirror_editor/lib/javascript/script_prosemirror_config.js.coffee +5 -5
- data/mod/prosemirror_editor/set/abstract/prosemirror_editor.rb +1 -1
- data/mod/settings/spec/set/right/comment_spec.rb +1 -3
- data/mod/standard/set/abstract/toolbar_split_button.rb +2 -2
- data/mod/standard/set/all/comment.rb +1 -0
- data/mod/standard/set/all/error.rb +1 -1
- data/mod/standard/set/all/rich_html/classy.rb +1 -1
- data/mod/standard/set/all/rich_html/content.rb +5 -5
- data/mod/standard/set/all/rich_html/editor.rb +2 -2
- data/mod/standard/set/all/rich_html/form.rb +1 -1
- data/mod/standard/set/all/rich_html/header.rb +7 -15
- data/mod/standard/set/all/rich_html/menu.rb +12 -10
- data/mod/standard/set/all/rich_html/toolbar.rb +18 -19
- data/mod/standard/set/all/rich_html/wrapper.rb +4 -6
- data/mod/standard/set/rstar/rules_editor.rb +1 -1
- data/mod/standard/set/self/activity_toolbar_button.rb +4 -4
- data/mod/standard/set/self/navbox.rb +5 -10
- data/mod/standard/set/self/rules_toolbar_button.rb +2 -1
- data/mod/standard/set/type/set.rb +35 -33
- data/mod/standard/spec/chunk/include_spec.rb +4 -4
- data/mod/standard/spec/set/all/history_spec.rb +1 -1
- data/mod/standard/spec/set/all/rich_html/wrapper_spec.rb +8 -8
- data/mod/standard/spec/set/type/phrase_spec.rb +1 -1
- data/mod/standard/spec/set/type/uri_spec.rb +1 -1
- data/mod/tinymce_editor/lib/javascript/script_tinymce_config.js.coffee +6 -6
- data/mod/tinymce_editor/set/abstract/tinymce_editor.rb +1 -1
- data/script/fetch_bootswatch_themes.rb +38 -0
- data/spec/lib/card/cache_spec.rb +1 -1
- data/spec/lib/card/migration/import_spec.rb +23 -17
- data/spec/support/helper/render_helper.rb +10 -3
- metadata +189 -298
- data/mod/bootstrap/lib/stylesheets/bootstrap/_alerts.scss +0 -73
- data/mod/bootstrap/lib/stylesheets/bootstrap/_badges.scss +0 -68
- data/mod/bootstrap/lib/stylesheets/bootstrap/_breadcrumbs.scss +0 -26
- data/mod/bootstrap/lib/stylesheets/bootstrap/_buttons.scss +0 -160
- data/mod/bootstrap/lib/stylesheets/bootstrap/_carousel.scss +0 -269
- data/mod/bootstrap/lib/stylesheets/bootstrap/_component-animations.scss +0 -37
- data/mod/bootstrap/lib/stylesheets/bootstrap/_dropdowns.scss +0 -214
- data/mod/bootstrap/lib/stylesheets/bootstrap/_forms.scss +0 -578
- data/mod/bootstrap/lib/stylesheets/bootstrap/_glyphicons.scss +0 -305
- data/mod/bootstrap/lib/stylesheets/bootstrap/_grid.scss +0 -84
- data/mod/bootstrap/lib/stylesheets/bootstrap/_input-groups.scss +0 -166
- data/mod/bootstrap/lib/stylesheets/bootstrap/_jumbotron.scss +0 -50
- data/mod/bootstrap/lib/stylesheets/bootstrap/_labels.scss +0 -66
- data/mod/bootstrap/lib/stylesheets/bootstrap/_media.scss +0 -61
- data/mod/bootstrap/lib/stylesheets/bootstrap/_mixins.scss +0 -39
- data/mod/bootstrap/lib/stylesheets/bootstrap/_navbar.scss +0 -662
- data/mod/bootstrap/lib/stylesheets/bootstrap/_navs.scss +0 -242
- data/mod/bootstrap/lib/stylesheets/bootstrap/_normalize.scss +0 -427
- data/mod/bootstrap/lib/stylesheets/bootstrap/_pager.scss +0 -54
- data/mod/bootstrap/lib/stylesheets/bootstrap/_pagination.scss +0 -88
- data/mod/bootstrap/lib/stylesheets/bootstrap/_panels.scss +0 -265
- data/mod/bootstrap/lib/stylesheets/bootstrap/_popovers.scss +0 -135
- data/mod/bootstrap/lib/stylesheets/bootstrap/_print.scss +0 -107
- data/mod/bootstrap/lib/stylesheets/bootstrap/_progress-bars.scss +0 -87
- data/mod/bootstrap/lib/stylesheets/bootstrap/_responsive-utilities.scss +0 -177
- data/mod/bootstrap/lib/stylesheets/bootstrap/_scaffolding.scss +0 -162
- data/mod/bootstrap/lib/stylesheets/bootstrap/_tables.scss +0 -237
- data/mod/bootstrap/lib/stylesheets/bootstrap/_theme.scss +0 -273
- data/mod/bootstrap/lib/stylesheets/bootstrap/_thumbnails.scss +0 -38
- data/mod/bootstrap/lib/stylesheets/bootstrap/_tooltip.scss +0 -102
- data/mod/bootstrap/lib/stylesheets/bootstrap/_type.scss +0 -298
- data/mod/bootstrap/lib/stylesheets/bootstrap/_utilities.scss +0 -55
- data/mod/bootstrap/lib/stylesheets/bootstrap/_variables.scss +0 -866
- data/mod/bootstrap/lib/stylesheets/bootstrap/_wells.scss +0 -29
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_background-variant.scss +0 -11
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_border-radius.scss +0 -18
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_buttons.scss +0 -52
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_center-block.scss +0 -7
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_clearfix.scss +0 -22
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_gradients.scss +0 -58
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_grid-framework.scss +0 -81
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_grid.scss +0 -122
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_hide-text.scss +0 -21
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_image.scss +0 -33
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_opacity.scss +0 -8
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_pagination.scss +0 -23
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_panels.scss +0 -24
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_progress-bar.scss +0 -10
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_reset-filter.scss +0 -8
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_responsive-visibility.scss +0 -21
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_size.scss +0 -10
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_tab-focus.scss +0 -9
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_table-row.scss +0 -28
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_text-emphasis.scss +0 -11
- data/mod/bootstrap/lib/stylesheets/bootstrap/mixins/_vendor-prefixes.scss +0 -222
- data/mod/machines/file/all_style_machine_output/file.css +0 -19
- data/tmpsets/set/mod001-core/abstract/code_file.rb +0 -79
- data/tmpsets/set/mod001-core/all/actify.rb +0 -100
- data/tmpsets/set/mod001-core/all/active_card.rb +0 -42
- data/tmpsets/set/mod001-core/all/collection.rb +0 -313
- data/tmpsets/set/mod001-core/all/content.rb +0 -69
- data/tmpsets/set/mod001-core/all/erb.rb +0 -18
- data/tmpsets/set/mod001-core/all/event.rb +0 -62
- data/tmpsets/set/mod001-core/all/export.rb +0 -49
- data/tmpsets/set/mod001-core/all/fetch.rb +0 -335
- data/tmpsets/set/mod001-core/all/haml.rb +0 -14
- data/tmpsets/set/mod001-core/all/initialize.rb +0 -42
- data/tmpsets/set/mod001-core/all/location_history.rb +0 -15
- data/tmpsets/set/mod001-core/all/name.rb +0 -282
- data/tmpsets/set/mod001-core/all/name_validations.rb +0 -65
- data/tmpsets/set/mod001-core/all/pattern.rb +0 -67
- data/tmpsets/set/mod001-core/all/permissions.rb +0 -309
- data/tmpsets/set/mod001-core/all/phases.rb +0 -23
- data/tmpsets/set/mod001-core/all/references.rb +0 -187
- data/tmpsets/set/mod001-core/all/rules.rb +0 -311
- data/tmpsets/set/mod001-core/all/stages.rb +0 -31
- data/tmpsets/set/mod001-core/all/states.rb +0 -31
- data/tmpsets/set/mod001-core/all/subcards.rb +0 -85
- data/tmpsets/set/mod001-core/all/templating.rb +0 -78
- data/tmpsets/set/mod001-core/all/tracked_attributes.rb +0 -154
- data/tmpsets/set/mod001-core/all/trash.rb +0 -63
- data/tmpsets/set/mod001-core/all/type.rb +0 -60
- data/tmpsets/set/mod001-core/all/utils.rb +0 -132
- data/tmpsets/set/mod001-core/all/view_cache.rb +0 -16
- data/tmpsets/set/mod002-history/all/actions.rb +0 -60
- data/tmpsets/set/mod002-history/all/content_history.rb +0 -168
- data/tmpsets/set/mod002-history/all/history.rb +0 -407
- data/tmpsets/set/mod003-basic_formats/all/all_css.rb +0 -45
- data/tmpsets/set/mod003-basic_formats/all/all_csv.rb +0 -56
- data/tmpsets/set/mod003-basic_formats/all/all_js.rb +0 -13
- data/tmpsets/set/mod003-basic_formats/all/base.rb +0 -155
- data/tmpsets/set/mod003-basic_formats/all/file.rb +0 -16
- data/tmpsets/set/mod003-basic_formats/all/json.rb +0 -76
- data/tmpsets/set/mod003-basic_formats/all/rss.rb +0 -77
- data/tmpsets/set/mod003-basic_formats/all/text.rb +0 -13
- data/tmpsets/set/mod003-basic_formats/self/01_head/javascript.rb +0 -79
- data/tmpsets/set/mod003-basic_formats/self/head.rb +0 -101
- data/tmpsets/set/mod004-pointer/abstract/01_pointer.rb +0 -193
- data/tmpsets/set/mod004-pointer/abstract/01_pointer/edit.rb +0 -224
- data/tmpsets/set/mod004-pointer/abstract/code_pointer.rb +0 -16
- data/tmpsets/set/mod004-pointer/self/script_editors.rb +0 -8
- data/tmpsets/set/mod004-pointer/self/script_mods.rb +0 -8
- data/tmpsets/set/mod004-pointer/self/script_pointer_config.rb +0 -10
- data/tmpsets/set/mod004-pointer/type/pointer.rb +0 -8
- data/tmpsets/set/mod005-ace_editor/abstract/ace_editor.rb +0 -18
- data/tmpsets/set/mod005-ace_editor/self/script_ace.rb +0 -10
- data/tmpsets/set/mod005-ace_editor/self/script_ace_config.rb +0 -12
- data/tmpsets/set/mod006-prosemirror_editor/abstract/prosemirror_editor.rb +0 -14
- data/tmpsets/set/mod006-prosemirror_editor/self/script_prosemirror.rb +0 -10
- data/tmpsets/set/mod006-prosemirror_editor/self/script_prosemirror_config.rb +0 -13
- data/tmpsets/set/mod008-solid_cache/abstract/solid_cache.rb +0 -106
- data/tmpsets/set/mod008-solid_cache/all/solid_cache.rb +0 -21
- data/tmpsets/set/mod008-solid_cache/right/solid_cache.rb +0 -39
- data/tmpsets/set/mod009-basic_types/type/html.rb +0 -26
- data/tmpsets/set/mod009-basic_types/type/plain_text.rb +0 -19
- data/tmpsets/set/mod010-machines/abstract/script.rb +0 -49
- data/tmpsets/set/mod010-machines/all/reset_machines.rb +0 -19
- data/tmpsets/set/mod010-machines/right/machine_cache.rb +0 -18
- data/tmpsets/set/mod010-machines/right/machine_input.rb +0 -10
- data/tmpsets/set/mod010-machines/right/machine_output.rb +0 -39
- data/tmpsets/set/mod010-machines/self/script_card_menu.rb +0 -8
- data/tmpsets/set/mod010-machines/self/script_html5shiv_printshiv.rb +0 -8
- data/tmpsets/set/mod010-machines/self/script_jquery.rb +0 -8
- data/tmpsets/set/mod010-machines/self/script_jquery_helper.rb +0 -16
- data/tmpsets/set/mod010-machines/self/script_slot.rb +0 -14
- data/tmpsets/set/mod010-machines/self/style_bootstrap_compatible.rb +0 -8
- data/tmpsets/set/mod010-machines/self/style_cards.rb +0 -8
- data/tmpsets/set/mod010-machines/self/style_jquery_ui_smoothness.rb +0 -8
- data/tmpsets/set/mod010-machines/type/coffee_script.rb +0 -47
- data/tmpsets/set/mod010-machines/type/css.rb +0 -67
- data/tmpsets/set/mod010-machines/type/java_script.rb +0 -36
- data/tmpsets/set/mod010-machines/type/scss.rb +0 -21
- data/tmpsets/set/mod010-machines/type/skin.rb +0 -13
- data/tmpsets/set/mod011-settings/abstract/permission.rb +0 -119
- data/tmpsets/set/mod011-settings/right/add_help.rb +0 -18
- data/tmpsets/set/mod011-settings/right/comment.rb +0 -8
- data/tmpsets/set/mod011-settings/right/create.rb +0 -8
- data/tmpsets/set/mod011-settings/right/default.rb +0 -14
- data/tmpsets/set/mod011-settings/right/delete.rb +0 -8
- data/tmpsets/set/mod011-settings/right/help.rb +0 -10
- data/tmpsets/set/mod011-settings/right/read.rb +0 -10
- data/tmpsets/set/mod011-settings/right/script.rb +0 -16
- data/tmpsets/set/mod011-settings/right/structure.rb +0 -68
- data/tmpsets/set/mod011-settings/right/style.rb +0 -17
- data/tmpsets/set/mod011-settings/right/update.rb +0 -8
- data/tmpsets/set/mod011-settings/self/accountable.rb +0 -10
- data/tmpsets/set/mod011-settings/self/add_help.rb +0 -9
- data/tmpsets/set/mod011-settings/self/autoname.rb +0 -9
- data/tmpsets/set/mod011-settings/self/captcha.rb +0 -9
- data/tmpsets/set/mod011-settings/self/create.rb +0 -9
- data/tmpsets/set/mod011-settings/self/default.rb +0 -9
- data/tmpsets/set/mod011-settings/self/default_html_view.rb +0 -9
- data/tmpsets/set/mod011-settings/self/delete.rb +0 -9
- data/tmpsets/set/mod011-settings/self/follow_fields.rb +0 -9
- data/tmpsets/set/mod011-settings/self/help.rb +0 -9
- data/tmpsets/set/mod011-settings/self/input.rb +0 -11
- data/tmpsets/set/mod011-settings/self/layout.rb +0 -9
- data/tmpsets/set/mod011-settings/self/on_create.rb +0 -9
- data/tmpsets/set/mod011-settings/self/on_delete.rb +0 -9
- data/tmpsets/set/mod011-settings/self/on_update.rb +0 -9
- data/tmpsets/set/mod011-settings/self/options.rb +0 -11
- data/tmpsets/set/mod011-settings/self/options_label.rb +0 -11
- data/tmpsets/set/mod011-settings/self/read.rb +0 -9
- data/tmpsets/set/mod011-settings/self/recent_settings.rb +0 -10
- data/tmpsets/set/mod011-settings/self/script.rb +0 -9
- data/tmpsets/set/mod011-settings/self/structure.rb +0 -9
- data/tmpsets/set/mod011-settings/self/style.rb +0 -9
- data/tmpsets/set/mod011-settings/self/table_of_contents.rb +0 -9
- data/tmpsets/set/mod011-settings/self/thanks.rb +0 -9
- data/tmpsets/set/mod011-settings/self/update.rb +0 -9
- data/tmpsets/set/mod011-settings/type/setting.rb +0 -111
- data/tmpsets/set/mod012-email/all/email_html.rb +0 -11
- data/tmpsets/set/mod012-email/all/email_text.rb +0 -12
- data/tmpsets/set/mod012-email/all/follow.rb +0 -253
- data/tmpsets/set/mod012-email/all/notify.rb +0 -271
- data/tmpsets/set/mod012-email/all/observer.rb +0 -33
- data/tmpsets/set/mod012-email/right/bcc.rb +0 -47
- data/tmpsets/set/mod012-email/right/cc.rb +0 -10
- data/tmpsets/set/mod012-email/right/follow.rb +0 -106
- data/tmpsets/set/mod012-email/right/follow_fields.rb +0 -10
- data/tmpsets/set/mod012-email/right/followers.rb +0 -41
- data/tmpsets/set/mod012-email/right/following.rb +0 -65
- data/tmpsets/set/mod012-email/right/from.rb +0 -10
- data/tmpsets/set/mod012-email/right/html_message.rb +0 -10
- data/tmpsets/set/mod012-email/right/to.rb +0 -10
- data/tmpsets/set/mod012-email/self/always.rb +0 -20
- data/tmpsets/set/mod012-email/self/created.rb +0 -26
- data/tmpsets/set/mod012-email/self/edited.rb +0 -27
- data/tmpsets/set/mod012-email/self/follow.rb +0 -9
- data/tmpsets/set/mod012-email/self/follow_defaults.rb +0 -75
- data/tmpsets/set/mod012-email/self/never.rb +0 -20
- data/tmpsets/set/mod012-email/type/email_template.rb +0 -133
- data/tmpsets/set/mod012-email/type_plus_right/user/follow.rb +0 -184
- data/tmpsets/set/mod013-carrierwave/abstract/attachment.rb +0 -282
- data/tmpsets/set/mod013-carrierwave/type/file.rb +0 -155
- data/tmpsets/set/mod013-carrierwave/type/image.rb +0 -96
- data/tmpsets/set/mod014-admin/self/admin.rb +0 -113
- data/tmpsets/set/mod014-admin/self/admin_info.rb +0 -110
- data/tmpsets/set/mod014-admin/self/version.rb +0 -15
- data/tmpsets/set/mod015-developer/all/event_viz.rb +0 -59
- data/tmpsets/set/mod015-developer/all/view_viz.rb +0 -30
- data/tmpsets/set/mod015-developer/right/debug.rb +0 -96
- data/tmpsets/set/mod016-standard/all/comment.rb +0 -67
- data/tmpsets/set/mod016-standard/all/error.rb +0 -229
- data/tmpsets/set/mod016-standard/all/links.rb +0 -165
- data/tmpsets/set/mod016-standard/all/list_changes.rb +0 -53
- data/tmpsets/set/mod016-standard/all/rich_html/content.rb +0 -261
- data/tmpsets/set/mod016-standard/all/rich_html/editing.rb +0 -247
- data/tmpsets/set/mod016-standard/all/rich_html/form.rb +0 -298
- data/tmpsets/set/mod016-standard/all/rich_html/header.rb +0 -78
- data/tmpsets/set/mod016-standard/all/rich_html/menu.rb +0 -154
- data/tmpsets/set/mod016-standard/all/rich_html/modal.rb +0 -58
- data/tmpsets/set/mod016-standard/all/rich_html/toolbar.rb +0 -312
- data/tmpsets/set/mod016-standard/all/rich_html/wrapper.rb +0 -191
- data/tmpsets/set/mod016-standard/right/discussion.rb +0 -10
- data/tmpsets/set/mod016-standard/right/when_created.rb +0 -14
- data/tmpsets/set/mod016-standard/right/when_last_edited.rb +0 -14
- data/tmpsets/set/mod016-standard/rstar/rules.rb +0 -107
- data/tmpsets/set/mod016-standard/rstar/rules_editor.rb +0 -371
- data/tmpsets/set/mod016-standard/self/alerts.rb +0 -12
- data/tmpsets/set/mod016-standard/self/codenames.rb +0 -7
- data/tmpsets/set/mod016-standard/self/foot.rb +0 -15
- data/tmpsets/set/mod016-standard/self/navbox.rb +0 -36
- data/tmpsets/set/mod016-standard/self/now.rb +0 -14
- data/tmpsets/set/mod016-standard/self/recent.rb +0 -34
- data/tmpsets/set/mod016-standard/self/search.rb +0 -71
- data/tmpsets/set/mod016-standard/type/basic.rb +0 -59
- data/tmpsets/set/mod016-standard/type/cardtype.rb +0 -81
- data/tmpsets/set/mod016-standard/type/date.rb +0 -15
- data/tmpsets/set/mod016-standard/type/layout_type.rb +0 -17
- data/tmpsets/set/mod016-standard/type/list.rb +0 -120
- data/tmpsets/set/mod016-standard/type/listed_by.rb +0 -85
- data/tmpsets/set/mod016-standard/type/number.rb +0 -25
- data/tmpsets/set/mod016-standard/type/phrase.rb +0 -10
- data/tmpsets/set/mod016-standard/type/search_type.rb +0 -339
- data/tmpsets/set/mod016-standard/type/session.rb +0 -42
- data/tmpsets/set/mod016-standard/type/set.rb +0 -371
- data/tmpsets/set/mod016-standard/type/toggle.rb +0 -19
- data/tmpsets/set/mod016-standard/type/uri.rb +0 -18
- data/tmpsets/set/mod017-account/all/account.rb +0 -72
- data/tmpsets/set/mod017-account/right/account.rb +0 -196
- data/tmpsets/set/mod017-account/right/email.rb +0 -61
- data/tmpsets/set/mod017-account/right/password.rb +0 -54
- data/tmpsets/set/mod017-account/right/salt.rb +0 -12
- data/tmpsets/set/mod017-account/right/status.rb +0 -16
- data/tmpsets/set/mod017-account/right/token.rb +0 -57
- data/tmpsets/set/mod017-account/self/account_links.rb +0 -72
- data/tmpsets/set/mod017-account/self/signin.rb +0 -165
- data/tmpsets/set/mod017-account/type/signup.rb +0 -175
- data/tmpsets/set/mod017-account/type/user.rb +0 -88
- data/tmpsets/set/mod018-bootstrap/all/bootstrap/form.rb +0 -42
- data/tmpsets/set/mod018-bootstrap/all/bootstrap/helper.rb +0 -236
- data/tmpsets/set/mod018-bootstrap/all/bootstrap/table.rb +0 -68
- data/tmpsets/set/mod018-bootstrap/all/bootstrap/tabs.rb +0 -88
- data/tmpsets/set/mod018-bootstrap/all/bootstrap/wrapper.rb +0 -18
- data/tmpsets/set/mod018-bootstrap/all/rich_bootstrap.rb +0 -13
- data/tmpsets/set/mod018-bootstrap/self/bootstrap_cards.rb +0 -8
- data/tmpsets/set/mod018-bootstrap/self/bootstrap_js.rb +0 -12
- data/tmpsets/set/mod018-bootstrap/self/bootswatch_shared.rb +0 -47
- data/tmpsets/set/mod018-bootstrap/self/script_mods.rb +0 -7
- data/tmpsets/set/mod018-bootstrap/self/smartmenu_css.rb +0 -12
- data/tmpsets/set/mod018-bootstrap/self/smartmenu_js.rb +0 -12
- data/tmpsets/set_pattern/100-all.rb +0 -24
- data/tmpsets/set_pattern/101-all_plus.rb +0 -26
- data/tmpsets/set_pattern/102-type.rb +0 -36
- data/tmpsets/set_pattern/103-star.rb +0 -28
- data/tmpsets/set_pattern/104-rstar.rb +0 -30
- data/tmpsets/set_pattern/105-right.rb +0 -33
- data/tmpsets/set_pattern/106-type_plus_right.rb +0 -39
- data/tmpsets/set_pattern/107-self.rb +0 -32
@@ -1,75 +0,0 @@
|
|
1
|
-
# -*- encoding : utf-8 -*-
|
2
|
-
class Card; module Set; class Self; module FollowDefaults; extend Card::Set
|
3
|
-
# ~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/email/set/self/follow_defaults.rb ~~
|
4
|
-
event :update_follow_rules, :finalize,
|
5
|
-
on: :save, when: proc { |c| c.update_all_users } do
|
6
|
-
defaults = item_names.map do |item|
|
7
|
-
if (set_card = Card.fetch item.to_name.left) && set_card.type_code == :set
|
8
|
-
option_card = Card.fetch(item.to_name.right) ||
|
9
|
-
Card[item.to_name.right.to_sym]
|
10
|
-
option = if option_card.follow_option?
|
11
|
-
option_card.name
|
12
|
-
else
|
13
|
-
"*always"
|
14
|
-
end
|
15
|
-
[set_card, option]
|
16
|
-
elsif (set_card = Card.fetch sug) && set_card.type_code == :set
|
17
|
-
[set_card, "*always"]
|
18
|
-
end
|
19
|
-
end.compact
|
20
|
-
Auth.as_bot do
|
21
|
-
Card.search(type: "user").each do |user|
|
22
|
-
defaults.each do |set_card, option|
|
23
|
-
follow_rule = Card.fetch(set_card.follow_rule_name(user.name), new: {})
|
24
|
-
next unless follow_rule
|
25
|
-
follow_rule.drop_item "*never"
|
26
|
-
follow_rule.drop_item "*always"
|
27
|
-
follow_rule.add_item option
|
28
|
-
follow_rule.save!
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
32
|
-
Card.follow_caches_expired
|
33
|
-
end
|
34
|
-
|
35
|
-
format :html do
|
36
|
-
view :edit, perms: :update, tags: :unknown_ok do |args|
|
37
|
-
frame_and_form :update, args do
|
38
|
-
[
|
39
|
-
_optional_render(:content_formgroup, args),
|
40
|
-
_optional_render(:confirm_update_all, args),
|
41
|
-
_optional_render(:button_formgroup, args)
|
42
|
-
]
|
43
|
-
end
|
44
|
-
end
|
45
|
-
|
46
|
-
view :confirm_update_all do |args|
|
47
|
-
wrap args do
|
48
|
-
alert "info" do
|
49
|
-
%(
|
50
|
-
<h1>Are you sure you want to change the default follow rules?</h1>
|
51
|
-
<p>You may choose to update all existing users.
|
52
|
-
This may take a while. </p>
|
53
|
-
)
|
54
|
-
end
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
|
-
def default_edit_args args
|
59
|
-
args[:hidden] ||= {}
|
60
|
-
args[:hidden].reverse_merge!(
|
61
|
-
success: "_self",
|
62
|
-
card: { update_all_users: false }
|
63
|
-
)
|
64
|
-
args[:buttons] = %(
|
65
|
-
#{submit_button text: 'Submit and update all users',
|
66
|
-
disable_with: 'Updating', class: 'follow-updater'}
|
67
|
-
#{button_tag 'Submit', class: 'follow'}
|
68
|
-
#{cancel_button href: path(view: :edit, id: card.id)}
|
69
|
-
)
|
70
|
-
end
|
71
|
-
end
|
72
|
-
|
73
|
-
|
74
|
-
# ~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/email/set/self/follow_defaults.rb ~~
|
75
|
-
end;end;end;end;
|
@@ -1,20 +0,0 @@
|
|
1
|
-
# -*- encoding : utf-8 -*-
|
2
|
-
class Card; module Set; class Self; module Never; extend Card::Set
|
3
|
-
# ~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/email/set/self/never.rb ~~
|
4
|
-
include Card::FollowOption
|
5
|
-
|
6
|
-
follow_opts position: 3
|
7
|
-
|
8
|
-
follow_test { |_follower_id, _accounted_ids| false }
|
9
|
-
|
10
|
-
def title
|
11
|
-
"Ignoring"
|
12
|
-
end
|
13
|
-
|
14
|
-
def label
|
15
|
-
"ignore"
|
16
|
-
end
|
17
|
-
|
18
|
-
|
19
|
-
# ~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/email/set/self/never.rb ~~
|
20
|
-
end;end;end;end;
|
@@ -1,133 +0,0 @@
|
|
1
|
-
# -*- encoding : utf-8 -*-
|
2
|
-
class Card; module Set; class Type; module EmailTemplate; extend Card::Set
|
3
|
-
# ~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/email/set/type/email_template.rb ~~
|
4
|
-
|
5
|
-
def clean_html?
|
6
|
-
false
|
7
|
-
end
|
8
|
-
|
9
|
-
def deliver args={}
|
10
|
-
mail = format.render_mail(args)
|
11
|
-
mail.deliver
|
12
|
-
rescue Net::SMTPError => exception
|
13
|
-
errors.add :exception, exception.message
|
14
|
-
end
|
15
|
-
|
16
|
-
def process_email_field field, config, args
|
17
|
-
config[field] =
|
18
|
-
if args[field]
|
19
|
-
args[field]
|
20
|
-
elsif (field_card = fetch(trait: field))
|
21
|
-
# configuration can be anything visible to configurer
|
22
|
-
user = (args[:follower] && Card.fetch(args[:follower])) ||
|
23
|
-
field_card.updater
|
24
|
-
Auth.as(user) do
|
25
|
-
yield(field_card)
|
26
|
-
end
|
27
|
-
else
|
28
|
-
""
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
|
-
def process_message_field field, config, args, format, special_args=nil
|
33
|
-
process_email_field(field, config, args) do |field_card|
|
34
|
-
content_args = args.clone
|
35
|
-
content_args.merge! special_args if special_args
|
36
|
-
field_card.contextual_content args[:context], { format: format },
|
37
|
-
content_args
|
38
|
-
end
|
39
|
-
end
|
40
|
-
|
41
|
-
def email_config args={}
|
42
|
-
config = {}
|
43
|
-
args[:context] ||= self
|
44
|
-
|
45
|
-
[:to, :from, :cc, :bcc].each do |field_name|
|
46
|
-
process_email_field(field_name, config, args) do |field_card|
|
47
|
-
field_card.process_email_addresses(
|
48
|
-
args[:context], { format: "email_text" }, args
|
49
|
-
)
|
50
|
-
end
|
51
|
-
end
|
52
|
-
process_email_field(:attach, config, args) do |field_card|
|
53
|
-
field_card.extended_item_contents args[:context]
|
54
|
-
end
|
55
|
-
process_message_field :subject, config, args, "email_text",
|
56
|
-
content_opts: { chunk_list: :nest_only }
|
57
|
-
process_message_field :text_message, config, args, "email_text"
|
58
|
-
process_message_field :html_message, config, args, "email_html"
|
59
|
-
if config[:html_message].present?
|
60
|
-
config[:html_message] = Card::Mailer.layout config[:html_message]
|
61
|
-
end
|
62
|
-
|
63
|
-
from_name, from_email =
|
64
|
-
if config[:from] =~ /(.*)\<(.*)>/
|
65
|
-
[Regexp.last_match(1).strip, Regexp.last_match(2)]
|
66
|
-
else
|
67
|
-
[nil, config[:from]]
|
68
|
-
end
|
69
|
-
|
70
|
-
if (default_from = Card::Mailer.default[:from])
|
71
|
-
config[:from] =
|
72
|
-
if from_email
|
73
|
-
%("#{from_name || from_email}" <#{default_from}>)
|
74
|
-
else
|
75
|
-
default_from
|
76
|
-
end
|
77
|
-
config[:reply_to] ||= config[:from]
|
78
|
-
elsif config[:from].blank?
|
79
|
-
config[:from] = Card[Card::WagnBotID].account.email
|
80
|
-
end
|
81
|
-
config.select { |_k, v| v.present? }
|
82
|
-
end
|
83
|
-
|
84
|
-
format do
|
85
|
-
view :mail, perms: :none do |args|
|
86
|
-
args = card.email_config(args)
|
87
|
-
text_message = args.delete(:text_message)
|
88
|
-
html_message = args.delete(:html_message)
|
89
|
-
attachment_list = args.delete(:attach)
|
90
|
-
alternative = (text_message.present? && html_message.present?)
|
91
|
-
mail = Card::Mailer.new_mail(args) do
|
92
|
-
if alternative
|
93
|
-
if attachment_list && !attachment_list.empty?
|
94
|
-
content_type "multipart/mixed"
|
95
|
-
part content_type: "multipart/alternative" do |copy|
|
96
|
-
copy.part content_type: "text/plain" do |plain|
|
97
|
-
plain.body = text_message
|
98
|
-
end
|
99
|
-
copy.part content_type: "text/html" do |html|
|
100
|
-
html.body = html_message
|
101
|
-
end
|
102
|
-
end
|
103
|
-
else
|
104
|
-
text_part { body text_message }
|
105
|
-
html_part do
|
106
|
-
content_type "text/html; charset=UTF-8"
|
107
|
-
body html_message
|
108
|
-
end
|
109
|
-
end
|
110
|
-
elsif html_message.present?
|
111
|
-
content_type "text/html; charset=UTF-8"
|
112
|
-
body html_message
|
113
|
-
else
|
114
|
-
content_type "text/plain; charset=UTF-8"
|
115
|
-
text_part { body text_message }
|
116
|
-
end
|
117
|
-
|
118
|
-
if attachment_list
|
119
|
-
attachment_list.each_with_index do |cardname, i|
|
120
|
-
if (c = Card[cardname]) && c.respond_to?(:attachment)
|
121
|
-
add_file filename: "attachment-#{i + 1}.#{c.attachment.extension}",
|
122
|
-
content: File.read(c.attachment.path)
|
123
|
-
end
|
124
|
-
end
|
125
|
-
end
|
126
|
-
end # TODO: add error handling
|
127
|
-
mail
|
128
|
-
end
|
129
|
-
end
|
130
|
-
|
131
|
-
|
132
|
-
# ~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/email/set/type/email_template.rb ~~
|
133
|
-
end;end;end;end;
|
@@ -1,184 +0,0 @@
|
|
1
|
-
# -*- encoding : utf-8 -*-
|
2
|
-
class Card; module Set; class TypePlusRight; module User; module Follow; extend Card::Set
|
3
|
-
# ~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/email/set/type_plus_right/user/follow.rb ~~
|
4
|
-
include Card::Set::Type::Pointer
|
5
|
-
|
6
|
-
def raw_content
|
7
|
-
item_names.map { |name| "[[#{name}]]" }
|
8
|
-
end
|
9
|
-
|
10
|
-
def item_names
|
11
|
-
if (user = left)
|
12
|
-
Card.preference_names user.name, "follow"
|
13
|
-
else
|
14
|
-
[]
|
15
|
-
end
|
16
|
-
end
|
17
|
-
|
18
|
-
def item_cards
|
19
|
-
item_names.map { |name| Card.fetch name }
|
20
|
-
end
|
21
|
-
|
22
|
-
def virtual?
|
23
|
-
!real?
|
24
|
-
end
|
25
|
-
|
26
|
-
format { include Card::Set::Type::Pointer::Format }
|
27
|
-
|
28
|
-
format :html do
|
29
|
-
include Card::Set::Type::Pointer::HtmlFormat
|
30
|
-
|
31
|
-
view :closed_content do |_args|
|
32
|
-
""
|
33
|
-
end
|
34
|
-
|
35
|
-
view :core do |args|
|
36
|
-
<<-HTML
|
37
|
-
<div role="tabpanel">
|
38
|
-
<ul class="nav nav-tabs" role="tablist" id="myTab">
|
39
|
-
<li role="presentation" class="active">
|
40
|
-
<a href="#following" aria-controls="following"
|
41
|
-
role="tab" data-toggle="tab">Follow</a>
|
42
|
-
</li>
|
43
|
-
<li role="presentation">
|
44
|
-
<a href="#ignoring" aria-controls="ignoring"
|
45
|
-
role="tab" data-toggle="tab">Ignore</a>
|
46
|
-
</li>
|
47
|
-
</ul>
|
48
|
-
<div class="tab-content">
|
49
|
-
<div role="tabpanel" class="tab-pane active" id="following">
|
50
|
-
#{render_following_list args}
|
51
|
-
</div>
|
52
|
-
<div role="tabpanel" class="tab-pane" id="ignoring">
|
53
|
-
#{render_ignoring_list}
|
54
|
-
</div>
|
55
|
-
</div>
|
56
|
-
</div>
|
57
|
-
HTML
|
58
|
-
end
|
59
|
-
|
60
|
-
def followed_by_option
|
61
|
-
hash = Hash.new { |h, k| h[k] = [] }
|
62
|
-
card.item_cards.each do |follow_rule|
|
63
|
-
follow_rule.item_cards.each do |follow_option|
|
64
|
-
hash[follow_option.codename.to_sym] << follow_rule
|
65
|
-
end
|
66
|
-
end
|
67
|
-
end
|
68
|
-
|
69
|
-
def each_suggestion
|
70
|
-
return unless (suggestions = Card["follow suggestions"])
|
71
|
-
suggestions.item_names.each do |sug|
|
72
|
-
set_card = Card.fetch sug.to_name.left
|
73
|
-
if set_card && set_card.type_code == :set
|
74
|
-
sugtag = sug.to_name.right
|
75
|
-
option_card = Card.fetch(sugtag) || Card[sugtag.to_sym]
|
76
|
-
option = option_card.follow_option? ? option_card.name : "*always"
|
77
|
-
yield(set_card, option)
|
78
|
-
elsif (set_card = Card.fetch sug) && set_card.type_code == :set
|
79
|
-
yield(set_card, "*always")
|
80
|
-
end
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
# returns hashes with existing and suggested follow options
|
85
|
-
# structure:
|
86
|
-
# set_pattern_class =>
|
87
|
-
# [ {card: rule_card, options: ['*always', '*created'] },.... ]
|
88
|
-
def followed_by_set
|
89
|
-
res = Hash.new { |h, k| h[k] = [] }
|
90
|
-
never = Card[:never].name
|
91
|
-
card.item_cards.each do |follow_rule|
|
92
|
-
options = follow_rule.item_names.reject { |item| item == never }
|
93
|
-
res[follow_rule.rule_set.subclass_for_set] << { card: follow_rule,
|
94
|
-
options: options }
|
95
|
-
end
|
96
|
-
|
97
|
-
if Auth.signed_in? && Auth.current_id == card.left.id
|
98
|
-
each_suggestion do |set_card, option|
|
99
|
-
suggested_rule_name = set_card.follow_rule_name(card.trunk)
|
100
|
-
rule = res[set_card.subclass_for_set].find do |rule|
|
101
|
-
rule[:card].name == suggested_rule_name
|
102
|
-
end
|
103
|
-
if rule
|
104
|
-
rule[:options] << option unless rule[:options].include? option
|
105
|
-
else
|
106
|
-
rule_card = Card.new(name: suggested_rule_name)
|
107
|
-
res[set_card.subclass_for_set] << { card: rule_card,
|
108
|
-
options: [option] }
|
109
|
-
end
|
110
|
-
end
|
111
|
-
end
|
112
|
-
res
|
113
|
-
end
|
114
|
-
|
115
|
-
view :following_list do |_args|
|
116
|
-
if !Auth.signed_in? || Auth.current_id != card.left.id
|
117
|
-
hide_buttons = [:delete_follow_rule_button, :add_follow_rule_button]
|
118
|
-
end
|
119
|
-
|
120
|
-
sets = followed_by_set
|
121
|
-
wrap_with :div, class: "pointer-list-editor" do
|
122
|
-
wrap_with :ul, class: "delete-list list-group" do
|
123
|
-
Card.set_patterns.select { |p| sets[p] }.reverse.map do |set_pattern|
|
124
|
-
sets[set_pattern].map do |rule|
|
125
|
-
rule[:options].map do |option|
|
126
|
-
content_tag :li, class: "list-group-item" do
|
127
|
-
subformat(rule[:card]).render_follow_item condition: option,
|
128
|
-
hide: hide_buttons
|
129
|
-
end
|
130
|
-
end.join("\n")
|
131
|
-
end.join("\n")
|
132
|
-
end.join("\n")
|
133
|
-
end
|
134
|
-
end
|
135
|
-
end
|
136
|
-
|
137
|
-
view :ignoring_list do |_args|
|
138
|
-
ignore_list = []
|
139
|
-
card.item_cards.each do |follow_rule|
|
140
|
-
follow_rule.item_cards.each do |follow_option|
|
141
|
-
ignore_list << follow_rule if follow_option.codename.to_sym == :never
|
142
|
-
end
|
143
|
-
end
|
144
|
-
if !Auth.signed_in? || Auth.current_id != card.left.id
|
145
|
-
hide_buttons = [:delete_follow_rule_button, :add_follow_rule_button]
|
146
|
-
end
|
147
|
-
never = Card[:never].name
|
148
|
-
wrap_with :div, class: "pointer-list-editor" do
|
149
|
-
wrap_with :ul, class: "delete-list list-group" do
|
150
|
-
ignore_list.map do |rule_card|
|
151
|
-
content_tag :li, class: "list-group-item" do
|
152
|
-
subformat(rule_card).render_follow_item condition: never,
|
153
|
-
hide: hide_buttons
|
154
|
-
end
|
155
|
-
end.join "\n"
|
156
|
-
end
|
157
|
-
end
|
158
|
-
end
|
159
|
-
|
160
|
-
view :pointer_items, tags: :unknown_ok do |args|
|
161
|
-
super(args.merge(item: :link))
|
162
|
-
end
|
163
|
-
|
164
|
-
view :errors, perms: :none do |args|
|
165
|
-
if card.errors.any?
|
166
|
-
if card.errors.find { |attrib, _msg| attrib == :permission_denied }
|
167
|
-
Env.save_interrupted_action(request.env["REQUEST_URI"])
|
168
|
-
title = "Problems with #{card.name}"
|
169
|
-
frame args.merge(panel_class: "panel panel-warning",
|
170
|
-
title: title, hide: "menu") do
|
171
|
-
"Please #{link_to 'sign in', card_url(':signin')}" # " #{to_task}"
|
172
|
-
end
|
173
|
-
else
|
174
|
-
super(args)
|
175
|
-
end
|
176
|
-
end
|
177
|
-
end
|
178
|
-
end
|
179
|
-
|
180
|
-
format(:css) { include Card::Set::Type::Pointer::CssFormat }
|
181
|
-
|
182
|
-
|
183
|
-
# ~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/email/set/type_plus_right/user/follow.rb ~~
|
184
|
-
end;end;end;end;end;
|
@@ -1,282 +0,0 @@
|
|
1
|
-
# -*- encoding : utf-8 -*-
|
2
|
-
class Card; module Set; class Abstract; module Attachment; extend Card::Set
|
3
|
-
# ~~ above autogenerated; below pulled from /Users/ethan/dev/wagn/gem/card/mod/carrierwave/set/abstract/attachment.rb ~~
|
4
|
-
require "carrier_wave/cardmount"
|
5
|
-
|
6
|
-
def self.included host_class
|
7
|
-
host_class.extend CarrierWave::CardMount
|
8
|
-
end
|
9
|
-
|
10
|
-
event :select_file_revision, after: :select_action do
|
11
|
-
attachment.retrieve_from_store!(attachment.identifier)
|
12
|
-
end
|
13
|
-
|
14
|
-
event :upload_attachment, :prepare_to_validate,
|
15
|
-
on: :save, when: proc { |c| c.preliminary_upload? } do
|
16
|
-
save_original_filename # save original filename as comment in action
|
17
|
-
write_identifier # set db_content
|
18
|
-
# (needs original filename to determine extension)
|
19
|
-
store_attachment!
|
20
|
-
finalize_action # create Card::Change entry for db_content
|
21
|
-
|
22
|
-
card_id = new_card? ? upload_cache_card.id : id
|
23
|
-
@current_action.update_attributes! draft: true, card_id: card_id
|
24
|
-
success << {
|
25
|
-
target: (new_card? ? upload_cache_card : self),
|
26
|
-
type: type_name,
|
27
|
-
view: "preview_editor",
|
28
|
-
rev_id: current_action.id
|
29
|
-
}
|
30
|
-
abort :success
|
31
|
-
end
|
32
|
-
|
33
|
-
event :assign_attachment_on_create, :initialize,
|
34
|
-
after: :assign_action, on: :create,
|
35
|
-
when: proc { |c| c.save_preliminary_upload? } do
|
36
|
-
if (action = Card::Action.fetch(@action_id_of_cached_upload))
|
37
|
-
upload_cache_card.selected_action_id = action.id
|
38
|
-
upload_cache_card.select_file_revision
|
39
|
-
assign_attachment upload_cache_card.attachment.file, action.comment
|
40
|
-
end
|
41
|
-
end
|
42
|
-
|
43
|
-
event :assign_attachment_on_update, :initialize,
|
44
|
-
after: :assign_action, on: :update,
|
45
|
-
when: proc { |c| c.save_preliminary_upload? } do
|
46
|
-
if (action = Card::Action.fetch(@action_id_of_cached_upload))
|
47
|
-
uploaded_file =
|
48
|
-
with_selected_action_id(action.id) do
|
49
|
-
attachment.file
|
50
|
-
end
|
51
|
-
assign_attachment uploaded_file, action.comment
|
52
|
-
end
|
53
|
-
end
|
54
|
-
|
55
|
-
def assign_attachment file, original_filename
|
56
|
-
send "#{attachment_name}=", file
|
57
|
-
write_identifier
|
58
|
-
@current_action.update_attributes! comment: original_filename
|
59
|
-
end
|
60
|
-
|
61
|
-
# we need a card id for the path so we have to update db_content when we have
|
62
|
-
# an id
|
63
|
-
event :correct_identifier, :finalize, on: :create do
|
64
|
-
update_column(:db_content, attachment.db_content(mod: load_from_mod))
|
65
|
-
expire
|
66
|
-
end
|
67
|
-
|
68
|
-
def file_ready_to_save?
|
69
|
-
attachment.file.present? &&
|
70
|
-
!preliminary_upload? &&
|
71
|
-
!save_preliminary_upload? &&
|
72
|
-
attachment_changed?
|
73
|
-
end
|
74
|
-
|
75
|
-
event :save_original_filename, :prepare_to_store,
|
76
|
-
when: proc { |c| c.file_ready_to_save? } do
|
77
|
-
return unless @current_action
|
78
|
-
@current_action.update_attributes! comment: original_filename
|
79
|
-
end
|
80
|
-
|
81
|
-
event :delete_cached_upload_file_on_create, :integrate,
|
82
|
-
on: :create, when: proc { |c| c.save_preliminary_upload? } do
|
83
|
-
if (action = Card::Action.fetch(@action_id_of_cached_upload))
|
84
|
-
upload_cache_card.delete_files_for_action action
|
85
|
-
action.delete
|
86
|
-
end
|
87
|
-
clear_upload_cache_dir_for_new_cards
|
88
|
-
end
|
89
|
-
|
90
|
-
event :delete_cached_upload_file_on_update, :integrate,
|
91
|
-
on: :update, when: proc { |c| c.save_preliminary_upload? } do
|
92
|
-
if (action = Card::Action.fetch(@action_id_of_cached_upload))
|
93
|
-
delete_files_for_action action
|
94
|
-
action.delete
|
95
|
-
end
|
96
|
-
end
|
97
|
-
|
98
|
-
event :validate_file_exist, :validate, on: :create do
|
99
|
-
unless attachment.file.present? || empty_ok?
|
100
|
-
errors.add attachment_name, "is missing"
|
101
|
-
end
|
102
|
-
end
|
103
|
-
|
104
|
-
event :write_identifier, after: :save_original_filename do
|
105
|
-
self.content = attachment.db_content(mod: load_from_mod)
|
106
|
-
end
|
107
|
-
|
108
|
-
def item_names _args={} # needed for flexmail attachments. hacky.
|
109
|
-
[cardname]
|
110
|
-
end
|
111
|
-
|
112
|
-
def original_filename
|
113
|
-
attachment.original_filename
|
114
|
-
end
|
115
|
-
|
116
|
-
def unfilled?
|
117
|
-
!attachment.present? && !save_preliminary_upload? && !subcards.present?
|
118
|
-
end
|
119
|
-
|
120
|
-
def preliminary_upload?
|
121
|
-
Card::Env && Card::Env.params[:attachment_upload]
|
122
|
-
end
|
123
|
-
|
124
|
-
def save_preliminary_upload?
|
125
|
-
@action_id_of_cached_upload.present?
|
126
|
-
end
|
127
|
-
|
128
|
-
def attachment_changed?
|
129
|
-
send "#{attachment_name}_changed?"
|
130
|
-
end
|
131
|
-
|
132
|
-
def create_versions?
|
133
|
-
true
|
134
|
-
end
|
135
|
-
|
136
|
-
# used for uploads for new cards until the new card is created
|
137
|
-
def upload_cache_card
|
138
|
-
@upload_cache_card ||= Card["new_#{attachment_name}".to_sym]
|
139
|
-
end
|
140
|
-
|
141
|
-
# action id of the cached upload
|
142
|
-
attr_writer :action_id_of_cached_upload
|
143
|
-
|
144
|
-
attr_reader :action_id_of_cached_upload
|
145
|
-
|
146
|
-
attr_writer :empty_ok
|
147
|
-
|
148
|
-
def empty_ok?
|
149
|
-
@empty_ok
|
150
|
-
end
|
151
|
-
|
152
|
-
def load_from_mod= value
|
153
|
-
@mod = value
|
154
|
-
write_identifier
|
155
|
-
@store_in_mod = true if value
|
156
|
-
end
|
157
|
-
|
158
|
-
def load_from_mod
|
159
|
-
@mod
|
160
|
-
end
|
161
|
-
|
162
|
-
def store_dir
|
163
|
-
if @store_in_mod
|
164
|
-
mod_dir
|
165
|
-
else
|
166
|
-
upload_dir
|
167
|
-
end
|
168
|
-
end
|
169
|
-
|
170
|
-
def retrieve_dir
|
171
|
-
if mod_file?
|
172
|
-
mod_dir
|
173
|
-
else
|
174
|
-
upload_dir
|
175
|
-
end
|
176
|
-
end
|
177
|
-
|
178
|
-
# place for files of regular file cards
|
179
|
-
def upload_dir
|
180
|
-
if id
|
181
|
-
"#{Card.paths['files'].existent.first}/#{id}"
|
182
|
-
else
|
183
|
-
tmp_upload_dir
|
184
|
-
end
|
185
|
-
end
|
186
|
-
|
187
|
-
# place for files if card doesn't have an id yet
|
188
|
-
def tmp_upload_dir _action_id=nil
|
189
|
-
"#{Card.paths['files'].existent.first}/#{upload_cache_card.id}"
|
190
|
-
end
|
191
|
-
|
192
|
-
# place for files of mod file cards
|
193
|
-
def mod_dir
|
194
|
-
mod = @mod || mod_file?
|
195
|
-
Card.paths["mod"].to_a.each do |mod_path|
|
196
|
-
dir = File.join(mod_path, mod, "file", codename)
|
197
|
-
return dir if Dir.exist? dir
|
198
|
-
end
|
199
|
-
end
|
200
|
-
|
201
|
-
def mod_file?
|
202
|
-
return @mod if @store_in_mod
|
203
|
-
# when db_content was changed assume that it's no longer a mod file
|
204
|
-
return if db_content_changed? || !content.present?
|
205
|
-
case content
|
206
|
-
when %r{^:[^/]+/([^.]+)} then Regexp.last_match(1) # current mod_file format
|
207
|
-
when /^\~/ then false # current id file format
|
208
|
-
else
|
209
|
-
if (lines = content.split("\n")) && (lines.size == 4)
|
210
|
-
# old format, still used in card_changes.
|
211
|
-
lines.last
|
212
|
-
end
|
213
|
-
end
|
214
|
-
end
|
215
|
-
|
216
|
-
def assign_set_specific_attributes
|
217
|
-
# reset content if we really have something to upload
|
218
|
-
if @set_specific.present? && @set_specific[attachment_name.to_s].present?
|
219
|
-
self.content = nil
|
220
|
-
end
|
221
|
-
super
|
222
|
-
end
|
223
|
-
|
224
|
-
def clear_upload_cache_dir_for_new_cards
|
225
|
-
Dir.entries(tmp_upload_dir).each do |filename|
|
226
|
-
if filename =~ /^\d+/
|
227
|
-
path = File.join(tmp_upload_dir, filename)
|
228
|
-
FileUtils.rm path if Card.older_than_five_days? File.ctime(path)
|
229
|
-
end
|
230
|
-
end
|
231
|
-
end
|
232
|
-
|
233
|
-
def delete_files_for_action action
|
234
|
-
with_selected_action_id(action.id) do
|
235
|
-
FileUtils.rm attachment.file.path
|
236
|
-
attachment.versions.each_value do |version|
|
237
|
-
FileUtils.rm version.path
|
238
|
-
end
|
239
|
-
end
|
240
|
-
end
|
241
|
-
|
242
|
-
# create filesystem links to files from prior action
|
243
|
-
def symlink_to prior_action_id
|
244
|
-
return unless prior_action_id != last_action_id
|
245
|
-
save_action_id = selected_action_id
|
246
|
-
links = {}
|
247
|
-
|
248
|
-
self.selected_action_id = prior_action_id
|
249
|
-
attachment.versions.each do |name, version|
|
250
|
-
links[name] = version.store_path
|
251
|
-
end
|
252
|
-
original = attachment.store_path
|
253
|
-
|
254
|
-
self.selected_action_id = last_action_id
|
255
|
-
attachment.versions.each do |name, version|
|
256
|
-
::File.symlink links[name], version.store_path
|
257
|
-
end
|
258
|
-
::File.symlink original, attachment.store_path
|
259
|
-
|
260
|
-
self.selected_action_id = save_action_id
|
261
|
-
end
|
262
|
-
|
263
|
-
def attachment_format ext
|
264
|
-
if ext.present? && attachment && (original_ext = attachment.extension)
|
265
|
-
if ["file", original_ext].member? ext
|
266
|
-
original_ext
|
267
|
-
elsif (exts = MIME::Types[attachment.content_type])
|
268
|
-
if exts.find { |mt| mt.extensions.member? ext }
|
269
|
-
ext
|
270
|
-
else
|
271
|
-
exts[0].extensions[0]
|
272
|
-
end
|
273
|
-
end
|
274
|
-
end
|
275
|
-
rescue => e
|
276
|
-
Rails.logger.info "attachment_format issue: #{e.message}"
|
277
|
-
nil
|
278
|
-
end
|
279
|
-
|
280
|
-
|
281
|
-
# ~~ below autogenerated; above pulled from /Users/ethan/dev/wagn/gem/card/mod/carrierwave/set/abstract/attachment.rb ~~
|
282
|
-
end;end;end;end;
|