2019-07-30 21:29:24 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-25 16:15:39 +00:00
|
|
|
# License: AGPL-3.0-or-later WITH Web-Template-Output-Additional-Permission-3.0-or-later
|
2018-03-25 17:30:42 +00:00
|
|
|
require 'qx'
|
|
|
|
|
|
|
|
module UpdateOrder
|
|
|
|
# data is an array of hashes of:
|
|
|
|
# - id : id of row to update
|
2019-07-30 21:29:24 +00:00
|
|
|
# - order: new order of row to update
|
2018-03-25 17:30:42 +00:00
|
|
|
def self.with_data(table_name, data)
|
2019-07-30 21:29:24 +00:00
|
|
|
vals = data.map { |h| "(#{h[:id].to_i}, #{h[:order].to_i})" }.join(', ')
|
2018-03-25 17:30:42 +00:00
|
|
|
from_str = "(VALUES #{vals}) AS data(id, \"order\")"
|
2019-07-30 21:29:24 +00:00
|
|
|
Qx.update(table_name.to_s)
|
2018-03-25 17:30:42 +00:00
|
|
|
.set('"order"="data"."order"')
|
|
|
|
.timestamps
|
|
|
|
.from(from_str)
|
|
|
|
.where("data.id=#{table_name}.id")
|
|
|
|
.returning("#{table_name}.order", "#{table_name}.id")
|
|
|
|
.execute
|
|
|
|
end
|
|
|
|
end
|