366 lines
12 KiB
HTML
366 lines
12 KiB
HTML
{{* -*- brindille -*- *}}
|
|
|
|
{{:admin_header title="Liste des amortissements" custom_css="./style.css" current="module_amortissement"}}
|
|
|
|
{{* barre de navigation *}}
|
|
{{:include file="_nav.html" current="amortization"}}
|
|
|
|
{{if $_GET.ok}}
|
|
{{if $_GET.msg|match:"attach"}}
|
|
{{:assign msg="Attachement effectué"}}
|
|
{{elseif $_GET.msg|match:"detach"}}
|
|
{{:assign msg="Attachement supprimé"}}
|
|
{{elseif $_GET.msg|match:"amortissement"}}
|
|
{{:assign msg="Amortissement enregistré"}}
|
|
{{/if}}
|
|
<p class="block confirm">{{$msg}}</p>
|
|
{{elseif $_GET.err}}
|
|
{{if $_GET.msg|match:"attach"}}
|
|
{{:assign msg="Échec attachement"}}
|
|
{{elseif $_GET.msg|match:"amortissement"}}
|
|
{{:assign msg="Échec enregistrement amortissement"}}
|
|
{{/if}}
|
|
<p class="block error">{{$msg}}</p>
|
|
{{/if}}
|
|
|
|
{{* récupérer les infos de l'immobilisation *}}
|
|
{{#load type="immo" assign="info_immo" where="$$.line = :line_id" :line_id=$_GET.line_id|intval}}
|
|
{{else}}
|
|
{{:assign message="Pas d'info concernant l'immobilisation %s"|args:$_GET.line_id}}
|
|
{{:error message=$message}}
|
|
{{/load}}
|
|
|
|
{{* liste de toutes les immobilisations gérées *}}
|
|
{{#load type="immo"}}
|
|
{{:assign
|
|
var="info_immos.%s"|args:$line
|
|
duration=$duration
|
|
amort=$amort
|
|
}}
|
|
{{:assign var="amort_associes" value=$amort|values}}
|
|
{{/load}}
|
|
{{:assign var="duree" from="info_immos.%s.duration"|args:$_GET.line_id}}
|
|
|
|
{{#select
|
|
line.id as line_id,
|
|
line.id_account as account_id,
|
|
line.id_project as project_id,
|
|
line.debit as montant,
|
|
trans.id as trans_id,
|
|
trans.label as label,
|
|
trans.date as date_achat,
|
|
y.id as year_id,
|
|
y.end_date as date_fin,
|
|
project.label as project_label
|
|
from acc_transactions_lines as line
|
|
inner join acc_transactions as trans on line.id_transaction = trans.id
|
|
inner join acc_years as y on trans.id_year = y.id
|
|
left join acc_projects AS project ON line.id_project = project.id
|
|
where line.id = :line_id;
|
|
:line_id = $_GET.line_id|intval
|
|
assign=ligne_immo
|
|
}}
|
|
<h2>Amortissement de « {{$label}} » d'un montant de {{"%f"|math:$montant|money_currency}} en date du {{$date_achat|date_short}} sur {{$duree}} ans</h2>
|
|
{{else}}
|
|
{{:assign message="Immobilisation %s non trouvée"|args:$_GET.line_id}}
|
|
{{:error message=$message}}
|
|
{{/select}}
|
|
|
|
{{* chercher des écritures d'amortissement liées à l'immobilisation *}}
|
|
{{#select
|
|
l_immo.id,
|
|
l_immo.id_account,
|
|
l_amort.credit as amort_amount,
|
|
l_amort.label as amort_label,
|
|
l_amort.id as amort_line,
|
|
l_amort.id_transaction as amort_trans_id,
|
|
l_amort.id_project as projet,
|
|
l_amort.id_account as account_id,
|
|
l_amort.id_project as project_id,
|
|
project.label as project_label,
|
|
trans.date as amort_date,
|
|
trans.label as trans_label,
|
|
trans.id_year as amort_year,
|
|
acc.code as account_code,
|
|
acc.label as account_name,
|
|
acc.id_chart as PC,
|
|
"vrai" as linked
|
|
from acc_transactions_lines as l_immo
|
|
inner JOIN acc_transactions_links as links on l_immo.id_transaction = links.id_related
|
|
inner JOIN acc_transactions_lines as l_amort on links.id_transaction = l_amort.id_transaction
|
|
inner join acc_accounts as acc on l_amort.id_account = acc.id
|
|
inner join acc_transactions as trans on l_amort.id_transaction = trans.id
|
|
inner join acc_projects AS project ON l_immo.id_project = project.id
|
|
where l_immo.id = :line_id and l_amort.credit <> 0
|
|
order by trans.date;
|
|
:line_id = $_GET.line_id|intval
|
|
assign=linked_lines.
|
|
}}
|
|
{{:assign var="amort_associes." value=$amort_line}}
|
|
{{:assign var="amort_years." value=$amort_year}}
|
|
{{/select}}
|
|
|
|
{{* chercher parmi les associations *}}
|
|
{{:assign var="liste_amort" from="info_immos.%s.amort"|args:$_GET.line_id}}
|
|
{{#foreach from=$liste_amort item="id_amort"}}
|
|
{{#select
|
|
l_amort.id_transaction as amort_trans_id,
|
|
l_amort.credit as amort_amount,
|
|
l_amort.label as amort_label,
|
|
trans.date as amort_date,
|
|
trans.label as trans_label,
|
|
trans.id_year as amort_year,
|
|
acc.code as account_code,
|
|
acc.label as account_name,
|
|
project.label as project_label
|
|
from acc_transactions_lines as l_amort
|
|
inner join acc_transactions as trans on l_amort.id_transaction = trans.id
|
|
inner join acc_accounts as acc on l_amort.id_account = acc.id
|
|
inner join acc_projects AS project ON l_amort.id_project = project.id
|
|
where l_amort.id = :l_amort_id;
|
|
:l_amort_id = $id_amort
|
|
}}
|
|
{{:assign
|
|
var="linked_lines."
|
|
amort_line=$id_amort
|
|
amort_trans_id=$amort_trans_id
|
|
amort_amount=$amort_amount
|
|
amort_label=$amort_label
|
|
amort_date=$amort_date
|
|
amort_year=$amort_year
|
|
trans_label=$trans_label
|
|
account_code=$account_code
|
|
account_name=$account_name
|
|
project_label=$project_label
|
|
}}
|
|
{{:assign var="amort_years." value=$amort_year}}
|
|
{{/select}}
|
|
{{/foreach}}
|
|
|
|
{{* montant de l'annuité théorique *}}
|
|
{{:assign montant="%f"|math:$ligne_immo.montant}}
|
|
{{:assign annuite="%f/%f"|math:$montant:$duree}}
|
|
|
|
{{* première annuité *}}
|
|
{{:assign date_achat=$ligne_immo.date_achat|date_short}}
|
|
{{:assign date_fin=$ligne_immo.date_fin|date_short}}
|
|
{{:include file="_calcul_dates.html" date_debut=$date_achat date_fin=$date_fin keep="nbjours"}}
|
|
{{:assign annuite_1="%f/360*%d"|math:$annuite:$nbjours|intval}}
|
|
|
|
{{:assign date_amort=$date_fin}}
|
|
{{:assign annuite_courante=$annuite_1}}
|
|
{{:assign current_year=$ligne_immo.year_id}}
|
|
{{:assign solde=$ligne_immo.montant}}
|
|
{{:assign nbamort=0}}
|
|
|
|
{{if $linked_lines != null}}
|
|
<section class="amortissement">
|
|
<h3 class="ruler">
|
|
Amortissements attachés à « <a class="num"
|
|
href={{"%s/acc/transactions/details.php?id=%s"|args:$admin_url:$ligne_immo.trans_id}}>{{$ligne_immo.trans_id}}</a>
|
|
{{$ligne_immo.label}} »
|
|
({{"%f"|math:$ligne_immo.montant|money_currency}}, {{$ligne_immo.date_achat|date_short}})
|
|
</h3>
|
|
<table class="list">
|
|
<thead>
|
|
<tr>
|
|
<th>N°</th>
|
|
<th>Date</th>
|
|
<th style="text-align: right;">Montant</th>
|
|
<th style="text-align: right;">Solde</th>
|
|
<th>Libellé</th>
|
|
<th>N° compte</th>
|
|
<th>Compte</th>
|
|
<th>Projet</th>
|
|
<th class="actions"></th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{{#foreach from=$linked_lines item="line"}}
|
|
{{* données de l'écriture *}}
|
|
{{:assign trans_url="%s/acc/transactions/details.php?id=%s"|args:$admin_url:$line.amort_trans_id}}
|
|
{{:assign solde="%f-%d"|math:$solde:$line.amort_amount}}
|
|
{{:assign date_amort=$line.amort_date}}
|
|
{{:assign current_year=$line.amort_year}}
|
|
<tr>
|
|
<td class="num"><a href={{$trans_url}}>#{{$line.amort_trans_id}}</a></td>
|
|
<td>{{$line.amort_date|date_short}}</td>
|
|
<td class="money">{{"%f"|math:$line.amort_amount|money}}</td>
|
|
<td class="money">{{"%f"|math:$solde|money}}</td>
|
|
<td>
|
|
{{if $line.amort_label == null}}
|
|
{{$line.trans_label}}
|
|
{{else}}
|
|
{{$line.amort_label}}
|
|
{{/if}}
|
|
</td>
|
|
<td>{{$line.account_code}}</td>
|
|
<td>{{$line.account_name}}</td>
|
|
<td>{{$line.project_label}}</td>
|
|
<td>
|
|
{{if $line.linked == null}}
|
|
{{:linkbutton label="Détacher" href="detach_amort.html?amort_id=%d&immo_id=%d"|args:$line.amort_line:$ligne_immo.line_id shape="plus"}}
|
|
{{else}}
|
|
{{:linkbutton label="Détacher" href="" shape="lock" class="disabled"}}
|
|
{{/if}}
|
|
</td>
|
|
</tr>
|
|
{{:assign annuite_courante=$annuite}}
|
|
{{:assign jour=$date_amort|date:"d"}}
|
|
{{:assign mois=$date_amort|date:"m"}}
|
|
{{:assign annee=$date_amort|date:"Y"}}
|
|
{{:assign annee="%d+1"|math:$annee}}
|
|
{{:assign date_amort="%s/%s/%s"|args:$jour:$mois:$annee|parse_date|date_short}}
|
|
{{:assign nbamort="%d+1"|math:$nbamort}}
|
|
{{/foreach}}
|
|
</tbody>
|
|
</table>
|
|
</section>
|
|
{{/if}}
|
|
|
|
{{:assign project_id=$ligne_immo.project_id}}
|
|
{{:assign project_label=$ligne_immo.project_label}}
|
|
{{:assign nbamort="%d-%d"|math:$duree:$nbamort}}
|
|
|
|
<section class="amortissement">
|
|
<h3 class="ruler">Amortissements à enregistrer</h3>
|
|
<table class="list">
|
|
<thead>
|
|
<tr>
|
|
<th>N°</th>
|
|
<th>Date</th>
|
|
<th>Montant</th>
|
|
<th>Solde</th>
|
|
<th>Libellé</th>
|
|
<th>N° compte</th>
|
|
<th>Compte</th>
|
|
<th>Projet</th>
|
|
<th class="actions"></th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{{#foreach count="%d+1"|math:$nbamort key="num"}}
|
|
{{:assign solde="%f-%d"|math:$solde:$annuite_courante}}
|
|
{{#select id from acc_years where end_date = :end_date and closed = 0; :end_date=$date_amort|parse_date}}
|
|
{{:assign enregistrer=1}}
|
|
{{else}}
|
|
{{:assign enregistrer=0}}
|
|
{{/select}}
|
|
<tr>
|
|
<td class="num">{{"%d+1"|math:$num}}</td>
|
|
<td>{{$date_amort}}</td>
|
|
<td class="money">{{"%f"|math:$annuite_courante|money}}</td>
|
|
<td class="money">{{if $solde == 0}}0,00{{else}}{{"%f"|math:$solde|money}}{{/if}}</td>
|
|
<td>
|
|
{{if $libelle == null}}
|
|
{{:assign libelle="Amortissement "|cat:$ligne_immo.label}}
|
|
{{/if}}
|
|
{{$libelle}}
|
|
</td>
|
|
<td></td>
|
|
<td></td>
|
|
<td></td>
|
|
<td class="actions">
|
|
{{if $enregistrer == 1}}
|
|
{{:linkbutton
|
|
label="Enregistrer"
|
|
href="save_amort.html?amount=%d&account=%s&year=%s&trans_id=%d&line_id=%s&project_id=%d&label=%s"|args:$annuite_courante:$ligne_immo.account_id:$current_year:$ligne_immo.trans_id:$_GET.line_id:$project_id:$libelle
|
|
shape="right"
|
|
}}
|
|
{{else}}
|
|
{{:linkbutton label="Enregistrer" href="" shape="lock" class="disabled"}}
|
|
{{/if}}
|
|
</td>
|
|
</tr>
|
|
{{:assign jour=$date_amort|date:"d"}}
|
|
{{:assign mois=$date_amort|date:"m"}}
|
|
{{:assign annee=$date_amort|date:"Y"}}
|
|
{{:assign annee="%d+1"|math:$annee}}
|
|
{{:assign date_amort="%s/%s/%s"|args:$jour:$mois:$annee|parse_date|date_short}}
|
|
{{:assign current_year="%d+1"|math:$current_year}}
|
|
{{:assign annuite_courante="min(%f,%f)"|math:$annuite:$solde}}
|
|
{{if $solde == 0}}{{:break}}{{/if}}
|
|
{{/foreach}}
|
|
</tbody>
|
|
</table>
|
|
</section>
|
|
|
|
<section class="amortissement">
|
|
<h3 class="ruler">Autres amortissements non rattachés</h3>
|
|
<table class="list">
|
|
<thead>
|
|
<tr>
|
|
<th>N°</th>
|
|
<th>Date</th>
|
|
<th style="text-align: right;">Montant</th>
|
|
<th>Libellé</th>
|
|
<th>N° compte</th>
|
|
<th>Compte</th>
|
|
<th>Projet</th>
|
|
<th class="actions"></th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
|
|
{{#select
|
|
li.id as l_id,
|
|
li.id_transaction as t_id,
|
|
li.credit as montant,
|
|
li.reference,
|
|
li.label as l_label,
|
|
pro.label as p_label,
|
|
trans.date as t_date,
|
|
trans.label as t_label,
|
|
acc.code as a_code,
|
|
acc.label as a_label,
|
|
y.label as y_label
|
|
from acc_transactions_lines as li
|
|
inner join acc_accounts as acc on acc.id = li.id_account
|
|
inner join acc_transactions as trans on trans.id = li.id_transaction
|
|
inner join acc_years as y on y.id = trans.id_year
|
|
inner join acc_projects as pro on li.id_project = pro.id
|
|
where acc.code like "28%"
|
|
order by trans.date, trans.label
|
|
}}
|
|
{{:assign linked="false"}}
|
|
{{#select
|
|
id_transaction,
|
|
id_related
|
|
from acc_transactions_links
|
|
where id_transaction = :id_amort;
|
|
:id_amort=$t_id}}
|
|
{{:assign linked="true"}}
|
|
{{/select}}
|
|
|
|
{{if ! $l_id|in:$amort_associes && $linked != "true"}}
|
|
{{:assign trans_url="%s/acc/transactions/details.php?id=%s"|args:$admin_url:$t_id}}
|
|
<tr>
|
|
<td class="num"><a href={{$trans_url}}>#{{$t_id}}</a></td>
|
|
<td>{{$t_date|date_short}}</td>
|
|
<td class="money">{{"%f"|math:$montant|money}}</td>
|
|
<td>{{if $l_label == null}}
|
|
{{$t_label}}
|
|
{{else}}
|
|
{{$l_label}}
|
|
{{/if}}
|
|
</td>
|
|
<td>{{$a_code}}</td>
|
|
<td>{{$a_label}}</td>
|
|
<td>{{$p_label}}</td>
|
|
<td>
|
|
{{if $linked != "true"}}
|
|
{{:linkbutton label="Attacher" href="attach_amort.html?amort_id=%d&immo_id=%d"|args:$l_id:$ligne_immo.line_id shape="plus"}}
|
|
{{else}}
|
|
{{:linkbutton label="Attacher" href="" shape="lock" class="disabled"}}
|
|
{{/if}}
|
|
</td>
|
|
</tr>
|
|
{{/if}}
|
|
{{/select}}
|
|
</tbody>
|
|
</table>
|
|
</section>
|
|
|
|
{{:form_errors}}
|
|
{{:admin_footer}}
|