resolv.ex (3221B)
1 # Zenflows is designed to implement the Valueflows vocabulary, 2 # written and maintained by srfsh <info@dyne.org>. 3 # Copyright (C) 2021-2023 Dyne.org foundation <foundation@dyne.org>. 4 # 5 # This program is free software: you can redistribute it and/or modify 6 # it under the terms of the GNU Affero General Public License as published by 7 # the Free Software Foundation, either version 3 of the License, or 8 # (at your option) any later version. 9 # 10 # This program is distributed in the hope that it will be useful, 11 # but WITHOUT ANY WARRANTY; without even the implied warranty of 12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 # GNU Affero General Public License for more details. 14 # 15 # You should have received a copy of the GNU Affero General Public License 16 # along with this program. If not, see <https://www.gnu.org/licenses/>. 17 18 defmodule Zenflows.VF.EconomicResource.Resolv do 19 @moduledoc false 20 21 use Absinthe.Schema.Notation 22 23 alias Zenflows.GQL.Connection 24 alias Zenflows.VF.EconomicResource.Domain 25 26 def economic_resource(params, _) do 27 Domain.one(params) 28 end 29 30 def economic_resources(params, _) do 31 with {:ok, page} <- Connection.parse(params), 32 {:ok, schemas} <- Domain.all(page) do 33 {:ok, Connection.from_list(schemas, page)} 34 end 35 end 36 37 def economic_resource_classifications(_, _) do 38 {:ok, Domain.classifications()} 39 end 40 41 def update_economic_resource(%{resource: %{id: id} = params}, _) do 42 with {:ok, eco_res} <- Domain.update(id, params) do 43 {:ok, %{economic_resource: eco_res}} 44 end 45 end 46 47 def delete_economic_resource(%{id: id}, _) do 48 with {:ok, _} <- Domain.delete(id) do 49 {:ok, true} 50 end 51 end 52 53 def images(eco_res, _, _) do 54 eco_res = Domain.preload(eco_res, :images) 55 {:ok, eco_res.images} 56 end 57 58 def conforms_to(eco_res, _, _) do 59 eco_res = Domain.preload(eco_res, :conforms_to) 60 {:ok, eco_res.conforms_to} 61 end 62 63 def accounting_quantity(eco_res, _, _) do 64 eco_res = Domain.preload(eco_res, :accounting_quantity) 65 {:ok, eco_res.accounting_quantity} 66 end 67 68 def onhand_quantity(eco_res, _, _) do 69 eco_res = Domain.preload(eco_res, :onhand_quantity) 70 {:ok, eco_res.onhand_quantity} 71 end 72 73 def primary_accountable(eco_res, _, _) do 74 eco_res = Domain.preload(eco_res, :primary_accountable) 75 {:ok, eco_res.primary_accountable} 76 end 77 78 def custodian(eco_res, _, _) do 79 eco_res = Domain.preload(eco_res, :custodian) 80 {:ok, eco_res.custodian} 81 end 82 83 def stage(eco_res, _, _) do 84 eco_res = Domain.preload(eco_res, :stage) 85 {:ok, eco_res.stage} 86 end 87 88 def state(eco_res, _, _) do 89 eco_res = Domain.preload(eco_res, :state) 90 {:ok, eco_res.state} 91 end 92 93 def current_location(eco_res, _, _) do 94 eco_res = Domain.preload(eco_res, :current_location) 95 {:ok, eco_res.current_location} 96 end 97 98 def lot(eco_res, _, _) do 99 eco_res = Domain.preload(eco_res, :lot) 100 {:ok, eco_res.lot} 101 end 102 103 def contained_in(eco_res, _, _) do 104 eco_res = Domain.preload(eco_res, :contained_in) 105 {:ok, eco_res.contained_in} 106 end 107 108 def unit_of_effort(eco_res, _, _) do 109 eco_res = Domain.preload(eco_res, :unit_of_effort) 110 {:ok, eco_res.unit_of_effort} 111 end 112 113 def previous(eco_res, _, _) do 114 {:ok, Domain.previous(eco_res)} 115 end 116 117 def trace(eco_res, _, _) do 118 {:ok, Domain.trace(eco_res)} 119 end 120 121 def trace_dpp(eco_res, _, _) do 122 {:ok, Domain.trace_dpp(eco_res)} 123 end 124 end