Mongoid не обновляет поле позиции - PullRequest
0 голосов
/ 24 января 2019

Я хочу иметь возможность обновлять поле Attachinary :: File position

Я использую ruby ​​2.5.0, rails 5.2.2, mongoid, 'jquery-ui-rails' и custom Attachinary (https://github.com/ipatovanton/attachinary/tree/position) для загрузки изображений.

application.js

jQuery(function() {
  $(document).on('turbolinks:load', function(){
    $('.attachinary-input').attachinary()

    $("#images").sortable({
      update: function(e, ui) {
        Rails.ajax({
          url: $(this).data("url"),
          type: "PATCH",
          data: $(this).sortable('serialize'),
        });
      }
    });
  });
})

rout.rb

resources :projects do
    collection do
      patch :sort
    end
end

project.rb

class Project
  include Mongoid::Document

  has_attachments :images
end

show.html.erb

<div id="images" class="grid" data-url="<%= sort_projects_path %>">
  <% @project.images.order(position: :desc).each do |image| %>
    <div id="image_<%= image.id %>" class="box">
      <div class="box-image">
        <%= cl_image_tag(image.path, width: '250', height: '250', crop: 'thumb') %>
      </div>
    </div>
  <% end %>
</div>

projects_controller.rb

class ProjectsController < ApplicationController
  def sort
    params[:image].each_with_index do |id, index|
      Attachinary::File.where(id: id).update_all(position: index + 1)
    end
    head :ok
  end
end

Когда я пытаюсь перетащить изображение, я получаю следующее сообщение.Но позиция не обновляется:

Запущен PATCH "/ projects / sort" для 127.0.0.1 в 2019-01-23 18:19:46 +0300 Обработка в ProjectsController # sort as / Параметры: { "образ" => [ "5c4827691996da1fef832f5d", "5c4827691996da1fef832f6e", "5c4827691996da1fef832f5e", "5c4827691996da1fef832f5f", "5c4827691996da1fef832f60", "5c4827691996da1fef832f61", "5c4827691996da1fef832f62", "5c4827691996da1fef832f63", "5c4827691996da1fef832f64",«5c4827691996da1fef832f65», «5c4827691996da1fef832f66», «5c4827691996da1fef832f67»,"5c4827691996da1fef832f68", "5c4827691996da1fef832f69", "5c4827691996da1fef832f6a", "5c4827691996da1fef832f6b", "5c4827691996da1fef832f6c", "5c4827691996da1fef832f6d", "5c4827691996da1fef832f5c"]} MongoDB |localhost: 27017 |squarely_development.find |НАЧАЛО |{"find" => "users", "filter" => {"_ id" => BSON :: ObjectId ('5c472c2e1996da1d037f57fb')}, "sort" => {"_ id" => 1}, "limit" => 1, "singleBatch" => true, "lsid" => {"id" =>}} MONGODB |localhost: 27017 |squarely_development.find |УСПЕШНО |0.001s Выполнено 200 OK за 6 мс

Если я использую ActiveRecord и gem 'pg', все работает

Но мне нужно это решение для работы с Mongodb

Любой, у кого естькакие-нибудь мысли или идеи по этому поводу?

Спасибо

1 Ответ

0 голосов
/ 05 марта 2019

Прежде всего, похоже, что вы пытаетесь отсортировать изображения проекта.

Если это так, тогда я предлагаю перенести этот маршрут на член, а не на коллекцию.

Это означает, что вам нужно будет добавить sort_project_path(@project).Это может упростить нашу жизнь, если вы извлекаете изображения так же, как вы обращаетесь к ним.

class ProjectsController < ApplicationController
  before_action :set_project # You may already have that

  def sort
    params[:image].each_with_index do |id, index|
      @project.images.where(id: id).update_all(position: index + 1)
    end
    head :ok
  end

  def set_project
    @project = Project.find(params[:id])
  end
end

Надеюсь, это сработает для вас.

...