revelry_content 0.0.1.2 → 1.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +21 -84
- data/Rakefile +1 -1
- data/app/assets/javascripts/revelry_content.js.coffee +3 -15
- data/app/assets/javascripts/revelry_content/components/Admin.js.cjsx +82 -78
- data/app/assets/javascripts/revelry_content/components/EditModeButton.js.cjsx +14 -15
- data/app/assets/javascripts/revelry_content/components/Loader.js.cjsx +9 -10
- data/app/assets/javascripts/revelry_content/components/Time.js.cjsx +13 -14
- data/app/assets/javascripts/revelry_content/components/TopBar.js.cjsx +15 -16
- data/app/assets/javascripts/revelry_content/components/editor.js.coffee +319 -287
- data/app/assets/javascripts/revelry_content/components/versions.js.coffee +154 -155
- data/app/assets/javascripts/revelry_content/config.js.coffee.erb +2 -2
- data/app/assets/javascripts/revelry_content/mixins/EditModeListener.coffee +3 -3
- data/app/assets/javascripts/revelry_content/models/Content.js.coffee +4 -4
- data/app/assets/javascripts/revelry_content/models/Version.js.coffee +5 -5
- data/app/assets/javascripts/revelry_content/setup.js +1 -0
- data/app/assets/stylesheets/revelry_content/components/buttons.scss +1 -1
- data/app/assets/stylesheets/revelry_content/components/loader.scss +1 -1
- data/app/controllers/{revelry_content → revelry/content}/application_controller.rb +1 -1
- data/app/controllers/{revelry_content → revelry/content}/contents_controller.rb +17 -12
- data/app/controllers/revelry/content/pages_controller.rb +30 -0
- data/app/controllers/{revelry_content → revelry/content}/versions_controller.rb +14 -6
- data/app/models/{revelry_content → revelry/content}/content.rb +25 -9
- data/app/models/{revelry_content → revelry/content}/content_version.rb +1 -1
- data/app/models/revelry/content/page.rb +6 -0
- data/app/views/layouts/revelry_content/application.html.erb +2 -2
- data/app/views/revelry_content/contents/_menus.html.erb +2 -2
- data/app/views/revelry_content/contents/index.html.erb +1 -1
- data/config/routes.rb +1 -1
- data/lib/generators/revelry/content/css_generator.rb +51 -0
- data/lib/generators/revelry/content/initializer_generator.rb +13 -0
- data/lib/generators/revelry/content/install_generator.rb +40 -0
- data/lib/generators/revelry/content/js_generator.rb +45 -0
- data/lib/generators/revelry/content/migrations_generator.rb +28 -0
- data/lib/generators/{revelry_content → revelry/content}/templates/create_revelry_content_contents.rb +0 -0
- data/lib/generators/revelry/content/templates/create_revelry_content_pages.rb +17 -0
- data/lib/generators/{revelry_content → revelry/content}/templates/create_versions.rb +0 -0
- data/lib/generators/revelry/content/templates/initializer.rb +13 -0
- data/lib/revelry/content/admin_concern.rb +13 -0
- data/lib/{revelry_content → revelry/content}/configuration.rb +2 -2
- data/lib/revelry/content/content_concern.rb +18 -0
- data/{app/helpers/revelry_content → lib/revelry/content}/contents_helper.rb +5 -5
- data/lib/{revelry_content → revelry/content}/engine.rb +5 -3
- data/lib/{revelry_content → revelry/content}/js_exporter.rb +4 -4
- data/lib/{revelry_content → revelry/content}/railtie.rb +2 -2
- data/lib/revelry/content/version.rb +5 -0
- data/lib/revelry_content.rb +25 -18
- data/lib/tasks/revelry_content_tasks.rake +1 -1
- data/test/controllers/revelry_content/contents_controller_test.rb +1 -1
- data/test/controllers/revelry_content/revelry_content/pages_controller_test.rb +9 -0
- data/test/dummy/app/controllers/home_controller.rb +1 -1
- data/test/dummy/config/initializers/content.rb +1 -1
- data/test/dummy/config/initializers/revelry_content.rb +1 -1
- data/test/dummy/config/routes.rb +1 -1
- data/test/dummy/db/development.sqlite3 +0 -0
- data/test/dummy/log/development.log +0 -2990
- data/test/dummy/log/test.log +0 -0
- data/test/fixtures/revelry_content/pages.yml +11 -0
- data/test/helpers/rev_content/contents_helper_test.rb +1 -1
- data/test/models/rev_content/content_test.rb +1 -1
- data/test/models/revelry_content/page_test.rb +9 -0
- data/test/revelry_content_test.rb +1 -1
- metadata +50 -438
- data/app/assets/javascripts/revelry_content/server_side.js.coffee +0 -10
- data/app/assets/javascripts/revelry_content/utilities.js +0 -69
- data/app/assets/javascripts/vendor/react_ujs.js +0 -64
- data/app/helpers/revelry_content/application_helper.rb +0 -4
- data/lib/generators/revelry_content/css_generator.rb +0 -47
- data/lib/generators/revelry_content/initializer_generator.rb +0 -11
- data/lib/generators/revelry_content/install_generator.rb +0 -38
- data/lib/generators/revelry_content/js_generator.rb +0 -43
- data/lib/generators/revelry_content/migrations_generator.rb +0 -25
- data/lib/generators/revelry_content/templates/initializer.rb +0 -13
- data/lib/revelry_content/controller_concern.rb +0 -11
- data/lib/revelry_content/model_concern.rb +0 -11
- data/lib/revelry_content/version.rb +0 -3
- data/test/dummy/public/uploads/revelry_content/content/src/3/Screen_Shot_2015-05-04_at_9.50.48_AM.png +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/-I_fh6Ob3TV3ynXTvv2TsuKA8cQq62L1tKIrIuNXWjA.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/-YnOULGJdPpgh539S1Ms1ELd5--WkKXQZL4yYylOy-0.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/01i3BQNbZnC6BxmgguLy4xMYU2RnsNjDy_lEOEdzhxY.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/0CsApXQBjT34U567rgWiQGYOFwIpgM1ZcV3ZvrXPAXg.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/0LnMwfkPx0KckDudP0t_qfcIfrUx2JEt9_W28i5ota8.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/0Soh65Z50qGQ79OzRV5ywJzksbLPZ9Y7Xukmqyr6k5E.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/0XbuhYD4hx4ktBwomnPqrp-8ofGrK18w0XFrKr9A0TQ.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/1aGcEQlzCZqj47bR8b18bidGhSM2TCoUF8PH47DmsLU.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/1k4qrvfTSqyZpqJotrEJvryNYKwAYhcPYDr762tOceA.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/1qAjZK81hSd2VjC4whKNDW4X7SdJpLItpFtUW5R2vUU.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/1tgQBRMWbVAGLWkDo0fO1_ePFLz60fDuTdCKwp-LIJU.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/22e58P_cEp6-Pu5wgZqEMEpiJGooGJ2dI6gfNXacBaw.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/2ZbqEyDxBgh2_LtnR16sYKThwIziSqlASeCjQjkwL7Q.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/2t8ZjvFIs5Qg2owTTr20k8NqE0dCrbY5mHTjJGQd2To.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/4cBcXkgJSg0A9kNtcagSpP-C7RpYMO7GIYMiIdC0K48.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/4eWrs3PFkK1uDMlHgGflFhNtKLF63kY4nMqArSbZBpY.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/5-_j0ZY9kq3RzZvSq8dpYirIlmqsRJUSBNkE97ZcqWY.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/55ea_CKRYg4qGN5pyZy2H1oKxEnbQuJzgGyrVQ1ZE-k.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/5PZzqc1OeigG9XRqgCM3SCT9fLVn6wTm6awQx74XAD0.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/5WUZd0B2PMhhtp-V7XsX5zFLOPXl9z2WpIVdT8rW5AE.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/5cWdZIkyqWp1hyfiXzGiMnuqZ_4SlHG0DmWpUkQYuS8.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/5wFIFg4lQ-rd1ZWBhlRi9J56-EqjP61WWYq0jOA7bek.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/6COX4oqZCCZnmoes6ehqGZqIr2xtXv5HVYqJzRnccnU.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/6Ck5oeyDTZNctS2vkmtYRv6UU5SCv8DW_cqAumQHEW4.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/6W7Zp0ylWiCA_3Z-Hese0EPiWLITfAv2OViiC3GHvzU.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/6ajykKpm3QojPPBBJIx6vRImRgKpc_V_zX68dF-yV1Q.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/75Qu5KXpoOg--ZIa5yMWG0sQS_OoZiF0og8GEfCKodI.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/78FVepsCcIAm-tqmhFYO4eaDkF1BHiAwzZjoc1W6XrI.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/7OzH_p-6ZYmSIl-UNVwWQfD6PJHalPe5Y01jCP_MF1w.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/856F5ONTmAq3bpS5lqrZAzppRy4gwhAkugo9inM3EEU.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/8AVC27x21kixmECkHeOm4sR-mSbzhJO320NRwrW6B38.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/8KCGLeeBgsHpq-GGsxAKvONGThHONpkBhLmQv5x-5i8.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/8cyMCW5yogfK5gPFpci4rPtVb8pVIiZmF5DpOH8F07Y.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/9EThCCo9tuqXzBz-afDke-GvEyM_NG0dxw7dSdkzINw.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/9NoeClumq19p-VmRk5PPOHLvDXN_Jr6BCYnczJWWfv4.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/9YD7CWCBCkOdAYp-yB8nGhaNDiiUWsP7fzRWPmHbzKI.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/AY9mbclr0zMOzxzP4BYRTYyvBOlpLFHHQAimzs6dSDI.cache +0 -38
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/AqkMYZH-ERTqi-15YvdhRVtysLKqim5CV7-GILZNras.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Au8GVVKkzmp8TySAWMgFJQObozIt4Mr-RW5BolO8J2k.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/BBPtOTznDSAhX5tIqbw_JRw9Cppz2SVtSFsJ1CpC37k.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/CC0dQuHqBjWqdKsRp2Ntw6nn3M1nC5lUY-dd8lMzJ6Y.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/CWYN7KxLVsU-N9FbSIrHgO979x5b6AeyckCfZ892Y7k.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/C_Sjupfz09XcSquDwczKxSTxWrEUrjaf49VmA5x68CQ.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/CcJCtip5hherUpH0eiHdJI5Stl08Txl1AU8NxDLKtro.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Clf7dMHxXwzeU3tZ2yxP8d3xr0HRWHFMdqjBuSceJZ0.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Cnkk4N8ysSWHH6ujQDBGzEiLuGa0dVNDL5Zq53tJq-M.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/D0USxWIEUAxLvX9bhYdtB_SXMXAJ9nQr9vewnyqrk5k.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Dy0AC2wVM0afv2MB-u7UGGLsb_2ExNZ8S6w7SGE-djg.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Ee1BFKugxHkzKUuAsIqQc60hV47E4VSUMZwBOThvSeY.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/EghXS1aAsnoopkxb4Fv0S21wqJGL59ryH5HV9-30KI8.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Eq8I8ukRZZ9BZ2SQxzSNc8mOoyKksxtzwtDh2FRZ1FE.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Eu26_D_tZu1dr7mVRA4F2--NUZ2UMM4QRXv9JcqO2TY.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/FEfkZdxv5MUSvLMUUWoC3lif13VZBbiaUYPNv8uizgM.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/FF9LKRGOPVZl03UeeMXbHRXBFwG4SkAdOfcDClwXXx8.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/F_NOlk6iL-Gonygn5tsU_AaDA69HBxeExwCiAa6Ezi4.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/FuMG_mCkNUt0OV_qrahX3ne-LN8Y3J-17T-I5BwYT_U.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/FzIl4k5FDcnN8SbzckzMXWXsj2DwBv_tGvZZky8_cvk.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/GBe9GA2qATaLqF7GTbxcZ8sWcPJ2zWeT8PFE8Cynb4U.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/GUcaNDg0KOqTIS7ltde6vWEZy4eTkdPuecVr52xaqY4.cache +0 -4
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/GWveyzQul11IW7JP-MFTH1p2O-FAiSldGQCixPtBWZc.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/H8Py9_cLtmjiNd1zVjVpr-60bPm8OKt1NzBdYpuRoSg.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/HIOnKEwfKW9leZhYm8hw2zTPcTC7Lhr9QO3pGkpVUC0.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/IUOCPt0S05lp6-q_7CuqTJjuySoP7ZTTe1srP_Sgdag.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/IlxQ_nfFkpBhgHXJ9EL7TgHKTrQYX_1ockXtSOHH_1Q.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Intu4bn50Zl1tGpuw8N2VhNjvLeG367yEoPjIxYkYxA.cache +0 -49
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/J3EzfF5t_RDdiaU-svpP2DBjb8gnlHHHCQjjpPvzvpk.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/J5rhZ_6c58sjOvHqDBBBBTvsLDbUGfHatkjiF1M-Fys.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/JP9pt25R98BIDqvwjp_DgmdNj4U1wLrVUhOnoDtekS8.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/K2yr6YhOBxRdaqrHViPlAYUKVTWMlI24INQctCW0rWQ.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/LT9baTsZAaEEgS5raUZGGsP2vTnlzW9LzvyCfQgqLLs.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/LW03HTHDvMz6l4ReQ29sJeZqRg3QLrcVdAutCg9ROyU.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/LcZdIStJUZnaKHh7vs-yLld_jzO3MSU4gCJaORFrjYk.cache +0 -7
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/LruVN3C21yeFX4pfE6ZQw7z2CzkYXY5b8PXOTfz2o1E.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/M2tXWSvBjMhGoQLT8CaoVYULKWDVirToNVLYqstyW-g.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/MJxRV2KlWMJ5KrraeWvC4yp7N4-aMpktlzqBpoLhft8.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/NGgP2dkovkWF23p4ypqAUEO3kldLkAA7E9hERHoxJ_M.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/NX-xwAHuCC7QChZD4MSpX9fgCXgl532SBhXfSsIxG4k.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/OQdV6HhyTI5Otzo9cwR6IY-8eX0eip8x561B8hXKikY.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/OSmr2Sj9749HFHCMkGsJP2YGkQxIztofCliXs0urGE8.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/P73ImcSy1BYWt27ZGM-JKdkbzyIm2063NZr-dn-ygPE.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/PVxgcRUvLL0uRj6ScbeM7YyccWyjP2O2kvs2640MHck.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/PmcUgH3Y4bLndb9k4NAJlxdFPTXl3T8-jEskNYv7T9M.cache +0 -15
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/PmrPSezdyM_8N-tzxdbn62XyY_l-YJPz7Tm7Qi1z2_M.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/QAr8mslUFMN0vPkEEQAZEbAUGes7lnpEtfFtKSK8lCc.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/QFioo2rOp-ljy1-PIoxzqOTmxmc6HFAft-qNbbQvfkQ.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/QPGkAA8L-cs-AO80ws0mqld73EIG2HCd8hzkga35Ydc.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/QaJhvzKs8vkSfWT534wn8jNcxfcnMDp4i8cDbwWESbs.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/RICRLw8IGgYZrEFYgyA-MY8-o_kXcmcY1gCavTvwW64.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/RgyohxMtV3OKNhuwrAaDjfXMV7SsjprKrEVgZ6NhwzE.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/RsbxexS-d0Msc_BIthGWINzE8v7aFHiWQVqTbifUHp4.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/SZlNp_5FFT99-2Qs5TFLbTZ4ZOG2UFO6sExA-aa-9Xc.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/T5Z3oNqbaal-reBCFzxyo8yxV-drGVwQjIC1O_pkHNI.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/T6Ft0zMwwCntps471lA0_0aXo1KaOp-ZFeptSt9SRks.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/TQ7i9C1sBaWIfDFYnQo4TqjBOMYbOVxm6f4Qhl0Uf6M.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/TR10mW2AT2rabnCmUhSF2tBx-ZpQJZfpoezdescBWxg.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/TSR9oCO5WIJZHL855zPdgj-pvzkWlz0vlnIPSMRudy4.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/V9W2dbEVRrR0tD27e8bft0flt50g1HHugzTd7lFVoMY.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/VHnCzqYhXqo4PNpfO5rhh1rxxllOWMQWrJ_1an8CxJ8.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Vs4mCFlsskLe0HvAg_ODhYRP8lNofUxZ45d6sOzUfC0.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/VsHDpo2bcpN87OPpULfpEIuC7ArNRDa4RgDTqYSgbbc.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/W1XNy0_UmGwk7xmb-0QiIdkD_gx_tjV351xE8X5LCPY.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/WEPPUYRJVm2CgPjW9cTdBuuFhadPuO7qPEqvqecfKjg.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/WIwRcAEBsLT7LSFw8071ukLJbJlwFoX_JaHD9w7fEAc.cache +0 -16
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/WSR5PdIRaA9ix0LLhrUegJL8ztgPoIgZHdaq1d3Jm7k.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/WxVFbgL4Oty9vrd1AD37P2KqOGjwvcH5o_LSGrMI_do.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/XSXbBZ-YPcBvmUp0fzcIUcTwqNvYHvUU7xfLa38qYvg.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/YB9oCB5SEQMC6OwASUsvmD1GE90Ul31VfE2ZRo1Hd2k.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/Yf6ZOsV9gRVVFTsRNcQPGxKgCQ63L3JprFkpZMD0slI.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/YjXlZUeBr9ONZpMKis8Beab3ld-NdnlSKXm2oZOsysc.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/ZBbRPnK9QPeL_bLmZNttUrL0MMH6DtrYDpD4f1DbYtc.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/_7w_iwIfp6xsakWz0Ww-HrRNserrl5q6WzSq1iYZGaQ.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/_k6iDcm-RS6SK8ChV7hlp56ZM2bVtgzaDCrpSHIDFZ4.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/_tne4TjP6WhsfK-a0TBVts5lr-lr-sDxyQiKIugRPhM.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/_zOYmE_ymvMvcRhHFdH2JutNJimhiytkMAhh4Oq6mkk.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/aDjgtkQ97t1Rcjxv5nZUTSSYXea5orrfkCeCNrlNNao.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/aKAjc-eEaECxCE89czdDC52Kqkw11EBSF9vk7QorxPA.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/auLKIVQfT6ZcV9nSxkDD4xMrcIRtB_1-hO1qKXOcwxo.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/axJrczuMPd6m4cWaLl9wfSWgg5SWjyHvv1N0d8e7cas.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/cWuWB7O6uRomqwh3IemLWVclp4_ioPR7TBAF7yrPpV0.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/ciEBvpxWzLqer60DBJkr319p1iKyYHZxfCm3tIPMqcI.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/ct5UmPAxknsInqDq17r9u_NbuFw8F6w4ZLKNU05xZ_Q.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/cxW0sGi1l_Lc7eCBF8kxQo4kNtHw27K5H-Ngpiixm2A.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/d7lXJjCfvSvwTWSI3x4kn3TQzzYG0DGvqTOJL3avl6Y.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/dW3LJvt2E0gKdWoqZTSTWtntGqxhTENv8_-mbT_kfn0.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/dfT6vHCtyIBci9lpNUVgyqepSYt55BCo8MDzrPXxUEw.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/e7OkNhH6RmnQjEY0ZEO597J545crZH0qZdVDYz71KT4.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/ea-3NiBlut0EOdCVqVGn-RwNm0CiwA8YVBRqfRqhgLg.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/eqpR2RCSOj4T0wmrPGJDb_td3gtOdiyLwD02BpzuBkg.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/eqrwo9jjG9uZiNQCUMkdkvT40JGz2uvrufAv-l00X1k.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/fG1WmTPapxY9EMQ5D8HQw8E2MpudT32v--jD6VgazTU.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/fLosOyYOiUc-ZJIEAtgmz68UfDVlAVCVMAxtAlML-nQ.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/faEE1R7Sb00wgGFfL9FC9IqAGSkEHNY7rLPURjZVFv0.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/fgmBwPUcbsTKyMd7bxMbzh9YFF7GkD269KSZbCOpe54.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/g4m06tmSxrOnDxGpUyYkIEY8hi0ymUoUzYMAh06YkGc.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/gP9Pm0rpnz4IvvhguI8VxK8xhDKU8WisGwfm5ox97RY.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/gtka4cvnxw2bm_SnkE-5LxtRYKxD-MvM_T7lYxdLAug.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/hQFzaNvvDOyvg2U4FZcg-xUjctMTLEdb7tK-RYIziz8.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/hcS2HARtyE_tpJmmwUqYO-9e-Tshg3TF6W6XL29_cwM.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/hdMwJqicGzH0qHgBqMVfxHB8u3-zdirRgb1zpnRfb6w.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/hfIPOqDhaIk7vhQa4hLyWEIQasPwJSn3H-i2egLuFvQ.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/i3Mr4BCaCS865aFe9brU973ERtfoSONrUQhX5FW509w.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/jBOiy_uvOKOoBovFao2qEf6xVkGYRFmw-CR_I756N5g.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/jZZQUkAYSpxGGWp7Vb_vs2S3Clde8_XKFWwjwHaBmU0.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/jiUvf7zJxbsJ9a9IiZOy06PqL6dOOfprzyXci5p8vMM.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/kd10Jyu0ZXLelGbmQo03cFEKpR0qQRw-QyPPMlnY-FQ.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/ksZL57FCLWVpXdOSIHVytq_XIsGz78TdArP4aWt7uQA.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/l4Mb7Zqpi9HWWa67ftgd_ZkPTvGuhxm--tpHlgu4Eyc.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/m3gQ2mqyaWT0r9UVJriOzT0qkFiL4aZ5mhMgbbyLmyw.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/n6NcZJQK0j-WDDTq_7wksLUZBBYhGRPaW38Cua19t4E.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/nKs1V_XYWUW2uG9E7WQPaiVIvYx2I5ttwdMZ9bRsUVY.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/oB34rjWhV_SBgt62MMSw20hEYuiVTjLMILeSBjagbDo.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/oydOGeF22N2dttfBS68MA5PK4ofniHzd-LgBwVmJvI4.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/pA1evykc28UE2mszGRw015uHbbmBCU9gFZIcU8Hrwls.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/pBYZnqSsUmggXeAPQXcQrZSfrScDOEsZQdeXOIqfHaA.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/pENTpYJeZrQ-P80SXbbHVaXcEd7kaOm1bZRItPVK7OE.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/pYKIN2HEVMsGLDogjm8iDQ_4W8iGEq98NsJbOdA822o.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/pb5zODtFDJpqFTtbh09cOhwG1mZowQW1EZ-54eauNTc.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/pnDWkMT2Wf6v8kCepJzn9oEGWrxNOY-H9MlCq85zTlU.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/qJ6pwEWoy3oUs_aPayRv5D5d_F7oEyNIzxrJCaEpcpM.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/rJ88KtO5aBXvyE9sef5emc-MsAJaTna76vG5TNayYa4.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/rPyv5XauOpu-aOgB95w5ZSl6jCFUGvS8YE1h1eZZID0.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/rcp1tSuAgctt1BdAdUoGgD_UtZeD7w3rLuANXg8YU58.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/rfYNZtDWV3PCq5a57xTyj0-_iC1Psq1TaxWG86fXR2A.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/smmkAgu4NNfatz7vllczgMFH_tckzDUAmeV3WvmmsRE.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/szDR2M9t_osfhsE_agd1lcIjKrl5nwRmORMlyoWxTus.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/t4fruk986h623vtFPEW2sALWc3kl3ayPfBbgOzRm6Cs.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/tJDIhl16K_HokIK8UZx1y9hy-Ne6lk9ie2kMbsHVxdY.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/tSDhvZZY2gcpUHWppbAMQYQL0iNPOc3Vo2HHrnqKlDw.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/tYYAXLHGMIYQ1Ls-jw8thSBIzdixEpeQC2kg6irmEy0.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/tgFK--mLRPBU9bZUb6lc4kt6Qq9-Ux6AAfG7mDQBpu8.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/tpBLVkgP9PSqHqSHfPf9ZLar0vHGOTCOUl0FKOqGN54.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/u0B5U9yc20iANkRJi6-SiyL9U5RMrThVGmgnWSR2Rew.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/vtTvV-oGMOMD-l4YDTQRNHPiFRebBjqEfL9IoavTSGE.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/w3rjuVGSs9xUdab61H5KOFtoRsLH5abeNs9uloC2b94.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/w9RM9nORoFIx66Xb5PwygnSIR3922sjAkZkXvyeykgE.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/wK-n2sVphfsiv5g-IV404qJkdw6Skfo5wk55Yf8IHfs.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/wbSRRkjts6z6OP0o88ZwLIz6Za9iMMeF8F1FMAubBxc.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/xE9HS1AxUe2VZv8zzVYALc75Yhv53_LPpQNxurm0oSI.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/xX3QhVOxSxG9HjrdSvjeQoK1iBpYJX3Kw-yjea2vSuo.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/xa4ZU0nFS4WqDtDriIXMlwNURqkpUm_djZVqiz0ZynA.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/xzsnr6Bgr0MP4j4FZVUcYBADfkQCUHoShH_9hGp0ckk.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/y6xgU0dR6b-1_hjgAZAhFFq1T9zGZ8yjUQzOefGpcu8.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/yJ9qoQ6ZeEPmm4ttulT9hdYPemgTF4VUSdmFjmr9Vpw.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/yJuZz8Lopwyvmy-rto8ycJ0nOLWeWSobCY8z-421Bec.cache +0 -0
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/yLZAaEFOlOcJfmo3pRpRpTiQMzBcqSRTrZYb_pJpTBs.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/yV9yGvP4CDMeEbb4ff4n_Hzu-GuBbM-S39cIE1WQy6Y.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/y_4IIBYH_ItxQoEeXjWm9Igwn6hAkl669CNtYfo0fyI.cache +0 -1
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/zF_lfa7oUNjRgtepm9Ufi0DCzN_IXCJTDHRrH-JHu7Q.cache +0 -2
- data/test/dummy/tmp/cache/assets/development/sprockets/v3.0/zeqXKQA7lKQnvEaJsDO404ZaYCV0dk57z-SXUkfmz24.cache +0 -1
- data/test/dummy/vendor/assets/javascripts/revelry_content/content.js +0 -4
@@ -0,0 +1,30 @@
|
|
1
|
+
require_dependency "revelry_content/application_controller"
|
2
|
+
|
3
|
+
module Revelry::Content
|
4
|
+
class PagesController < ApplicationController
|
5
|
+
include ::Revelry::Content::WithRevelryContent
|
6
|
+
|
7
|
+
layout ->(_) { 'application' }
|
8
|
+
|
9
|
+
def show
|
10
|
+
render template: template_path
|
11
|
+
end
|
12
|
+
|
13
|
+
def template_path
|
14
|
+
"templates/#{current_page.template}"
|
15
|
+
end
|
16
|
+
|
17
|
+
def current_page
|
18
|
+
@_current_page ||= find_page
|
19
|
+
end
|
20
|
+
|
21
|
+
def find_page
|
22
|
+
::Revelry::Content::Page.find_by(slug: params[:id]) || raise(ActionController::RoutingError.new('Not Found'))
|
23
|
+
end
|
24
|
+
|
25
|
+
def content_scope
|
26
|
+
::Revelry::Content::Content.excluding_prefix('pages') +
|
27
|
+
::Revelry::Content::Content.prefix("pages.#{params[:id]}")
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -1,6 +1,8 @@
|
|
1
|
-
class
|
1
|
+
class Revelry::Content::VersionsController < ApplicationController
|
2
2
|
respond_to :json, :html
|
3
|
-
include
|
3
|
+
include Revelry::Content::ControllerAuthorization
|
4
|
+
|
5
|
+
before_action :check_authorization
|
4
6
|
|
5
7
|
def info_for_paper_trail
|
6
8
|
{ rollback_version_id: params[:id] }
|
@@ -9,14 +11,14 @@ class RevelryContent::VersionsController < ApplicationController
|
|
9
11
|
def index
|
10
12
|
# Versions does not include the version, so grab versions, convert the
|
11
13
|
# currents to mock versions, then combine and sort
|
12
|
-
@versions =
|
13
|
-
@content =
|
14
|
+
@versions = Revelry::Content::ContentVersion.all
|
15
|
+
@content = Revelry::Content::Content.all.map { |content| Revelry::Content::PseudoContentVersion.new model: content }
|
14
16
|
@all_versions = (@content + @versions).sort { |a, b| b.created_at - a.created_at }
|
15
|
-
respond_with @all_versions
|
17
|
+
respond_with data: @all_versions
|
16
18
|
end
|
17
19
|
|
18
20
|
def revert_all_to
|
19
|
-
newer_versions =
|
21
|
+
newer_versions = Revelry::Content::ContentVersion.where('id >= ?', params[:id]).order('id desc')
|
20
22
|
newer_versions.each do |version|
|
21
23
|
if ['create', 'import create'].include? version.event
|
22
24
|
unless version.id == params[:id].to_i
|
@@ -33,4 +35,10 @@ class RevelryContent::VersionsController < ApplicationController
|
|
33
35
|
|
34
36
|
redirect_to :back
|
35
37
|
end
|
38
|
+
|
39
|
+
private
|
40
|
+
|
41
|
+
def check_authorization
|
42
|
+
throw "Unauthorized" unless Revelry::Content.config.authorize(self)
|
43
|
+
end
|
36
44
|
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
class
|
1
|
+
class Revelry::Content::PseudoContentVersion
|
2
2
|
include ActiveModel::Model
|
3
3
|
attr_accessor :id, :model, :rollback_version_id
|
4
4
|
|
@@ -33,17 +33,20 @@ class RevelryContent::PseudoContentVersion
|
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
|
-
class
|
36
|
+
class Revelry::Content::Content < ActiveRecord::Base
|
37
37
|
include ERB::Util
|
38
|
-
has_paper_trail class_name: '
|
38
|
+
has_paper_trail class_name: 'Revelry::Content::ContentVersion'
|
39
39
|
mount_uploader :src, SrcUploader
|
40
40
|
|
41
|
-
has_many :versions, class_name: '
|
41
|
+
has_many :versions, class_name: 'Revelry::Content::ContentVersion', :as => :item
|
42
42
|
validates :key, presence: true, uniqueness: true
|
43
43
|
|
44
|
+
scope :prefix, ->(prefix) { where("key LIKE '#{prefix}%'") }
|
45
|
+
scope :excluding_prefix, ->(prefix) { where.not("key LIKE '#{prefix}%'") }
|
46
|
+
|
44
47
|
def html_content
|
45
48
|
return if content.nil?
|
46
|
-
|
49
|
+
Revelry::Content.config.sanitizer.call(markdown_engine.render(content))
|
47
50
|
end
|
48
51
|
|
49
52
|
def as_json(opts = {})
|
@@ -140,7 +143,7 @@ class RevelryContent::Content < ActiveRecord::Base
|
|
140
143
|
end
|
141
144
|
|
142
145
|
def self.from_import_hash(content_object)
|
143
|
-
content_model =
|
146
|
+
content_model = Revelry::Content::Content.find_or_initialize_by(key: content_object['key'])
|
144
147
|
# Mark as an import event for papertrail to distinguish from a normal create/update
|
145
148
|
if content_model.new_record?
|
146
149
|
content_model.paper_trail_event = 'import create'
|
@@ -154,14 +157,27 @@ class RevelryContent::Content < ActiveRecord::Base
|
|
154
157
|
end
|
155
158
|
|
156
159
|
def markdown_engine
|
157
|
-
@markdown ||= Redcarpet::Markdown.new(
|
160
|
+
@markdown ||= Redcarpet::Markdown.new(Revelry::Content.config.markdown_renderer, underline: true)
|
158
161
|
end
|
159
162
|
|
160
|
-
def self.as_lookup_table
|
161
|
-
|
163
|
+
def self.as_lookup_table(content_scope = nil)
|
164
|
+
content_scope = all unless content_scope.present?
|
165
|
+
Hash[content_scope.map { |c| [c.key, c.as_json] }]
|
162
166
|
end
|
163
167
|
|
164
168
|
def self.as_serialized_table
|
165
169
|
Hash[all.map { |c| [c.key, c.as_serialized_json] }]
|
166
170
|
end
|
171
|
+
|
172
|
+
if self.respond_to?(:rails_admin)
|
173
|
+
rails_admin do
|
174
|
+
object_label_method { :key }
|
175
|
+
|
176
|
+
include_fields :key, :content, :src
|
177
|
+
|
178
|
+
field :src do
|
179
|
+
label 'Image'
|
180
|
+
end
|
181
|
+
end
|
182
|
+
end
|
167
183
|
end
|
@@ -4,7 +4,7 @@ PaperTrail::Version.module_eval do
|
|
4
4
|
end
|
5
5
|
end
|
6
6
|
|
7
|
-
class
|
7
|
+
class Revelry::Content::ContentVersion < PaperTrail::Version
|
8
8
|
self.table_name = :revelry_content_content_versions
|
9
9
|
self.sequence_name = :revelry_content_version_id_seq
|
10
10
|
before_save :cast_whodunnit
|
@@ -1,9 +1,9 @@
|
|
1
1
|
<!DOCTYPE html>
|
2
2
|
<html>
|
3
3
|
<head>
|
4
|
-
<title>
|
4
|
+
<title>Revelry::Content</title>
|
5
5
|
<%= stylesheet_link_tag "revelry_content/application" %>
|
6
|
-
<%= javascript_include_tag "
|
6
|
+
<%= javascript_include_tag "application" %>
|
7
7
|
<%= csrf_meta_tags %>
|
8
8
|
</head>
|
9
9
|
<body>
|
@@ -1,2 +1,2 @@
|
|
1
|
-
<div data-react-class="
|
2
|
-
<div data-react-class="
|
1
|
+
<div data-react-class="Rev.Content.TopBar" data-react-props="{}"></div>
|
2
|
+
<div data-react-class="Rev.Content.EditModeButton" data-react-props="{}"></div>
|
@@ -1 +1 @@
|
|
1
|
-
<div data-react-class="
|
1
|
+
<div data-react-class="Rev.Content.AdminPage" data-react-props="{}"></div>
|
data/config/routes.rb
CHANGED
@@ -0,0 +1,51 @@
|
|
1
|
+
require 'rails/generators'
|
2
|
+
|
3
|
+
module Revelry
|
4
|
+
module Generators
|
5
|
+
module Content
|
6
|
+
class CssGenerator < ::Rails::Generators::Base
|
7
|
+
CSS_FILE_EXTENSIONS = %w(
|
8
|
+
.css
|
9
|
+
.css.sass
|
10
|
+
.css.scss
|
11
|
+
.sass
|
12
|
+
.scss
|
13
|
+
)
|
14
|
+
|
15
|
+
def add_css_assets
|
16
|
+
if using_sass?
|
17
|
+
append_to_file css_app_bundle do
|
18
|
+
'@import "revelry_content";'
|
19
|
+
end
|
20
|
+
else
|
21
|
+
insert_into_file css_app_bundle, before: %r{(//|\*)= require_self} do
|
22
|
+
"*= require revelry_content\n "
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
private
|
28
|
+
|
29
|
+
def using_sass?
|
30
|
+
/s(c|a)ss/.match(css_file_extname)
|
31
|
+
end
|
32
|
+
|
33
|
+
def css_app_bundle
|
34
|
+
File.join(css_base_dir, "revelry-app#{ css_file_extname }")
|
35
|
+
end
|
36
|
+
|
37
|
+
def css_base_dir
|
38
|
+
File.join('app', 'assets', 'stylesheets')
|
39
|
+
end
|
40
|
+
|
41
|
+
def test_css_format(fmt)
|
42
|
+
File.exist?(File.join(css_base_dir, "revelry-app#{ fmt }"))
|
43
|
+
end
|
44
|
+
|
45
|
+
def css_file_extname
|
46
|
+
CSS_FILE_EXTENSIONS.find { |fmt| test_css_format(fmt) }
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
module Revelry
|
2
|
+
module Generators
|
3
|
+
module Content
|
4
|
+
class InitializerGenerator < ::Rails::Generators::Base
|
5
|
+
source_root File.expand_path('../templates', __FILE__)
|
6
|
+
|
7
|
+
def add_initializer
|
8
|
+
template 'initializer.rb', 'config/initializers/revelry_content.rb'
|
9
|
+
end
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
@@ -0,0 +1,40 @@
|
|
1
|
+
module Revelry
|
2
|
+
module Generators
|
3
|
+
module Content
|
4
|
+
class InstallGenerator < ::Rails::Generators::Base
|
5
|
+
def add_migrations
|
6
|
+
generate 'revelry:content:migrations'
|
7
|
+
rake 'db:migrate'
|
8
|
+
end
|
9
|
+
|
10
|
+
def add_js_assets
|
11
|
+
generate 'revelry:content:js'
|
12
|
+
end
|
13
|
+
|
14
|
+
def add_css_assets
|
15
|
+
generate 'revelry:content:css'
|
16
|
+
end
|
17
|
+
|
18
|
+
def add_initializer
|
19
|
+
generate 'revelry:content:initializer'
|
20
|
+
end
|
21
|
+
|
22
|
+
def add_route
|
23
|
+
route 'mount Revelry::Content::Engine => "/revelry_content"'
|
24
|
+
end
|
25
|
+
|
26
|
+
def add_controller_concern
|
27
|
+
insert_into_file app_controller, after: "ApplicationController < ActionController::Base\n" do
|
28
|
+
"include Revelry::Content::WithRevelryContent\n"
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
private
|
33
|
+
|
34
|
+
def app_controller
|
35
|
+
File.join('app', 'controllers', 'application_controller.rb')
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
40
|
+
end
|
@@ -0,0 +1,45 @@
|
|
1
|
+
module Revelry
|
2
|
+
module Generators
|
3
|
+
module Content
|
4
|
+
class JsGenerator < ::Rails::Generators::Base
|
5
|
+
JS_FILE_EXTENSIONS = %w(
|
6
|
+
.coffee
|
7
|
+
.coffee.erb
|
8
|
+
.js.coffee
|
9
|
+
.js.coffee.rb
|
10
|
+
.js
|
11
|
+
.js.rb
|
12
|
+
)
|
13
|
+
|
14
|
+
def add_js_assets
|
15
|
+
insert_into_file js_app_bundle, before: %r{(//|#)= require_tree \.} do
|
16
|
+
"#{ js_require_marker }= require revelry_content\n"
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
private
|
21
|
+
|
22
|
+
def js_app_bundle
|
23
|
+
File.join(js_base_dir, "revelry-app#{ js_file_extname }")
|
24
|
+
end
|
25
|
+
|
26
|
+
def test_js_format(fmt)
|
27
|
+
File.exist?(File.join(js_base_dir, "revelry-app#{ fmt }"))
|
28
|
+
end
|
29
|
+
|
30
|
+
def js_base_dir
|
31
|
+
File.join('app', 'assets', 'javascripts')
|
32
|
+
end
|
33
|
+
|
34
|
+
def js_file_extname
|
35
|
+
JS_FILE_EXTENSIONS.find { |fmt| test_js_format(fmt) }
|
36
|
+
end
|
37
|
+
|
38
|
+
def js_require_marker
|
39
|
+
'#' if js_file_extname.include?('coffee')
|
40
|
+
'//'
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
require 'rails/generators/migration'
|
2
|
+
|
3
|
+
module Revelry
|
4
|
+
module Generators
|
5
|
+
module Content
|
6
|
+
class MigrationsGenerator < ::Rails::Generators::Base
|
7
|
+
include Rails::Generators::Migration
|
8
|
+
source_root File.expand_path('../templates', __FILE__)
|
9
|
+
desc "add the migrations"
|
10
|
+
|
11
|
+
def self.next_migration_number(path)
|
12
|
+
unless @prev_migration_nr
|
13
|
+
@prev_migration_nr = Time.now.utc.strftime("%Y%m%d%H%M%S").to_i
|
14
|
+
else
|
15
|
+
@prev_migration_nr += 1
|
16
|
+
end
|
17
|
+
@prev_migration_nr.to_s
|
18
|
+
end
|
19
|
+
|
20
|
+
def copy_migrations
|
21
|
+
migration_template "create_revelry_content_contents.rb", "db/migrate/create_revelry_content_contents.rb"
|
22
|
+
migration_template "create_versions.rb", "db/migrate/create_versions.rb"
|
23
|
+
migration_template "create_revelry_content_pages.rb", "db/migrate/create_revelry_content_pages.rb"
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
data/lib/generators/{revelry_content → revelry/content}/templates/create_revelry_content_contents.rb
RENAMED
File without changes
|
@@ -0,0 +1,17 @@
|
|
1
|
+
class CreateRevelryContentPages < ActiveRecord::Migration
|
2
|
+
def change
|
3
|
+
create_table :revelry_content_pages do |t|
|
4
|
+
t.string :slug
|
5
|
+
t.string :menu_name
|
6
|
+
t.string :name
|
7
|
+
t.string :template
|
8
|
+
t.string :ancestry
|
9
|
+
t.integer :depth_cache
|
10
|
+
t.boolean :show_in_menu
|
11
|
+
t.boolean :draft
|
12
|
+
t.timestamps null: false
|
13
|
+
end
|
14
|
+
|
15
|
+
add_index :revelry_content_pages, :template
|
16
|
+
end
|
17
|
+
end
|
File without changes
|
@@ -0,0 +1,13 @@
|
|
1
|
+
Revelry::Content.configure do |config|
|
2
|
+
#config.user_for_content do |controller|
|
3
|
+
# # Your authentication logic here
|
4
|
+
# controller.current_user
|
5
|
+
#end
|
6
|
+
|
7
|
+
#config.authorization_policy do |user|
|
8
|
+
# # Your authorization logic here
|
9
|
+
# user.admin?
|
10
|
+
#end
|
11
|
+
|
12
|
+
#config.js_export = true
|
13
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
unless defined?(Revelry::Content::ControllerAuthorization)
|
2
|
+
module Revelry::Content::ControllerAuthorization
|
3
|
+
extend ActiveSupport::Concern
|
4
|
+
|
5
|
+
included do
|
6
|
+
before_action :check_authorization
|
7
|
+
end
|
8
|
+
|
9
|
+
def check_authorization
|
10
|
+
throw "Unauthorized" unless Revelry::Content.config.authorize(self)
|
11
|
+
end
|
12
|
+
end
|
13
|
+
end
|
@@ -1,4 +1,4 @@
|
|
1
|
-
class
|
1
|
+
class Revelry::Content::Configuration
|
2
2
|
def js_export
|
3
3
|
@js_export || false
|
4
4
|
end
|
@@ -33,7 +33,7 @@ class RevelryContent::Configuration
|
|
33
33
|
def default_authorization_policy
|
34
34
|
->(user) do
|
35
35
|
if user.present?
|
36
|
-
if user.respond_to?
|
36
|
+
if user.respond_to?(:has_role?)
|
37
37
|
return user.has_role? :admin
|
38
38
|
else
|
39
39
|
return user.admin?
|
@@ -0,0 +1,18 @@
|
|
1
|
+
unless defined?(::Revelry::Content::WithRevelryContent)
|
2
|
+
module ::Revelry::Content::WithRevelryContent
|
3
|
+
extend ActiveSupport::Concern
|
4
|
+
|
5
|
+
included do
|
6
|
+
before_action :gather_contents
|
7
|
+
end
|
8
|
+
|
9
|
+
def content_scope
|
10
|
+
Revelry::Content::Content.excluding_prefix('pages')
|
11
|
+
end
|
12
|
+
|
13
|
+
def gather_contents
|
14
|
+
@revelry_content_contents =
|
15
|
+
Revelry::Content::Content.as_lookup_table(content_scope)
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|