From 9579d38d6abef4c03fc2dc8d8d0fd5c26395bbb2 Mon Sep 17 00:00:00 2001 From: SimonLab Date: Tue, 5 Feb 2019 10:22:14 +0000 Subject: [PATCH] keeps inserted_at value on update, #30 --- lib/alog.ex | 22 ---------------------- mix.exs | 2 +- 2 files changed, 1 insertion(+), 23 deletions(-) diff --git a/lib/alog.ex b/lib/alog.ex index 31244a8..a06f9a9 100644 --- a/lib/alog.ex +++ b/lib/alog.ex @@ -204,7 +204,6 @@ defmodule Alog do |> Map.get(:data) |> @repo.preload(__MODULE__.__schema__(:associations)) |> Map.put(:id, nil) - |> Map.put(:inserted_at, nil) |> Map.put(:updated_at, nil) changeset @@ -243,19 +242,6 @@ defmodule Alog do User.all() """ def all do - # get the oldest items - sub = - from(m in __MODULE__, - distinct: m.entry_id, - order_by: [asc: :inserted_at], - select: m - ) - - query = from(m in subquery(sub), where: not m.deleted, select: m) - - oldest_items = @repo.all(query) - - # get the most recent inserted items, ie desc: :inserted_at sub = from(m in __MODULE__, distinct: m.entry_id, @@ -266,14 +252,6 @@ defmodule Alog do query = from(m in subquery(sub), where: not m.deleted, select: m) @repo.all(query) - |> Enum.map(fn(newest_item) -> - oldest_item = Enum.find(oldest_items, &(&1.entry_id == newest_item.entry_id)) - if oldest_item do - %{newest_item | inserted_at: oldest_item.inserted_at} - else - newest_item - end - end) end @doc """ diff --git a/mix.exs b/mix.exs index b7e96a5..06d677b 100644 --- a/mix.exs +++ b/mix.exs @@ -4,7 +4,7 @@ defmodule Alog.MixProject do def project do [ app: :alog, - version: "0.4.2", + version: "0.4.3", elixir: "~> 1.7", elixirc_paths: elixirc_paths(Mix.env()), start_permanent: Mix.env() == :prod,