рд▓реЗрдЦ рдХреЗ
рдкрд╣рд▓реЗ рднрд╛рдЧ рдореЗрдВ, рд╣рдордиреЗ рдПрдХ REST рдПрдкреНрд▓рд┐рдХреЗрд╢рди рд▓рд┐рдЦрд╛ рдФрд░ Redactor.js 1/3 рдХреЛ рдХреЙрдиреНрдлрд╝рд┐рдЧрд░ рдХрд┐рдпрд╛ред рдЖрдЬ рд╣рдо рдЕрдкрд▓реЛрдб рдХреА рдЧрдИ рдЫрд╡рд┐рдпреЛрдВ рдХреЛ рдкреНрд░рдмрдВрдзрд┐рдд рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП рдПрдХ рдЗрдВрдЯрд░рдлрд╝реЗрд╕ рд▓рд┐рдЦрдХрд░ рдЕрдкрдирд╛ рдЖрд╡рд┐рд╖реНрдХрд╛рд░ рдкреВрд░рд╛ рдХрд░реЗрдВрдЧреЗ, рдФрд░ рд╣рдо рдлрд╝рд╛рдЗрд▓ рдбрд╛рдЙрдирд▓реЛрдб рдкреНрд░рджрд╛рди рдХрд░реЗрдВрдЧреЗред рдлрд╝рд╛рдЗрд▓реЛрдВ рдХреЛ рдбрд╛рдЙрдирд▓реЛрдб рдХрд░рддреЗ рд╕рдордп, рд╣рдо рдХреИрд░рд┐рдпрд░рд╡реЗ рдХрд╛ рдЙрдкрдпреЛрдЧ рдирд╣реАрдВ рдХрд░реЗрдВрдЧреЗ, рдмрд▓реНрдХрд┐, рд╣рдо рд╕рд╛рдорд╛рдиреНрдп рд░реВрдмреА рдкрде рдХрд╛ рдкрд╛рд▓рди рдХрд░реЗрдВрдЧреЗред
рдЪрд▓рд┐рдП рдлрд╛рдЗрд▓ рдЕрдкрд▓реЛрдб рдХрд░рдХреЗ рд╢реБрд░реВ рдХрд░рддреЗ рд╣реИрдВред рдореБрдЭреЗ рд▓рдЧрддрд╛ рд╣реИ рдХрд┐ рдЕрдм рдЖрдкрдХреЗ рдкрд╛рд╕ рдРрд╕реА init.rb рдлрд╝рд╛рдЗрд▓ рд╣реИ:
рдЗрд╕рд▓рд┐рдП, рд╕рд╛рд░реНрд╡рдЬрдирд┐рдХ / рдЕрдкрд▓реЛрдб рдирд┐рд░реНрджреЗрд╢рд┐рдХрд╛ рдореЗрдВ рдлрд╝рд╛рдЗрд▓реЗрдВ рдлрд╝реЛрд▓реНрдбрд░ рдмрдирд╛рдПрдБ, рдПрдХ рдирдпрд╛ UploadedFiles рдореЙрдбрд▓ рд▓рд┐рдЦреЗрдВ рдФрд░ рдлрд╝рд╛рдЗрд▓реЛрдВ рдХреЛ рдЕрдкрд▓реЛрдб рдХрд░рдиреЗ рдХреЗ рд▓рд┐рдП рдкреЛрд╕реНрдЯ рд╡рд┐рдзрд┐ рдЬреЛрдбрд╝реЗрдВ
set :files, File.join(settings.public_directory, 'uploads/files')
рдЕрдм рдпрд╣ рд╕рдВрдкрд╛рджрдХ рдХреЛ рдмрддрд╛рдиреЗ рдХреЗ рд▓рд┐рдП рд░рд╣рддрд╛ рд╣реИ рдХрд┐ рдлрд╝рд╛рдЗрд▓реЛрдВ рдХреЛ рдХреИрд╕реЗ рдЕрдкрд▓реЛрдб рдХрд┐рдпрд╛ рдЬрд╛рдП, рд▓реЗрдЖрдЙрдЯ рдХреЛ рдЦреЛрд▓реЗрдВ
$('.redactor_1').redactor({toolbar: 'default', lang: 'ru', imageUpload: '/upload/image', imageGetJson: '/uploads/images/imageslist.json'});
рдЗрд╕ рддрд░рд╣
рджрд┐рдЦрдиреЗ рдХреЗ рд▓рд┐рдП
рдлрд╛рдЗрд▓рдЕрдк рд▓реЛрдбрд┐рдВрдЧ рд╕реЗрдЯрд┐рдВрдЧ
: '/ рдЕрдкрд▓реЛрдб / рдлрд╛рдЗрд▓' рдЬреЛрдбрд╝реЗрдВ
$('.redactor_1').redactor({toolbar: 'default', lang: 'ru', imageUpload: '/upload/image', fileUpload: '/upload/file', imageGetJson: '/uploads/images/imageslist.json'});
рд╣рдордиреЗ рд╕рднреА рдЖрд╡рд╢реНрдпрдХ рд╕реЗрдЯрд┐рдВрдЧреНрд╕ рдмрдирд╛рдИрдВ: рдПрдХ рдореЙрдбрд▓ рдмрдирд╛рдпрд╛, рдбрд╛рдЙрдирд▓реЛрдб рдХреА рдЧрдИ рдлрд╝рд╛рдЗрд▓реЛрдВ рдХреЗ рд▓рд┐рдП рдкрде рдХреЛ рдХреЙрдиреНрдлрд╝рд┐рдЧрд░ рдХрд┐рдпрд╛, рд╡рд╛рд╕реНрддрд╡ рдореЗрдВ рдлрд╝рд╛рдЗрд▓ рдбрд╛рдЙрдирд▓реЛрдб рдХреЛ рд▓рд╛рдЧреВ рдХрд┐рдпрд╛, рдЕрдиреБрдордд рдлрд╝рд╛рдЗрд▓реЛрдВ рдХреЗ рд▓рд┐рдП рдПрдХ рдЪреЗрдХ рдмрдирд╛рдпрд╛ред рдпрд╣рд╛рдВ рдореИрдВ рдзреНрдпрд╛рди рджреЗрдирд╛ рдЪрд╛рд╣реВрдВрдЧрд╛, рдПрдХ рддреНрд░реБрдЯрд┐ рд╕рдВрджреЗрд╢ рд▓рд╛рдЧреВ рдХрд░рдирд╛ рдЕрдЪреНрдЫрд╛ рд╣реЛрдЧрд╛ рдпрджрд┐ рдлрд╝рд╛рдЗрд▓ рдПрдХреНрд╕рдЯреЗрдВрд╢рди рдЕрдиреБрдордд рдПрдХ рд╕реЗ рдореЗрд▓ рдирд╣реАрдВ рдЦрд╛рддрд╛ рд╣реИ, рд▓реЗрдХрд┐рди 2 рдмрдЯрди рд╣реИрдВ: рд╕рдмрд╕реЗ рдкрд╣рд▓реЗ, Redactor.js рдлреНрд░реЗрдо рдореЗрдВ рд╕рдм рдХреБрдЫ рдХрд░рддрд╛ рд╣реИ рдФрд░ рдпрджрд┐ рдЖрдк рдПрдХ рддреНрд░реБрдЯрд┐ рд╕рдВрджреЗрд╢ рдмрдирд╛рддреЗ рд╣реИрдВ, рддреЛ рдпрд╣ рд▓рд┐рдЦрд╛ рдЬрд╛рдПрдЧрд╛ textarea рдореЗрдВ, рдЬреЛ, рдореЗрд░реА рд░рд╛рдп рдореЗрдВ, рдПрдХ рдЕрдЪреНрдЫрд╛ рд╡рд┐рдЪрд╛рд░ рдирд╣реАрдВ рд╣реИ, рдпрджрд┐ рдЖрдк рдордгрд┐ рд╕рд┐рдирдЯреНрд░рд╛-рдлреНрд▓реИрд╢ рдХреЗ рдорд╛рдзреНрдпрдо рд╕реЗ рддреНрд░реБрдЯрд┐ рд╕рдВрджреЗрд╢ рдХреЛ рд▓рд╛рдЧреВ рдХрд░рдиреЗ рдХрд╛ рдкреНрд░рдпрд╛рд╕ рдХрд░рддреЗ рд╣реИрдВ, рддреЛ рдлрд┐рд░ рд╕реЗ рдпрд╣ рдПрдХ рд╡рд┐рдХрд▓реНрдк рдирд╣реАрдВ рд╣реИ, рдХреНрдпреЛрдВрдХрд┐ рдкреГрд╖реНрда рд░реАрд▓реЛрдб рдХрд┐рдП рдЬрд╛рдиреЗ рдХреЗ рдмрд╛рдж рд╣реА рддреНрд░реБрдЯрд┐ рджрд┐рдЦрд╛рдИ рджреЗрдЧреАред рдЦреИрд░, рд╢рд╛рдпрдж рдЕрдзрд┐рдХ рдЕрдиреБрднрд╡реА рд▓реЛрдЧ рдЖрдкрдХреЛ рдмрддрд╛рдПрдВрдЧреЗ рдХрд┐ рдХрд┐рд╕ рддрд░рд╣ рд╕реЗ рдЦреБрджрд╛рдИ рдХрд░рдирд╛ рд╣реИред
рдЕрдм рдбрд╛рдЙрдирд▓реЛрдб рдХрд┐рдП рдЧрдП рдЪрд┐рддреНрд░реЛрдВ рдХреЛ рдкреНрд░рдмрдВрдзрд┐рдд рдХрд░рдирд╛ рд╢реБрд░реВ рдХрд░рддреЗ рд╣реИрдВ, рдЬреЛ рд╣рдо рдХрд░реЗрдВрдЧреЗ рд╡рд╣ рд╕рднреА рдбрд╛рдЙрдирд▓реЛрдб рдХреА рдЧрдИ рдЫрд╡рд┐рдпреЛрдВ рдХреА рд╕реВрдЪреА рд╣реИ рдФрд░ рдЙрдиреНрд╣реЗрдВ рд╣рдЯрд╛ рджреЗрдВред
Init.rb рдореЗрдВ рдЬреЛрдбрд╝реЗрдВ
рджреГрд╢реНрдп рдирд┐рд░реНрджреЗрд╢рд┐рдХрд╛ рдореЗрдВ images.erb рдлрд╝рд╛рдЗрд▓ рдмрдирд╛рдПрдБ
<strong><a href="/posts"> post'</a></strong> <h2> </h2> <% @ uploadedimage.each do |uploadedimages| %> <a href="<%= uploadedimages.image %>"><img src="<%= uploadedimages.thumb %>"></a><br> # <a href="/images/<%= uploadedimages.id %>/delete"></a><br><br> <% end %>
рдЦреИрд░, рд╣рдордиреЗ рдЕрдкрдирд╛ рдЖрд╡реЗрджрди рд╕рдорд╛рдкреНрдд рдХрд░ рджрд┐рдпрд╛ рд╣реИред рдЫрд╡рд┐ рдкреНрд░рдмрдВрдзрди рдХреЗ рд╕рд╛рде рд╕рд╛рджреГрд╢реНрдп рджреНрд╡рд╛рд░рд╛, рдлрд╝рд╛рдЗрд▓ рдкреНрд░рдмрдВрдзрди рднреА рдХрд┐рдпрд╛ рдЬрд╛ рд╕рдХрддрд╛ рд╣реИред рдореБрдЭреЗ рд▓рдЧрддрд╛ рд╣реИ рдХрд┐ рдпрд╣ рдмрд╣реБрдд рдЕрдЪреНрдЫреА рддрд░рд╣ рд╕реЗ рдирд┐рдХрд▓рд╛ред рдФрд░ рдпрд╣ рдЕрдВрдд рдирд╣реАрдВ рд╣реИ, рдореИрдВ рд░реВрдмреА рдФрд░ рд╕рд┐рдирд╛рддреНрд░рд╛ рдХрд╛ рдЕрдзреНрдпрдпрди рдХрд░рдирд╛ рдЬрд╛рд░реА рд░рдЦрддрд╛ рд╣реВрдВ рдФрд░ рдЕрдзрд┐рдХ рд▓реЗрдЦ рд╣реЛрдВрдЧреЗред
рдЬреАрдереБрдм рд╕реНрд░реЛрдд рдХреЛрдб
рдкреБрдирд╢реНрдЪ: рд╣рд░ рдЬрдЧрд╣ рдореИрдВ рднрд░ рдЖрдпрд╛
<hh user=posts>
рдпрд╛
<hh user=images>
рд╕рд┐рд░реНрдл @variable_name рдХреЗ рд╕рд╛рде рдмрджрд▓реЗрдВ