releaf-core 1.1.20 → 2.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/app/assets/config/releaf_core_manifest.js +3 -0
- data/app/assets/images/ckeditor/plugins/about/dialogs/hidpi/logo_ckeditor.png +0 -0
- data/app/assets/images/ckeditor/plugins/about/dialogs/logo_ckeditor.png +0 -0
- data/app/assets/images/ckeditor/plugins/flash/images/placeholder.png +0 -0
- data/app/assets/images/ckeditor/plugins/forms/images/hiddenfield.gif +0 -0
- data/app/assets/images/ckeditor/plugins/icons.png +0 -0
- data/app/assets/images/ckeditor/plugins/iframe/images/placeholder.png +0 -0
- data/app/assets/images/ckeditor/plugins/image/images/noimage.png +0 -0
- data/app/assets/images/ckeditor/plugins/link/images/anchor.png +0 -0
- data/app/assets/images/ckeditor/plugins/link/images/hidpi/anchor.png +0 -0
- data/app/assets/images/ckeditor/plugins/magicline/images/hidpi/icon-rtl.png +0 -0
- data/app/assets/images/ckeditor/plugins/magicline/images/hidpi/icon.png +0 -0
- data/app/assets/images/ckeditor/plugins/magicline/images/icon-rtl.png +0 -0
- data/app/assets/images/ckeditor/plugins/magicline/images/icon.png +0 -0
- data/app/assets/images/ckeditor/plugins/pagebreak/images/pagebreak.gif +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_address.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_blockquote.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_div.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_h1.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_h2.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_h3.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_h4.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_h5.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_h6.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_p.png +0 -0
- data/app/assets/images/ckeditor/plugins/showblocks/images/block_pre.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/angel_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/angel_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/angry_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/angry_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/broken_heart.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/broken_heart.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/confused_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/confused_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/cry_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/cry_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/devil_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/devil_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/embaressed_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/embarrassed_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/embarrassed_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/envelope.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/envelope.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/heart.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/heart.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/kiss.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/kiss.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/lightbulb.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/lightbulb.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/omg_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/omg_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/regular_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/regular_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/sad_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/sad_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/shades_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/shades_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/teeth_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/teeth_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/thumbs_down.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/thumbs_down.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/thumbs_up.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/thumbs_up.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/tongue_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/tongue_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/tounge_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/whatchutalkingabout_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/whatchutalkingabout_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/wink_smile.gif +0 -0
- data/app/assets/images/ckeditor/plugins/smiley/images/wink_smile.png +0 -0
- data/app/assets/images/ckeditor/plugins/templates/templates/images/template1.gif +0 -0
- data/app/assets/images/ckeditor/plugins/templates/templates/images/template2.gif +0 -0
- data/app/assets/images/ckeditor/plugins/templates/templates/images/template3.gif +0 -0
- data/app/assets/images/ckeditor/plugins/widget/images/handle.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/icons.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/icons_hidpi.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/arrow.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/close.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/hidpi/close.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/hidpi/lock-open.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/hidpi/lock.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/hidpi/refresh.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/lock-open.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/lock.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/refresh.png +0 -0
- data/app/assets/images/ckeditor/skins/moono-lisa/images/spinner.gif +0 -0
- data/app/assets/javascripts/ckeditor-jquery.js +3 -0
- data/app/assets/javascripts/ckeditor/CHANGES.md +1637 -0
- data/app/assets/javascripts/ckeditor/LICENSE.md +1420 -0
- data/app/assets/javascripts/ckeditor/README.md +39 -0
- data/app/assets/javascripts/ckeditor/basepath.js.erb +6 -0
- data/app/assets/javascripts/ckeditor/build-config.js +190 -0
- data/app/assets/javascripts/ckeditor/ckeditor.js +1331 -0
- data/app/assets/javascripts/ckeditor/config.js +10 -0
- data/app/assets/javascripts/ckeditor/jquery.js +10 -0
- data/app/assets/javascripts/ckeditor/lang/af.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ar.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/az.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/bg.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/bn.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/bs.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ca.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/cs.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/cy.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/da.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/de-ch.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/de.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/el.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/en-au.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/en-ca.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/en-gb.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/en.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/eo.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/es-mx.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/es.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/et.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/eu.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/fa.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/fi.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/fo.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/fr-ca.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/fr.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/gl.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/gu.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/he.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/hi.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/hr.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/hu.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/id.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/is.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/it.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ja.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ka.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/km.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ko.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ku.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/lt.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/lv.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/mk.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/mn.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ms.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/nb.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/nl.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/no.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/oc.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/pl.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/pt-br.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/pt.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ro.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ru.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/si.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/sk.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/sl.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/sq.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/sr-latn.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/sr.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/sv.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/th.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/tr.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/tt.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/ug.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/uk.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/vi.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/zh-cn.js +5 -0
- data/app/assets/javascripts/ckeditor/lang/zh.js +5 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/a11yhelp.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/af.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/ar.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/az.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/bg.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/ca.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/cs.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/cy.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/da.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/de-ch.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/de.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/el.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/en-au.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/en-gb.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/en.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/eo.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/es-mx.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/es.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/et.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/eu.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/fa.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/fi.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/fo.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/fr-ca.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/fr.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/gl.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/gu.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/he.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/hi.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/hr.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/hu.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/id.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/it.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/ja.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/km.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/ko.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/ku.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/lt.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/lv.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/mk.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/mn.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/nb.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/nl.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/no.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/oc.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/pl.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/pt-br.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/pt.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/ro.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/ru.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/si.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/sk.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/sl.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/sq.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/sr-latn.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/sr.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/sv.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/th.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/tr.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/tt.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/ug.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/uk.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/vi.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/zh-cn.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/a11yhelp/dialogs/lang/zh.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/about/dialogs/about.js +8 -0
- data/app/assets/javascripts/ckeditor/plugins/clipboard/dialogs/paste.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/colordialog/dialogs/colordialog.js +14 -0
- data/app/assets/javascripts/ckeditor/plugins/dialog/dialogDefinition.js +4 -0
- data/app/assets/javascripts/ckeditor/plugins/div/dialogs/div.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/find/dialogs/find.js +25 -0
- data/app/assets/javascripts/ckeditor/plugins/flash/dialogs/flash.js +24 -0
- data/app/assets/javascripts/ckeditor/plugins/forms/dialogs/button.js +8 -0
- data/app/assets/javascripts/ckeditor/plugins/forms/dialogs/checkbox.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/forms/dialogs/form.js +8 -0
- data/app/assets/javascripts/ckeditor/plugins/forms/dialogs/hiddenfield.js +7 -0
- data/app/assets/javascripts/ckeditor/plugins/forms/dialogs/radio.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/forms/dialogs/select.js +21 -0
- data/app/assets/javascripts/ckeditor/plugins/forms/dialogs/textarea.js +8 -0
- data/app/assets/javascripts/ckeditor/plugins/forms/dialogs/textfield.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/iframe/dialogs/iframe.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/image/dialogs/image.js +44 -0
- data/app/assets/javascripts/ckeditor/plugins/link/dialogs/anchor.js +8 -0
- data/app/assets/javascripts/ckeditor/plugins/link/dialogs/link.js +30 -0
- data/app/assets/javascripts/ckeditor/plugins/liststyle/dialogs/liststyle.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/pastefromword/filter/default.js +55 -0
- data/app/assets/javascripts/ckeditor/plugins/preview/preview.html +13 -0
- data/app/assets/javascripts/ckeditor/plugins/scayt/CHANGELOG.md +20 -0
- data/app/assets/javascripts/ckeditor/plugins/scayt/LICENSE.md +28 -0
- data/app/assets/javascripts/ckeditor/plugins/scayt/README.md +25 -0
- data/app/assets/javascripts/ckeditor/plugins/scayt/dialogs/options.js +32 -0
- data/app/assets/javascripts/ckeditor/plugins/smiley/dialogs/smiley.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/af.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/ar.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/az.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/bg.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/ca.js +14 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/cs.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/cy.js +14 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/da.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/de-ch.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/de.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/el.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/en-au.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/en-ca.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/en-gb.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/en.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/eo.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/es-mx.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/es.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/et.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/eu.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/fa.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/fi.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/fr-ca.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/fr.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/gl.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/he.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/hr.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/hu.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/id.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/it.js +14 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/ja.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/km.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/ko.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/ku.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/lt.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/lv.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/nb.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/nl.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/no.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/oc.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/pl.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/pt-br.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/pt.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/ro.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/ru.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/si.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/sk.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/sl.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/sq.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/sv.js +11 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/th.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/tr.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/tt.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/ug.js +13 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/uk.js +12 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/vi.js +14 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/zh-cn.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/lang/zh.js +9 -0
- data/app/assets/javascripts/ckeditor/plugins/specialchar/dialogs/specialchar.js +14 -0
- data/app/assets/javascripts/ckeditor/plugins/table/dialogs/table.js +21 -0
- data/app/assets/javascripts/ckeditor/plugins/tabletools/dialogs/tableCell.js +18 -0
- data/app/assets/javascripts/ckeditor/plugins/templates/dialogs/templates.js +10 -0
- data/app/assets/javascripts/ckeditor/plugins/templates/templates/default.js +7 -0
- data/app/assets/javascripts/ckeditor/plugins/wsc/LICENSE.md +28 -0
- data/app/assets/javascripts/ckeditor/plugins/wsc/README.md +25 -0
- data/app/assets/javascripts/ckeditor/plugins/wsc/dialogs/ciframe.html +66 -0
- data/app/assets/javascripts/ckeditor/plugins/wsc/dialogs/tmpFrameset.html +52 -0
- data/app/assets/javascripts/ckeditor/plugins/wsc/dialogs/wsc.js +91 -0
- data/app/assets/javascripts/ckeditor/plugins/wsc/dialogs/wsc_ie.js +11 -0
- data/app/assets/javascripts/ckeditor/styles.js +137 -0
- data/app/assets/javascripts/releaf/include/remote_validator.js +1 -1
- data/app/assets/javascripts/releaf/include/store_settings.js +2 -2
- data/app/assets/javascripts/releaf/include/url_builder.js +130 -130
- data/app/assets/stylesheets/ckeditor/contents.css +208 -0
- data/app/assets/stylesheets/ckeditor/plugins/colordialog/dialogs/colordialog.css +20 -0
- data/app/assets/stylesheets/ckeditor/plugins/copyformatting/styles/copyformatting.css +45 -0
- data/app/assets/stylesheets/ckeditor/plugins/scayt/dialogs/dialog.css +23 -0
- data/app/assets/stylesheets/ckeditor/plugins/scayt/dialogs/toolbar.css +71 -0
- data/app/assets/stylesheets/ckeditor/plugins/scayt/skins/moono-lisa/scayt.css +25 -0
- data/app/assets/stylesheets/ckeditor/plugins/tableselection/styles/tableselection.css +36 -0
- data/app/assets/stylesheets/ckeditor/plugins/templates/dialogs/templates.css +84 -0
- data/app/assets/stylesheets/ckeditor/plugins/wsc/dialogs/wsc.css +82 -0
- data/app/assets/stylesheets/ckeditor/plugins/wsc/skins/moono-lisa/wsc.css +43 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/dialog.css +5 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/dialog_ie.css +5 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/dialog_ie8.css +5 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/dialog_iequirks.css +5 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/editor.css +5 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/editor_gecko.css +5 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/editor_ie.css +5 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/editor_ie8.css +5 -0
- data/app/assets/stylesheets/ckeditor/skins/moono-lisa/editor_iequirks.css +5 -0
- data/app/builders/releaf/builders.rb +4 -1
- data/app/builders/releaf/builders/base.rb +1 -1
- data/app/builders/releaf/builders/form_builder/associations.rb +1 -1
- data/app/builders/releaf/builders/page/layout_builder.rb +1 -1
- data/app/builders/releaf/builders/pagination_builder.rb +1 -1
- data/app/builders/releaf/builders/table_builder.rb +7 -0
- data/app/controllers/releaf/action_controller.rb +2 -2
- data/app/controllers/releaf/root_controller.rb +9 -7
- data/app/helpers/releaf/application_helper.rb +2 -2
- data/app/lib/releaf/action_controller/features.rb +1 -6
- data/app/lib/releaf/build_errors_hash.rb +12 -12
- data/app/lib/releaf/responders.rb +0 -1
- data/app/lib/releaf/search.rb +5 -18
- data/app/models/releaf/settings.rb +1 -1
- data/app/views/releaf/action/create_releaf_richtext_attachment.haml +2 -1
- data/app/views/releaf/error_pages/access_denied.html.haml +1 -1
- data/lib/generators/dummy/install_generator.rb +2 -1
- data/lib/generators/dummy/templates/assets/config/manifest.js +3 -0
- data/lib/generators/dummy/templates/controllers/application_controller.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_authors.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_banner_groups.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_banner_pages.rb +2 -2
- data/lib/generators/dummy/templates/migrations/create_banners.rb +2 -2
- data/lib/generators/dummy/templates/migrations/create_book_sequels.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_books.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_bundles.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_chapters.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_home_pages.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_node_extra_fields.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_other_nodes.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_publishers.rb +1 -1
- data/lib/generators/dummy/templates/migrations/create_text_pages.rb +1 -1
- data/lib/generators/dummy/templates/models/author.rb +1 -1
- data/lib/generators/dummy/templates/models/banner.rb +1 -1
- data/lib/generators/dummy/templates/models/banner_group.rb +1 -1
- data/lib/generators/dummy/templates/models/book.rb +1 -1
- data/lib/generators/releaf/templates/initializers/releaf.rb +1 -1
- data/lib/generators/releaf/templates/migrations/create_releaf_nodes.rb +1 -1
- data/lib/generators/releaf/templates/migrations/create_releaf_permissions.rb +1 -1
- data/lib/generators/releaf/templates/migrations/create_releaf_richtext_attachments.rb +1 -1
- data/lib/generators/releaf/templates/migrations/create_releaf_roles.rb +1 -1
- data/lib/generators/releaf/templates/migrations/create_releaf_settings.rb +1 -1
- data/lib/generators/releaf/templates/migrations/create_releaf_translations.rb +1 -1
- data/lib/generators/releaf/templates/migrations/create_releaf_users.rb +1 -1
- data/lib/releaf-core.rb +1 -2
- data/lib/releaf/engine.rb +2 -3
- data/lib/releaf/rails_ext/globalize-accessors.rb +64 -0
- data/lib/releaf/rails_ext/validation_error_codes.rb +0 -36
- metadata +418 -221
- data/app/lib/releaf/responders/feature_disabled_responder.rb +0 -9
- data/app/views/releaf/error_pages/feature_disabled.html.haml +0 -1
- data/spec/builders/releaf/builders/association_reflector_spec.rb +0 -138
- data/spec/builders/releaf/builders/base_spec.rb +0 -272
- data/spec/builders/releaf/builders/collection_spec.rb +0 -18
- data/spec/builders/releaf/builders/confirm_destroy_dialog_builder_spec.rb +0 -71
- data/spec/builders/releaf/builders/confirm_dialog_builder_spec.rb +0 -107
- data/spec/builders/releaf/builders/edit_builder_spec.rb +0 -322
- data/spec/builders/releaf/builders/form_builder/associations_spec.rb +0 -129
- data/spec/builders/releaf/builders/form_builder/date_fields_spec.rb +0 -86
- data/spec/builders/releaf/builders/form_builder/i18n_fields_spec.rb +0 -48
- data/spec/builders/releaf/builders/form_builder/label_spec.rb +0 -106
- data/spec/builders/releaf/builders/form_builder/number_fields_spec.rb +0 -37
- data/spec/builders/releaf/builders/form_builder_spec.rb +0 -228
- data/spec/builders/releaf/builders/index_builder_spec.rb +0 -364
- data/spec/builders/releaf/builders/page/header_builder_spec.rb +0 -65
- data/spec/builders/releaf/builders/page/layout_builder_spec.rb +0 -237
- data/spec/builders/releaf/builders/page/menu_builder_spec.rb +0 -345
- data/spec/builders/releaf/builders/pagination_builder_spec.rb +0 -330
- data/spec/builders/releaf/builders/resource_dialog_spec.rb +0 -21
- data/spec/builders/releaf/builders/resource_view_spec.rb +0 -158
- data/spec/builders/releaf/builders/show_builder_spec.rb +0 -7
- data/spec/builders/releaf/builders/table_builder_spec.rb +0 -624
- data/spec/builders/releaf/builders/template_spec.rb +0 -12
- data/spec/builders/releaf/builders/toolbox_builder_spec.rb +0 -67
- data/spec/builders/releaf/builders/toolbox_spec.rb +0 -48
- data/spec/builders/releaf/builders/utilities/date_fields_spec.rb +0 -125
- data/spec/builders/releaf/builders/utilities/resolve_attribute_field_method_name_spec.rb +0 -318
- data/spec/builders/releaf/builders/view_spec.rb +0 -281
- data/spec/builders/releaf/builders_spec.rb +0 -134
- data/spec/builders/releaf/settings/form_builder_spec.rb +0 -48
- data/spec/builders/releaf/settings/table_builder_spec.rb +0 -23
- data/spec/controllers/concerns/releaf/richtext_attachments_spec.rb +0 -51
- data/spec/controllers/releaf/action_controller_spec.rb +0 -423
- data/spec/controllers/releaf/root_controller_spec.rb +0 -45
- data/spec/controllers/releaf/settings_controller_spec.rb +0 -52
- data/spec/error_hash_builder_spec.rb +0 -83
- data/spec/ext/array_reorder_spec.rb +0 -12
- data/spec/features/ajaxbox_spec.rb +0 -111
- data/spec/features/authorization_spec.rb +0 -50
- data/spec/features/breadcrumbs_spec.rb +0 -16
- data/spec/features/dragonfly_integration_spec.rb +0 -24
- data/spec/features/edit_actions_spec.rb +0 -186
- data/spec/features/errors_spec.rb +0 -47
- data/spec/features/index_actions_spec.rb +0 -85
- data/spec/features/index_table_spec.rb +0 -35
- data/spec/features/menu_spec.rb +0 -71
- data/spec/features/richtext_attachments_spec.rb +0 -64
- data/spec/features/richtext_custom_config_spec.rb +0 -28
- data/spec/features/richtext_embed_spec.rb +0 -29
- data/spec/features/richtext_spec.rb +0 -31
- data/spec/features/search_spec.rb +0 -825
- data/spec/features/settings_spec.rb +0 -70
- data/spec/features/title_spec.rb +0 -13
- data/spec/fixtures/common_fields.yml +0 -17
- data/spec/fixtures/cs.png +0 -0
- data/spec/fixtures/time.formats.xlsx +0 -0
- data/spec/fixtures/unicorn.jpg +0 -0
- data/spec/helpers/application_helper_spec.rb +0 -73
- data/spec/helpers/button_helper_spec.rb +0 -146
- data/spec/lib/releaf/action_controller/features_spec.rb +0 -171
- data/spec/lib/releaf/action_controller/search_spec.rb +0 -84
- data/spec/lib/releaf/application_spec.rb +0 -43
- data/spec/lib/releaf/assets_resolver_spec.rb +0 -130
- data/spec/lib/releaf/build_errors_hash_spec.rb +0 -141
- data/spec/lib/releaf/configuration_spec.rb +0 -205
- data/spec/lib/releaf/controller_definition_spec.rb +0 -78
- data/spec/lib/releaf/controller_group_definition_spec.rb +0 -33
- data/spec/lib/releaf/default_searchable_fields_spec.rb +0 -161
- data/spec/lib/releaf/instance_cache_spec.rb +0 -98
- data/spec/lib/releaf/resource_base_spec.rb +0 -212
- data/spec/lib/releaf/resource_fields_spec.rb +0 -12
- data/spec/lib/releaf/resource_params_spec.rb +0 -115
- data/spec/lib/releaf/resource_table_fields_spec.rb +0 -20
- data/spec/lib/releaf/resource_utilities_spec.rb +0 -87
- data/spec/lib/releaf/responders/access_denied_responder_spec.rb +0 -12
- data/spec/lib/releaf/responders/after_save_responder_spec.rb +0 -88
- data/spec/lib/releaf/responders/confirm_destroy_responder_spec.rb +0 -26
- data/spec/lib/releaf/responders/destroy_responder_spec.rb +0 -30
- data/spec/lib/releaf/responders/error_responder_spec.rb +0 -26
- data/spec/lib/releaf/responders/feature_disabled_responder_spec.rb +0 -12
- data/spec/lib/releaf/responders/page_not_found_responder_spec.rb +0 -12
- data/spec/lib/releaf/responders_spec.rb +0 -60
- data/spec/lib/releaf/root/configuration_spec.rb +0 -9
- data/spec/lib/releaf/root/default_controller_resolver_spec.rb +0 -44
- data/spec/lib/releaf/root_spec.rb +0 -13
- data/spec/lib/releaf/service_spec.rb +0 -20
- data/spec/lib/releaf/settings/normalize_value_spec.rb +0 -103
- data/spec/lib/releaf/settings/register_spec.rb +0 -135
- data/spec/lib/releaf/settings_manager_spec.rb +0 -22
- data/spec/lib/validation_error_codes_spec.rb +0 -56
- data/spec/misc/factories_spec.rb +0 -31
- data/spec/models/settings_spec.rb +0 -100
- data/spec/routing/route_mapper_spec.rb +0 -185
- data/spec/rspec_helpers/test_helpers_spec.rb +0 -20
- data/spec/rspec_helpers/test_spec.rb +0 -14
- data/spec/services/array/reorder_spec.rb +0 -121
@@ -1,364 +0,0 @@
|
|
1
|
-
require "rails_helper"
|
2
|
-
|
3
|
-
describe Releaf::Builders::IndexBuilder, type: :class do
|
4
|
-
class TranslationsIndexBuilderTestHelper < ActionView::Base
|
5
|
-
include Releaf::ApplicationHelper
|
6
|
-
delegate :resource_class, :table_options, to: :controller
|
7
|
-
|
8
|
-
def controller
|
9
|
-
@controller ||= Admin::BooksController.new
|
10
|
-
end
|
11
|
-
end
|
12
|
-
|
13
|
-
let(:template){ TranslationsIndexBuilderTestHelper.new }
|
14
|
-
let(:subject){ described_class.new(template) }
|
15
|
-
let(:collection){ Book.page(1).per_page(2) }
|
16
|
-
|
17
|
-
before do
|
18
|
-
allow(subject).to receive(:controller_name).and_return("_controller_name_")
|
19
|
-
allow(subject).to receive(:collection).and_return(collection)
|
20
|
-
end
|
21
|
-
|
22
|
-
it "includes Releaf::Builders::View" do
|
23
|
-
expect(described_class.ancestors).to include(Releaf::Builders::View)
|
24
|
-
end
|
25
|
-
|
26
|
-
it "includes Releaf::Builders::Collection" do
|
27
|
-
expect(described_class.ancestors).to include(Releaf::Builders::Collection)
|
28
|
-
end
|
29
|
-
|
30
|
-
describe "#dialog?" do
|
31
|
-
it "returns false" do
|
32
|
-
expect(subject.dialog?).to be false
|
33
|
-
end
|
34
|
-
end
|
35
|
-
|
36
|
-
describe "#search_block" do
|
37
|
-
before do
|
38
|
-
allow(subject).to receive(:text_search_block).and_return("aa")
|
39
|
-
allow(subject).to receive(:extra_search_block).and_return("bb")
|
40
|
-
allow(subject).to receive(:search_form_attributes).and_return(a: "xx")
|
41
|
-
end
|
42
|
-
|
43
|
-
it "returns search from with attributes and text/extra search blocks" do
|
44
|
-
expect(subject.search_block).to eq('<form a="xx">aabb</form>')
|
45
|
-
end
|
46
|
-
|
47
|
-
context "when no text blocks available" do
|
48
|
-
it "returns nil" do
|
49
|
-
allow(subject).to receive(:text_search_block).and_return(nil)
|
50
|
-
allow(subject).to receive(:extra_search_block).and_return(nil)
|
51
|
-
expect(subject.search_block).to be nil
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
|
56
|
-
describe "#search_form_attributes" do
|
57
|
-
before do
|
58
|
-
allow(subject).to receive(:text_search_available?).and_return(true)
|
59
|
-
allow(subject).to receive(:extra_search_available?).and_return(true)
|
60
|
-
allow(subject.template).to receive(:url_for).with(controller: "_controller_name_", action: "index").and_return("x")
|
61
|
-
end
|
62
|
-
|
63
|
-
it "returns url and css classes for search form" do
|
64
|
-
classes = ["search", "has-text-search", "has-extra-search"]
|
65
|
-
expect(subject.search_form_attributes).to eq(class: classes, action: "x")
|
66
|
-
end
|
67
|
-
|
68
|
-
context "when text search is not available" do
|
69
|
-
it "does not add text search class" do
|
70
|
-
allow(subject).to receive(:text_search_available?).and_return(false)
|
71
|
-
expect(subject.search_form_attributes[:class]).to_not include("has-text-search")
|
72
|
-
end
|
73
|
-
end
|
74
|
-
|
75
|
-
context "when extra search is not available" do
|
76
|
-
it "does not add extra search class" do
|
77
|
-
allow(subject).to receive(:extra_search_available?).and_return(false)
|
78
|
-
expect(subject.search_form_attributes[:class]).to_not include("has-extra-search")
|
79
|
-
end
|
80
|
-
end
|
81
|
-
end
|
82
|
-
|
83
|
-
describe "#header_extras" do
|
84
|
-
before do
|
85
|
-
allow(subject).to receive(:search_block).and_return("x")
|
86
|
-
end
|
87
|
-
|
88
|
-
context "when search feature is enabled" do
|
89
|
-
it "returns search block" do
|
90
|
-
allow(subject).to receive(:feature_available?).with(:search).and_return(true)
|
91
|
-
expect(subject.header_extras).to eq("x")
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
context "when search feature is disabled" do
|
96
|
-
it "returns nil" do
|
97
|
-
allow(subject).to receive(:feature_available?).with(:search).and_return(false)
|
98
|
-
expect(subject.header_extras).to be nil
|
99
|
-
end
|
100
|
-
end
|
101
|
-
end
|
102
|
-
|
103
|
-
describe "#extra_search_available?" do
|
104
|
-
context "when extra search block is present" do
|
105
|
-
it "returns true" do
|
106
|
-
allow(subject).to receive(:extra_search_block).and_return("x")
|
107
|
-
expect(subject.extra_search_available?).to be true
|
108
|
-
end
|
109
|
-
end
|
110
|
-
|
111
|
-
context "when extra search block is nil" do
|
112
|
-
it "returns false" do
|
113
|
-
allow(subject).to receive(:extra_search_block).and_return(nil)
|
114
|
-
expect(subject.extra_search_available?).to be false
|
115
|
-
end
|
116
|
-
end
|
117
|
-
end
|
118
|
-
|
119
|
-
describe "#text_search_available?", focus: true do
|
120
|
-
context "when template variable `searchable_fields` is present" do
|
121
|
-
it "returns true" do
|
122
|
-
allow( template.controller ).to receive(:searchable_fields).and_return([:a])
|
123
|
-
expect(subject.text_search_available?).to be true
|
124
|
-
end
|
125
|
-
end
|
126
|
-
|
127
|
-
context "when template variable `searchable_fields` is blank" do
|
128
|
-
it "returns false" do
|
129
|
-
allow( template.controller ).to receive(:searchable_fields).and_return([])
|
130
|
-
expect(subject.text_search_available?).to be false
|
131
|
-
end
|
132
|
-
end
|
133
|
-
end
|
134
|
-
|
135
|
-
describe "#text_search_block" do
|
136
|
-
before do
|
137
|
-
allow(subject).to receive(:text_search_content).and_return("x")
|
138
|
-
end
|
139
|
-
|
140
|
-
context "when text search is available" do
|
141
|
-
it "returns true" do
|
142
|
-
allow(subject).to receive(:text_search_available?).and_return(true)
|
143
|
-
expect(subject.text_search_block).to eq('<div class="text-search">x</div>')
|
144
|
-
end
|
145
|
-
end
|
146
|
-
|
147
|
-
context "when text search is not available" do
|
148
|
-
it "returns false" do
|
149
|
-
allow(subject).to receive(:text_search_available?).and_return(false)
|
150
|
-
expect(subject.text_search_block).to be nil
|
151
|
-
end
|
152
|
-
end
|
153
|
-
end
|
154
|
-
|
155
|
-
describe "#text_search_content" do
|
156
|
-
|
157
|
-
it "returns text search field and button" do
|
158
|
-
allow(subject).to receive(:t).with('Search').and_return("sss")
|
159
|
-
allow(subject).to receive(:params).and_return(search: "xxx")
|
160
|
-
allow(subject).to receive(:button)
|
161
|
-
.with(nil, "search", type: "submit", title: 'sss')
|
162
|
-
.and_return("<search_button />".html_safe)
|
163
|
-
expect(subject).to receive(:search_field).with("search").and_call_original
|
164
|
-
expect(subject.text_search_content).to match_html(%Q[
|
165
|
-
<div class="search-field" data-name="search">
|
166
|
-
<input name="search" type="search" class="text" value="xxx" autofocus="autofocus"></input>
|
167
|
-
<search_button />
|
168
|
-
</div>
|
169
|
-
])
|
170
|
-
end
|
171
|
-
|
172
|
-
end
|
173
|
-
|
174
|
-
describe "#search_field" do
|
175
|
-
it "returns the given block in a search field wrapper" do
|
176
|
-
expect(subject.search_field("foo") { '<block_html>'.html_safe }).to match_html(%Q[
|
177
|
-
<div class="search-field" data-name="foo">
|
178
|
-
<block_html>
|
179
|
-
</div>
|
180
|
-
])
|
181
|
-
end
|
182
|
-
end
|
183
|
-
|
184
|
-
describe "#extra_search_content" do
|
185
|
-
it "returns nil(available for override)" do
|
186
|
-
expect(subject.extra_search_content).to be nil
|
187
|
-
end
|
188
|
-
end
|
189
|
-
|
190
|
-
describe "#extra_search_button" do
|
191
|
-
it "returns extra search button" do
|
192
|
-
allow(subject).to receive(:t).with('Search').and_return("sss")
|
193
|
-
allow(subject).to receive(:t).with('Filter').and_return("fff")
|
194
|
-
allow(subject).to receive(:button)
|
195
|
-
.with("fff", "search", type: "submit", title: 'sss')
|
196
|
-
.and_return("xx")
|
197
|
-
expect(subject.extra_search_button).to eq("xx")
|
198
|
-
end
|
199
|
-
end
|
200
|
-
|
201
|
-
describe "#extra_search_block" do
|
202
|
-
before do
|
203
|
-
allow(subject).to receive(:extra_search_button).and_return("btn")
|
204
|
-
allow(subject).to receive(:extra_search_content).and_return("xx")
|
205
|
-
end
|
206
|
-
|
207
|
-
it "returns extra search block" do
|
208
|
-
expect(subject.extra_search_block).to eq('<div class="extras">xxbtn</div>')
|
209
|
-
end
|
210
|
-
|
211
|
-
it "caches extra search content" do
|
212
|
-
allow(subject).to receive(:extra_search_content).and_return("xx").once
|
213
|
-
subject.extra_search_block
|
214
|
-
subject.extra_search_block
|
215
|
-
end
|
216
|
-
|
217
|
-
context "when extra search content is not present" do
|
218
|
-
it "returns nil" do
|
219
|
-
allow(subject).to receive(:extra_search_content).and_return(nil)
|
220
|
-
expect(subject.extra_search_block).to be nil
|
221
|
-
end
|
222
|
-
end
|
223
|
-
end
|
224
|
-
|
225
|
-
describe "#section_header_text" do
|
226
|
-
it "returns section header text" do
|
227
|
-
allow(subject).to receive(:t).with('All resources').and_return("all")
|
228
|
-
expect(subject.section_header_text).to eq("all")
|
229
|
-
end
|
230
|
-
end
|
231
|
-
|
232
|
-
describe "#section_header_extras" do
|
233
|
-
it "returns true" do
|
234
|
-
allow(subject).to receive(:t)
|
235
|
-
.with("Resources found", count: 0, default: "%{count} resources found", create_plurals: true)
|
236
|
-
.and_return("sss")
|
237
|
-
expect(subject.section_header_extras).to eq('<span class="extras totals only-text">sss</span>')
|
238
|
-
end
|
239
|
-
|
240
|
-
context "when collection does not respond to total_entries" do
|
241
|
-
it "returns nil" do
|
242
|
-
allow(subject).to receive(:collection).and_return(Book.all)
|
243
|
-
expect(subject.section_header_extras).to be nil
|
244
|
-
end
|
245
|
-
end
|
246
|
-
end
|
247
|
-
|
248
|
-
describe "#footer_blocks" do
|
249
|
-
before do
|
250
|
-
allow(subject).to receive(:footer_primary_block).and_return("a")
|
251
|
-
allow(subject).to receive(:pagination_block).and_return("b")
|
252
|
-
allow(subject).to receive(:footer_secondary_block).and_return("c")
|
253
|
-
allow(subject).to receive(:pagination?).and_return(true)
|
254
|
-
end
|
255
|
-
|
256
|
-
it "returns array with footer primary, pagination and secondary blocks" do
|
257
|
-
expect(subject.footer_blocks).to eq(["a", "b", "c"])
|
258
|
-
end
|
259
|
-
|
260
|
-
context "when pagination is not available" do
|
261
|
-
it "does not include pagination block within returned array" do
|
262
|
-
allow(subject).to receive(:pagination?).and_return(false)
|
263
|
-
expect(subject.footer_blocks).to eq(["a", "c"])
|
264
|
-
end
|
265
|
-
end
|
266
|
-
end
|
267
|
-
|
268
|
-
describe "#footer_primary_tools" do
|
269
|
-
before do
|
270
|
-
allow(subject).to receive(:resource_creation_button).and_return("a")
|
271
|
-
allow(subject).to receive(:feature_available?).with(:create).and_return(true)
|
272
|
-
end
|
273
|
-
|
274
|
-
it "returns array with resource creation button" do
|
275
|
-
expect(subject.footer_primary_tools).to eq(["a"])
|
276
|
-
end
|
277
|
-
|
278
|
-
context "when creation feature is not available" do
|
279
|
-
it "returns empty array" do
|
280
|
-
allow(subject).to receive(:feature_available?).with(:create).and_return(false)
|
281
|
-
expect(subject.footer_primary_tools).to eq([])
|
282
|
-
end
|
283
|
-
end
|
284
|
-
end
|
285
|
-
|
286
|
-
describe "#pagination?" do
|
287
|
-
context "when collection responds to `page` method" do
|
288
|
-
it "returns true" do
|
289
|
-
expect(subject.pagination?).to be true
|
290
|
-
end
|
291
|
-
end
|
292
|
-
|
293
|
-
context "when collection does not respond to `page` method" do
|
294
|
-
it "returns false" do
|
295
|
-
allow(subject).to receive(:collection).and_return(Book.all)
|
296
|
-
expect(subject.pagination?).to be true
|
297
|
-
end
|
298
|
-
end
|
299
|
-
end
|
300
|
-
|
301
|
-
describe "#pagination_builder_class" do
|
302
|
-
it "returns a builder class" do
|
303
|
-
expect(subject.pagination_builder_class).to be_a Class
|
304
|
-
end
|
305
|
-
end
|
306
|
-
|
307
|
-
describe "#pagination_block" do
|
308
|
-
|
309
|
-
before do
|
310
|
-
allow(subject).to receive(:params).and_return(page: "2")
|
311
|
-
end
|
312
|
-
|
313
|
-
it "constructs a new pagination builder and returns its output" do
|
314
|
-
builder_args = [ template, { collection: collection, params: { page: "2" } } ]
|
315
|
-
builder = Releaf::Builders::PaginationBuilder.new( *builder_args )
|
316
|
-
|
317
|
-
expect(builder.class).to receive(:new).with( *builder_args ).and_return( builder )
|
318
|
-
expect(builder).to receive(:output).and_return("xx")
|
319
|
-
|
320
|
-
expect(subject.pagination_block).to eq("xx")
|
321
|
-
end
|
322
|
-
|
323
|
-
it "uses pagination builder class" do
|
324
|
-
dummy = double
|
325
|
-
allow(dummy).to receive(:new).and_return(dummy)
|
326
|
-
allow(dummy).to receive(:output).and_return(:ok)
|
327
|
-
expect(subject).to receive(:pagination_builder_class).and_return(dummy)
|
328
|
-
expect( subject.pagination_block).to eq :ok
|
329
|
-
end
|
330
|
-
end
|
331
|
-
|
332
|
-
describe "#resource_creation_button" do
|
333
|
-
it "returns resource creation button" do
|
334
|
-
allow(subject.template).to receive(:url_for).with(controller: "_controller_name_", action: "new").and_return("x")
|
335
|
-
allow(subject).to receive(:t).with('Create new resource').and_return("sss")
|
336
|
-
allow(subject).to receive(:button)
|
337
|
-
.with("sss", "plus", class: "primary", href: "x")
|
338
|
-
.and_return("btn")
|
339
|
-
expect(subject.resource_creation_button).to eq("btn")
|
340
|
-
end
|
341
|
-
end
|
342
|
-
|
343
|
-
describe "#section_body" do
|
344
|
-
it "returns collection table" do
|
345
|
-
allow(template).to receive(:releaf_table)
|
346
|
-
.with(collection, Book, builder: Admin::Books::TableBuilder, toolbox: true)
|
347
|
-
.and_return("xx")
|
348
|
-
expect(subject.section_body).to eq('<div class="body">xx</div>')
|
349
|
-
end
|
350
|
-
end
|
351
|
-
|
352
|
-
describe "#table_options" do
|
353
|
-
it "returns table options" do
|
354
|
-
allow(subject).to receive(:builder_class).with(:table).and_return("CustomTableBuilderClassHere")
|
355
|
-
allow(subject).to receive(:feature_available?).with(:toolbox).and_return("boolean_value_here")
|
356
|
-
|
357
|
-
options = {
|
358
|
-
builder: "CustomTableBuilderClassHere",
|
359
|
-
toolbox: "boolean_value_here"
|
360
|
-
}
|
361
|
-
expect(subject.table_options).to eq(options)
|
362
|
-
end
|
363
|
-
end
|
364
|
-
end
|
@@ -1,65 +0,0 @@
|
|
1
|
-
require "rails_helper"
|
2
|
-
|
3
|
-
describe Releaf::Builders::Page::HeaderBuilder, type: :class do
|
4
|
-
class PageHeaderBuilderTestHelper < ActionView::Base
|
5
|
-
include Rails.application.routes.url_helpers
|
6
|
-
include FontAwesome::Rails::IconHelper
|
7
|
-
|
8
|
-
def protect_against_forgery?
|
9
|
-
true
|
10
|
-
end
|
11
|
-
|
12
|
-
def form_authenticity_token
|
13
|
-
"xxx"
|
14
|
-
end
|
15
|
-
|
16
|
-
def request_forgery_protection_token
|
17
|
-
"yyy"
|
18
|
-
end
|
19
|
-
end
|
20
|
-
|
21
|
-
subject { described_class.new(template) }
|
22
|
-
let(:template){ PageHeaderBuilderTestHelper.new }
|
23
|
-
|
24
|
-
describe "#output" do
|
25
|
-
it "returns safely joined items" do
|
26
|
-
allow(subject).to receive(:items).and_return([ '<', ActiveSupport::SafeBuffer.new(">")])
|
27
|
-
expect(subject.output).to eq("<>")
|
28
|
-
end
|
29
|
-
end
|
30
|
-
|
31
|
-
describe "#items" do
|
32
|
-
it "returns array of home link, profile block and logout form content" do
|
33
|
-
allow(subject).to receive(:home_link).and_return("a")
|
34
|
-
expect(subject.items).to eq(["a"])
|
35
|
-
end
|
36
|
-
end
|
37
|
-
|
38
|
-
describe "#home_link" do
|
39
|
-
it "returns home link with a logo" do
|
40
|
-
allow(subject).to receive(:home_url).and_return("www.xxx")
|
41
|
-
allow(subject).to receive(:home_text).and_return("Rrr")
|
42
|
-
allow(subject).to receive(:home_image_path).and_return("releaf/foo.png")
|
43
|
-
content = '<a class="home" href="www.xxx"><img alt="Rrr" src="/images/releaf/foo.png" /></a>'
|
44
|
-
expect(subject.home_link).to eq(content)
|
45
|
-
end
|
46
|
-
end
|
47
|
-
|
48
|
-
describe "#home_url" do
|
49
|
-
it "returns home url" do
|
50
|
-
expect(subject.home_url).to eq("/admin")
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
describe "#home_image_path" do
|
55
|
-
it "returns image to the logo image asset" do
|
56
|
-
expect(subject.home_image_path).to eq("releaf/logo.png")
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
describe "#home_text" do
|
61
|
-
it "returns releaf home link text" do
|
62
|
-
expect(subject.home_text).to eq("Releaf")
|
63
|
-
end
|
64
|
-
end
|
65
|
-
end
|
@@ -1,237 +0,0 @@
|
|
1
|
-
require "rails_helper"
|
2
|
-
|
3
|
-
describe Releaf::Builders::Page::LayoutBuilder, type: :class do
|
4
|
-
class DummyBuilder
|
5
|
-
include Releaf::Builders::Base
|
6
|
-
include Releaf::Builders::Template
|
7
|
-
def output; end
|
8
|
-
end
|
9
|
-
|
10
|
-
class DummyAssetsResolver
|
11
|
-
def self.controller_assets(_a, _b); end
|
12
|
-
end
|
13
|
-
|
14
|
-
class PageHeaderBuilderTestHelper < ActionView::Base
|
15
|
-
include Rails.application.routes.url_helpers
|
16
|
-
include FontAwesome::Rails::IconHelper
|
17
|
-
|
18
|
-
def protect_against_forgery?
|
19
|
-
true
|
20
|
-
end
|
21
|
-
|
22
|
-
def form_authenticity_token
|
23
|
-
"xxx"
|
24
|
-
end
|
25
|
-
|
26
|
-
def request_forgery_protection_token
|
27
|
-
"yyy"
|
28
|
-
end
|
29
|
-
end
|
30
|
-
|
31
|
-
class NewRolesController < Releaf::Permissions::RolesController
|
32
|
-
end
|
33
|
-
|
34
|
-
subject { described_class.new(template) }
|
35
|
-
let(:template){ PageHeaderBuilderTestHelper.new }
|
36
|
-
|
37
|
-
describe "#controller_classes" do
|
38
|
-
it "returns array of ignorable ancester classes" do
|
39
|
-
allow(subject).to receive(:controller).and_return(NewRolesController.new)
|
40
|
-
expect(subject.controller_classes).to eq([Releaf::Permissions::RolesController, NewRolesController])
|
41
|
-
|
42
|
-
allow(subject).to receive(:controller).and_return(Releaf::Permissions::RolesController.new)
|
43
|
-
expect(subject.controller_classes).to eq([Releaf::Permissions::RolesController])
|
44
|
-
|
45
|
-
allow(subject).to receive(:controller).and_return(Releaf::Permissions::SessionsController.new)
|
46
|
-
expect(subject.controller_classes).to eq([Releaf::Permissions::SessionsController])
|
47
|
-
end
|
48
|
-
end
|
49
|
-
|
50
|
-
describe "#features" do
|
51
|
-
it "returns controller layout features" do
|
52
|
-
allow(subject).to receive(:controller).and_return(NewRolesController.new)
|
53
|
-
allow(subject.controller).to receive(:layout_features).and_return([:a, :c])
|
54
|
-
expect(subject.features).to eq([:a, :c])
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
|
-
describe "#header_builder" do
|
59
|
-
it "returns `Releaf::Builders::Page::HeaderBuilder` class" do
|
60
|
-
expect(subject.header_builder).to eq(Releaf::Builders::Page::HeaderBuilder)
|
61
|
-
end
|
62
|
-
end
|
63
|
-
|
64
|
-
describe "#assets_resolver" do
|
65
|
-
it "returns `Releaf::AssetsResolver` class" do
|
66
|
-
expect(subject.assets_resolver).to eq(Releaf::AssetsResolver)
|
67
|
-
end
|
68
|
-
end
|
69
|
-
|
70
|
-
describe "#feature_available?" do
|
71
|
-
before do
|
72
|
-
allow(subject).to receive(:features).and_return([:a, :b])
|
73
|
-
end
|
74
|
-
|
75
|
-
it "returns true when feature is available" do
|
76
|
-
expect(subject.feature_available?(:a)).to be true
|
77
|
-
end
|
78
|
-
|
79
|
-
it "returns false when feature is not available" do
|
80
|
-
expect(subject.feature_available?(:c)).to be false
|
81
|
-
end
|
82
|
-
end
|
83
|
-
|
84
|
-
describe "#stylesheets" do
|
85
|
-
it "returns stylesheets from assets resolver for given controller" do
|
86
|
-
allow(subject).to receive(:assets_resolver).and_return(DummyAssetsResolver)
|
87
|
-
allow(subject).to receive(:controller_name).and_return("_controller")
|
88
|
-
allow(DummyAssetsResolver).to receive(:controller_assets).with("_controller", :stylesheets)
|
89
|
-
.and_return("x")
|
90
|
-
expect(subject.stylesheets).to eq("x")
|
91
|
-
end
|
92
|
-
end
|
93
|
-
|
94
|
-
describe "#javascripts" do
|
95
|
-
it "returns javascripts from assets resolver for given controller" do
|
96
|
-
allow(subject).to receive(:assets_resolver).and_return(DummyAssetsResolver)
|
97
|
-
allow(subject).to receive(:controller_name).and_return("_controller")
|
98
|
-
allow(DummyAssetsResolver).to receive(:controller_assets).with("_controller", :javascripts)
|
99
|
-
.and_return("y")
|
100
|
-
expect(subject.javascripts).to eq("y")
|
101
|
-
end
|
102
|
-
end
|
103
|
-
|
104
|
-
describe "#header" do
|
105
|
-
it "returns menu builder output wrapped within `aside` tag" do
|
106
|
-
menu_builder = DummyBuilder.new(template)
|
107
|
-
allow(menu_builder).to receive(:output).and_return("_header")
|
108
|
-
allow(DummyBuilder).to receive(:new).with(template).and_return(menu_builder)
|
109
|
-
allow(subject).to receive(:header_builder).and_return(DummyBuilder)
|
110
|
-
allow(subject).to receive(:tag).with(:header, "_header").and_return("<_header>")
|
111
|
-
|
112
|
-
expect(subject.header).to eq("<_header>")
|
113
|
-
end
|
114
|
-
end
|
115
|
-
|
116
|
-
describe "#menu" do
|
117
|
-
it "returns menu builder output wrapped within `aside` tag" do
|
118
|
-
menu_builder = DummyBuilder.new(template)
|
119
|
-
allow(menu_builder).to receive(:output).and_return("_menu")
|
120
|
-
allow(DummyBuilder).to receive(:new).with(template).and_return(menu_builder)
|
121
|
-
allow(subject).to receive(:menu_builder).and_return(DummyBuilder)
|
122
|
-
allow(subject).to receive(:tag).with(:aside, "_menu").and_return("<_menu>")
|
123
|
-
|
124
|
-
expect(subject.menu).to eq("<_menu>")
|
125
|
-
end
|
126
|
-
end
|
127
|
-
|
128
|
-
describe "#menu_builder" do
|
129
|
-
it "returns `Releaf::Builders::Page::MenuBuilder` class" do
|
130
|
-
expect(subject.menu_builder).to eq(Releaf::Builders::Page::MenuBuilder)
|
131
|
-
end
|
132
|
-
end
|
133
|
-
|
134
|
-
describe "#body" do
|
135
|
-
it "returns body with body attributes and" do
|
136
|
-
allow(subject).to receive(:body_atttributes).and_return(class: ["xx", "y"], id: "121212")
|
137
|
-
allow(subject).to receive(:body_content_blocks){|*args, &block| expect(block.call).to eq("x") }
|
138
|
-
.and_return(["a<b>".html_safe, "b<i>", "c<d>".html_safe])
|
139
|
-
expect(subject.body{ "x" }).to eq("<body class=\"xx y\" id=\"121212\">a<b>b<i>c<d></body>")
|
140
|
-
end
|
141
|
-
end
|
142
|
-
|
143
|
-
#parts = []
|
144
|
-
#parts << header if feature_available?(:header)
|
145
|
-
#parts << menu if feature_available?(:sidebar)
|
146
|
-
#parts << tag(:main, id: "main"){ yield } if feature_available?(:main)
|
147
|
-
#parts << notifications
|
148
|
-
#parts << assets(:javascripts, :javascript_include_tag)
|
149
|
-
#parts
|
150
|
-
|
151
|
-
|
152
|
-
describe "#body_content_blocks" do
|
153
|
-
before do
|
154
|
-
allow(subject).to receive(:feature_available?).with(:header).and_return(true)
|
155
|
-
allow(subject).to receive(:feature_available?).with(:sidebar).and_return(true)
|
156
|
-
allow(subject).to receive(:feature_available?).with(:main).and_return(true)
|
157
|
-
|
158
|
-
allow(subject).to receive(:assets).with(:javascripts, :javascript_include_tag).and_return("_assets_")
|
159
|
-
allow(subject).to receive(:header).and_return("_header_")
|
160
|
-
allow(subject).to receive(:menu).and_return("_menu_")
|
161
|
-
allow(subject).to receive(:notifications).and_return("_notifications_")
|
162
|
-
allow(subject).to receive(:tag).with(:main, id: :main){|*args, &block| expect(block.call).to eq("x") }.and_return("body content")
|
163
|
-
end
|
164
|
-
|
165
|
-
it "returns body with body attributes and" do
|
166
|
-
expect(subject.body_content_blocks{ "x" }).to eq(["_header_", "_menu_", "body content", "_notifications_", "_assets_"])
|
167
|
-
end
|
168
|
-
|
169
|
-
it "skips header when header feature not available" do
|
170
|
-
allow(subject).to receive(:feature_available?).with(:header).and_return(false)
|
171
|
-
expect(subject.body_content_blocks{ "x" }).to eq(["_menu_", "body content", "_notifications_", "_assets_"])
|
172
|
-
end
|
173
|
-
|
174
|
-
it "skips menu when sidebar feature not available" do
|
175
|
-
allow(subject).to receive(:feature_available?).with(:sidebar).and_return(false)
|
176
|
-
expect(subject.body_content_blocks{ "x" }).to eq(["_header_", "body content", "_notifications_", "_assets_"])
|
177
|
-
end
|
178
|
-
|
179
|
-
it "skips main conrtent when main feature not available" do
|
180
|
-
allow(subject).to receive(:feature_available?).with(:main).and_return(false)
|
181
|
-
expect(subject.body_content_blocks{ "x" }).to eq(["_header_", "_menu_", "_notifications_", "_assets_"])
|
182
|
-
end
|
183
|
-
end
|
184
|
-
|
185
|
-
describe "#controller_body_classes" do
|
186
|
-
it "returns normalized html classes from controller classes" do
|
187
|
-
allow(subject).to receive(:controller_classes).and_return([Releaf::ActionController, Releaf::Permissions::RolesController])
|
188
|
-
expect(subject.controller_body_classes).to eq(["controller-releaf-action", "controller-releaf-permissions-roles"])
|
189
|
-
end
|
190
|
-
end
|
191
|
-
|
192
|
-
describe "#settings_path" do
|
193
|
-
it "returns root controller settings path" do
|
194
|
-
allow(subject).to receive(:url_for).with(action: "store_settings", controller: "/releaf/root", only_path: true)
|
195
|
-
.and_return("asdasdasd")
|
196
|
-
expect(subject.settings_path).to eq("asdasdasd")
|
197
|
-
end
|
198
|
-
end
|
199
|
-
|
200
|
-
describe "#body_atttributes" do
|
201
|
-
it "returns hash with classes, data-settings-path and data-layout-features" do
|
202
|
-
allow(subject).to receive(:features).and_return([:top, :bottom])
|
203
|
-
allow(subject).to receive(:controller_body_classes).and_return(["a", "b"])
|
204
|
-
allow(subject).to receive(:settings_path).and_return("/xxx/sett")
|
205
|
-
expect(subject.body_atttributes).to eq(class: ["application-dummy", "a", "b"],
|
206
|
-
"data-settings-path" => "/xxx/sett",
|
207
|
-
"data-layout-features" => "top bottom")
|
208
|
-
end
|
209
|
-
end
|
210
|
-
|
211
|
-
describe "#head_blocks" do
|
212
|
-
it "returns array" do
|
213
|
-
{
|
214
|
-
title: :title_sym,
|
215
|
-
meta: :meta_sym,
|
216
|
-
favicons: :favicon_sym,
|
217
|
-
ms_tile: :ms_tile_sym,
|
218
|
-
assets: :assets_sym,
|
219
|
-
csrf: :csrf_sym,
|
220
|
-
}.each_pair do |method, stub_answer|
|
221
|
-
allow(subject).to receive(method).and_return stub_answer
|
222
|
-
end
|
223
|
-
|
224
|
-
expect(subject.head_blocks).to match_array(
|
225
|
-
[
|
226
|
-
:title_sym,
|
227
|
-
:meta_sym,
|
228
|
-
:favicon_sym,
|
229
|
-
:ms_tile_sym,
|
230
|
-
:assets_sym,
|
231
|
-
:csrf_sym,
|
232
|
-
]
|
233
|
-
)
|
234
|
-
end
|
235
|
-
end
|
236
|
-
end
|
237
|
-
|