2018-03-28 17:04:10 +02:00
|
|
|
<?php
|
2020-09-07 15:04:06 +02:00
|
|
|
/*
|
|
|
|
* OpenSTAManager: il software gestionale open source per l'assistenza tecnica e la fatturazione
|
2021-01-20 15:08:51 +01:00
|
|
|
* Copyright (C) DevCode s.r.l.
|
2020-09-07 15:04:06 +02:00
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2018-03-28 17:04:10 +02:00
|
|
|
|
|
|
|
include_once __DIR__.'/../../core.php';
|
|
|
|
|
2020-09-09 16:55:45 +02:00
|
|
|
$id_anagrafica = filter('id_anagrafica');
|
|
|
|
|
|
|
|
echo '
|
|
|
|
<form action="" method="post" id="add-form">
|
2018-03-28 17:04:10 +02:00
|
|
|
<input type="hidden" name="op" value="add">
|
|
|
|
<input type="hidden" name="backto" value="record-edit">
|
|
|
|
|
|
|
|
<div class="row">
|
2020-09-09 16:55:45 +02:00
|
|
|
<div class="col-md-6">
|
|
|
|
{[ "type": "select", "label": "'.tr('Anagrafica').'", "name": "id_anagrafica", "required": "1", "value": "$id_anagrafica$", "ajax-source": "anagrafiche", "value": "'.$id_anagrafica.'", "disabled": "'.intval(!empty($id_anagrafica)).'" ]}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="col-md-6">
|
|
|
|
{[ "type": "text", "label": "'.tr('Nome').'", "name": "nome", "required": "1" ]}
|
2018-03-28 17:04:10 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2020-09-07 15:04:06 +02:00
|
|
|
|
2018-12-28 00:04:41 +01:00
|
|
|
<div class="row">
|
2021-04-26 09:27:05 +02:00
|
|
|
<div class="col-md-8">
|
2020-09-09 16:55:45 +02:00
|
|
|
{[ "type": "text", "label": "'.tr('IBAN').'", "name": "iban", "required": "1", "class": "alphanumeric-mask", "maxlength": 32, "value": "$iban$" ]}
|
2018-12-28 00:04:41 +01:00
|
|
|
</div>
|
2021-04-26 09:27:05 +02:00
|
|
|
|
|
|
|
<div class="col-md-4">
|
|
|
|
{[ "type": "text", "label": "'.tr('BIC').'", "name": "bic", "required": "1", "class": "alphanumeric-mask", "minlength": 8, "maxlength": 11, "value": "$bic$", "help": "'.$help_codice_bic.'" ]}
|
|
|
|
</div>
|
2018-12-28 00:04:41 +01:00
|
|
|
</div>
|
2018-03-28 17:04:10 +02:00
|
|
|
|
2021-12-02 11:46:59 +01:00
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-4">
|
|
|
|
{[ "type": "select", "label": "'.tr('Nazione').'", "name": "id_nazione", "ajax-source": "nazioni" ]}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="col-md-4">
|
|
|
|
{[ "type": "text", "label": "'.tr('Codice banca nazionale (ABI)').'", "name": "bank_code", "class": "alphanumeric-mask" ]}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="col-md-4">
|
|
|
|
{[ "type": "text", "label": "'.tr('Codice filiale (CAB)').'", "name": "branch_code", "class": "alphanumeric-mask" ]}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
2018-03-28 17:04:10 +02:00
|
|
|
<!-- PULSANTI -->
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-12 text-right">
|
2020-09-09 16:55:45 +02:00
|
|
|
<button type="submit" class="btn btn-primary">
|
|
|
|
<i class="fa fa-plus"></i> '.tr('Aggiungi').'
|
|
|
|
</button>
|
2018-03-28 17:04:10 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2020-09-09 16:55:45 +02:00
|
|
|
</form>';
|
2021-12-02 11:46:59 +01:00
|
|
|
?>
|
|
|
|
<script>
|
|
|
|
var iban = input("iban");
|
|
|
|
|
|
|
|
var branch_code = input("branch_code");
|
|
|
|
var bank_code = input("bank_code");
|
|
|
|
var id_nazione = input("id_nazione");
|
|
|
|
|
|
|
|
var components = [branch_code, bank_code, id_nazione];
|
|
|
|
|
|
|
|
$(document).ready(function (){
|
|
|
|
iban.trigger("keyup");
|
|
|
|
});
|
|
|
|
|
|
|
|
iban.on("keyup", function () {
|
|
|
|
if (!iban.isDisabled()){
|
|
|
|
let value = iban.get();
|
|
|
|
for (const component of components){
|
|
|
|
component.setDisabled(value !== "")
|
|
|
|
}
|
|
|
|
|
|
|
|
scomponiIban();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
for (const component of components){
|
|
|
|
component.on("keyup", function () {
|
|
|
|
let i = input(this);
|
|
|
|
if (!i.isDisabled()) {
|
|
|
|
iban.setDisabled(i.get() !== "")
|
|
|
|
|
|
|
|
componiIban();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function scomponiIban() {
|
|
|
|
$.ajax({
|
|
|
|
url: globals.rootdir + '/actions.php',
|
|
|
|
data: {
|
|
|
|
id_module: globals.id_module,
|
|
|
|
op: "decompose",
|
|
|
|
iban: iban.get(),
|
|
|
|
},
|
|
|
|
type: 'GET',
|
|
|
|
dataType: "json",
|
|
|
|
success: function (response) {
|
|
|
|
compilaCampi(response);
|
|
|
|
},
|
|
|
|
error: function() {
|
|
|
|
toastr["error"]("<?php echo tr('Formato IBAN non valido'); ?>");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function componiIban() {
|
|
|
|
// Controllo su campi con valore impostato
|
|
|
|
let continua = false;
|
|
|
|
for (const component of components){
|
|
|
|
continua |= !([undefined, null, ""].includes(component.get()));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!continua){
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
url: globals.rootdir + '/actions.php',
|
|
|
|
data: {
|
|
|
|
id_module: globals.id_module,
|
|
|
|
op: "compose",
|
|
|
|
branch_code: branch_code.get(),
|
|
|
|
bank_code: bank_code.get(),
|
|
|
|
id_nazione: id_nazione.get(),
|
|
|
|
},
|
|
|
|
type: 'GET',
|
|
|
|
dataType: "json",
|
|
|
|
success: function (response) {
|
|
|
|
compilaCampi(response);
|
|
|
|
},
|
|
|
|
error: function() {
|
|
|
|
toastr["error"]("<?php echo tr('Formato IBAN non valido'); ?>");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function compilaCampi(values) {
|
|
|
|
for([key, value] of Object.entries(values)) {
|
|
|
|
if (typeof value === 'object' && value !== null) {
|
|
|
|
input(key).getElement().selectSetNew(value.id, value.text, value);
|
|
|
|
} else {
|
|
|
|
input(key).set(value);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|