records_in.blade.php 58 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048
  1. <div class="col">
  2. <div class="row h-100">
  3. <div class="col-auto filterWrapper" id="filter--section" wire:ignore>
  4. <aside>
  5. <header>
  6. <h2>Filtra Ricerca</h2>
  7. </header>
  8. <form action="" id="filter--form" class="dark-form row">
  9. <div class="filter--item">
  10. <span class="filter--item_title">Tipologia</span>
  11. <div class="filter--item_formElement">
  12. <div class="form-check form-check-inline d-inline-flex align-items-center">
  13. <input class="form-check-input" type="radio" value="0" name="filterCommercial" checked>
  14. <label class="form-check-label ms-2" for="inlineCheckbox1">Entrambe</label>
  15. </div>
  16. <div class="form-check form-check-inline d-inline-flex align-items-center">
  17. <input class="form-check-input" type="radio" value="1" name="filterCommercial" >
  18. <label class="form-check-label ms-2" for="inlineCheckbox1">Commerciale</label>
  19. </div>
  20. <div class="form-check form-check-inline d-inline-flex align-items-center">
  21. <input class="form-check-input" type="radio" value="2" name="filterCommercial">
  22. <label class="form-check-label ms-2" for="inlineCheckbox1">Non commerciale</label>
  23. </div>
  24. </div>
  25. </div>
  26. <!-- filter item -->
  27. <div class="filter--item">
  28. <span class="filter--item_title">Persona</span>
  29. <div class="filter--item_formElement">
  30. <select name="search_member_id" class="form-select filterMember">
  31. <option value="">--Seleziona--
  32. @foreach($members as $member)
  33. <option value="{{$member->id}}">{{$member->last_name}} {{$member->first_name}}
  34. @endforeach
  35. </select>
  36. </div>
  37. </div>
  38. <div class="filter--item">
  39. <span class="filter--item_title">Pagamento</span>
  40. <div class="filter--item_formElement">
  41. <select name="search_payment_method_id" class="form-select filterPaymentMethod">
  42. <option value="">--Seleziona--
  43. @foreach($payments as $payment)
  44. <option value="{{$payment->id}}">{{$payment->name}}
  45. @endforeach
  46. </select>
  47. </div>
  48. </div>
  49. <!-- filter item -->
  50. <div class="filter--item">
  51. <span class="filter--item_title">Causali</span>
  52. <div class="filter--item_formElement">
  53. <select name="search_causal_id" class="form-select filterCausals">
  54. <option value="">--Seleziona--
  55. @foreach($causals as $causal)
  56. <option value="{{$causal["id"]}}">{!!$causal["name"]!!}
  57. @endforeach
  58. </select>
  59. </div>
  60. </div>
  61. <!-- filter item -->
  62. <div class="filter--item">
  63. <span class="filter--item_title">Periodo </span>
  64. <div class="filter--item_formElement">
  65. <input id="dateFrom" type="date" class="form-control filterFrom" style="background-color:white" >
  66. </div>
  67. <div class="filter--item_formElement">
  68. <input id="dateTo" type="date" class="form-control filterTo" style="background-color:white" >
  69. </div>
  70. </div>
  71. </form>
  72. <footer>
  73. <div class="d-flex align-items-center totalDiv">
  74. </div>
  75. <div class="filter--buttons d-flex align-items-center justify-content-between">
  76. <button class="btn--ui small dark disable" onclick="reset()">cancella</button>
  77. <button class="btn--ui small white" onclick="loadDataTable()">filtra</button>
  78. </div>
  79. </footer>
  80. </aside>
  81. </div>
  82. <div class="col card--ui" id="card--dashboard">
  83. <header id="title--section" class="d-flex align-items-center justify-content-between">
  84. <div class="title--section_name d-flex align-items-center justify-content-between">
  85. <i class="ico--ui title_section entrate me-2"></i>
  86. <h2 class="primary">@if(!$add && !$update)Entrate @else Inserimento/modifica entrata @endif</h2>
  87. </div>
  88. @if(!$add && !$update)
  89. <div class="title--section_addButton" wire:click="add()" style="cursor: pointer;">
  90. <div class="card--ui card--ui_btnAddHeaderUser entrata d-flex justify-items-between">
  91. <header class="d-flex justify-content-between"><div class="card-title d-flex align-items-start"><h2><small>Registra</small><br>Nuova Entrata</h2></div><a href="#" wire:click="add()"><i class="ico--ui big add primary"></i></a></header>
  92. </div>
  93. </div>
  94. @endif
  95. </header>
  96. @if(!$add && !$update)
  97. <button id="open-filter" onclick="pcsh1()"></button>
  98. <button id="close-filter" onclick="pcsh2()"></button>
  99. <section id="subheader" class="d-flex align-items-center justify-content-between">
  100. </section>
  101. @if (session()->has('receipt'))
  102. <div class="alert alert-success" role="alert">
  103. {{ session()->get('receipt') }}
  104. </div>
  105. @endif
  106. <section id="resume-table">
  107. <div class="compare--chart_wrapper d-none"></div>
  108. <table class="table tablesaw tablesaw-stack" id="tablesaw-350">
  109. <thead>
  110. <tr>
  111. <!--<th scope="col"></th>-->
  112. <th scope="col">Data pagamento</th>
  113. <th scope="col">Importo</th>
  114. <th scope="col">Nome</th>
  115. <th scope="col">Cognome</th>
  116. <th scope="col">Commerciale</th>
  117. <th scope="col">Causale</th>
  118. <th scope="col">Pagamento</th>
  119. <th scope="col">Stato</th>
  120. <th scope="col">...</th>
  121. </tr>
  122. </thead>
  123. <tbody id="checkall-target">
  124. </tbody>
  125. </table>
  126. <br><b class="totalDiv"></b>
  127. </section>
  128. @else
  129. @if (session()->has('error'))
  130. <div class="alert alert-danger" role="alert">
  131. {{ session()->get('error') }}
  132. </div>
  133. @endif
  134. <section id="accountingEntry" class="d-flex">
  135. <div class="accountingEntry_data" wire:key='reload-{{$selectId}}'>
  136. <form class="form--accounting" >
  137. <div class="row gx-2">
  138. <div class="col-md-12">
  139. <span class="title-form d-block w-100">Tipologia</span>
  140. <div class="input-group mb-12">
  141. <div class="check--invoice d-flex align-items-center">
  142. <div class="form-check me-3">
  143. <input class="form-check-input" type="radio" value="1" wire:model="commercial" {{$this->dataId > 0 ? 'disabled' : ''}}>
  144. <label class="form-check-label" for="flexCheckChecked">&nbsp;Commerciale</label>
  145. </div>
  146. <div class="form-check">
  147. <input class="form-check-input" type="radio" value="0" wire:model="commercial" {{$this->dataId > 0 ? 'disabled' : ''}}>
  148. <label class="form-check-label" for="flexCheck">&nbsp;Non Commerciale</label>
  149. </div>
  150. </div>
  151. </div>
  152. </div>
  153. <div class="col-md-6 mt-3">
  154. <span class="title-form d-block w-100">Data pagamento</span>
  155. <div class="input-group mb-3">
  156. <input id="date" type="date" class="form-control" wire:model="date" {{$this->dataId > 0 ? 'disabled' : ''}}>
  157. </div>
  158. </div>
  159. <div class="col-md-6">&nbsp;</div>
  160. <div class="col-md-6">
  161. <span class="title-form d-block w-100">Persona</span>
  162. <select name="member_id" class="form-select memberClass @error('member_id') is-invalid @enderror" aria-label="Seleziona una persona" wire:model="member_id" {{$this->dataId > 0 ? 'disabled' : ''}}>
  163. <option value="">--Seleziona--
  164. @foreach($members as $member)
  165. <option value="{{$member->id}}">{{$member->last_name}} {{$member->first_name}} ({{$member->fiscal_code}})
  166. @endforeach
  167. </select>
  168. @error('member_id')
  169. <div class="invalid-feedback">{{ $message }}</div>
  170. @enderror
  171. <br><br>
  172. @if($this->dataId == 0)
  173. <button type="button" class="btn--ui primary" data-bs-toggle="modal" data-bs-target="#userModal">
  174. Aggiungi
  175. </button>
  176. @endif
  177. </div>
  178. <div class="col-md-6">
  179. @if($this->member)
  180. <b>{{$this->member->first_name}} {{$this->member->last_name}}</b> {!! !$this->member->isAdult() ? '<span style="color:red;font-weight:bold">&nbsp;MINORENNE</span>' : '' !!}<br>
  181. <span class="title-form w-100">Codice fiscale</span> : {{$this->member->fiscal_code}}<br>
  182. <span class="title-form w-100">Email</span> : {{$this->member->email}}<br>
  183. <span class="title-form w-100">Borsellino virtuale</span>
  184. <b>{{number_format($virtual, 2, ".", "")}} &euro;</b><br>
  185. @if(sizeof($this->member->certificates) > 0)
  186. @php
  187. $cert = $this->member->certificates[0]
  188. @endphp
  189. @if($cert->expire_date < date("Y-m-d"))
  190. <span class="title-form w-100">Certificato medico </span><span class="badge tessera-badge suspended">scaduto</span>
  191. @endif
  192. @endif
  193. @endif
  194. </div>
  195. </div>
  196. <div class="row gx-2 mt-3">
  197. <span class="title-form d-block w-100">Pagamento</span>
  198. <div class="col-md-12" >
  199. <select name="payment_method_id" class="form-select paymentClass @error('payment_method_id') is-invalid @enderror" aria-label="Seleziona un metodo di pagamento" wire:model="payment_method_id" style="width:100%">
  200. <option value="">--Seleziona--
  201. @foreach($payments as $payment)
  202. <option value="{{$payment->id}}">{{$payment->name}}
  203. @endforeach
  204. </select>
  205. @error('payment_method_id')
  206. <div class="invalid-feedback">{{ $message }}</div>
  207. @enderror
  208. </div>
  209. </div>
  210. @foreach($rows as $idx => $row)
  211. <div class="row gx-2 mt-3" >
  212. <span class="title-form d-block w-100">Causale</span>
  213. <div class="col-md-12">
  214. @if($this->dataId > 0)
  215. {{$this->getCausal($rows[$idx]['causal_id'])}}<br>
  216. @else
  217. <livewire:causals :type="$typeIN" :idx="$idx" :causal_id="$rows[$idx]['causal_id']" :wire:key="$idx"/>
  218. @endif
  219. @error('rows.'. $idx . '.causal_id')
  220. <span style="argin-top: 0.25rem; font-size: 0.875em; color: var(--bs-form-invalid-color);">{{ $message }}</span>
  221. @enderror
  222. </div>
  223. </div>
  224. <div class="row gx-2 mt-3">
  225. <span class="title-form d-block w-100">Dettaglio causale</span>
  226. <div class="col-md-12">
  227. <input class="form-control " id="causal_detail_{{$idx}}" type="text" placeholder="Dettaglio causale" wire:model="rows.{{$idx}}.note" {{$this->dataId > 0 ? 'disabled' : ''}}>
  228. </div>
  229. </div>
  230. <div class="row gx-2 mt-3 align-items-center">
  231. <div class="col-md-6">
  232. <span class="total primary">Importo</span>
  233. </div>
  234. @if ($commercial)
  235. <div class="col-md-3">
  236. <select id="rows.{{$idx}}.vat_id" class="form-select" wire:model="rows.{{$idx}}.vat_id">
  237. <option value="0">
  238. @foreach($vats as $vat)
  239. <option value="{{$vat->id}}">{{$vat->name}}
  240. @endforeach
  241. </select>
  242. </div>
  243. @else
  244. <div class="col-md-3"></div>
  245. @endif
  246. <div class="col-md-3">
  247. @if($add)
  248. <input type="text" class="form-control totalInput text-end @error('amount') is-invalid @enderror" id="rows.{{$idx}}.amount" wire:model="rows.{{$idx}}.amount" wire:keydown.enter="store(false)" onkeyup="onlyNumberAmount(this)" placeholder="€ 0,00" {{$this->dataId > 0 ? 'disabled' : ''}}>
  249. @endif
  250. @if($update)
  251. <input type="text" class="form-control totalInput text-end @error('amount') is-invalid @enderror" id="rows.{{$idx}}.amount" placeholder="€ 0,00" wire:model="rows.{{$idx}}.amount" onkeyup="onlyNumberAmount(this)" wire:keydown.enter="update(false)" {{$this->dataId > 0 ? 'disabled' : ''}}>
  252. @endif
  253. @error('rows.'. $idx . '.amount')
  254. <span style="argin-top: 0.25rem; font-size: 0.875em; color: var(--bs-form-invalid-color);">{{ $message }}</span>
  255. @enderror
  256. </div>
  257. </div>
  258. <div class="row gx-2 mt-3 align-items-center">
  259. <div class="col-md-4">
  260. <span class="total primary">Competenza</span>
  261. </div>
  262. <div class="col-md-8">
  263. <div class="row">
  264. @if($multiP)
  265. <div class="row" style="background-color:lightGrey">
  266. <h4>Seleziona inizio e fine multiperiodo</h4>
  267. <div class="col-md-3">
  268. <span class="title-form d-block w-100">Dal mese</span>
  269. <div class="input-group mb-3">
  270. <select class="form-select form-select-lg me-1" wire:model="multiMonthFrom" {{$this->dataId > 0 ? 'disabled' : ''}}>
  271. <option value="1">Gennaio</option>
  272. <option value="2">Febbraio</option>
  273. <option value="3">Marzo</option>
  274. <option value="4">Aprile</option>
  275. <option value="5">Maggio</option>
  276. <option value="6">Giugno</option>
  277. <option value="7">Luglio</option>
  278. <option value="8">Agosto</option>
  279. <option value="9">Settembre</option>
  280. <option value="10">Ottobre</option>
  281. <option value="11">Novembre</option>
  282. <option value="12">Dicembre</option>
  283. </select>
  284. </div>
  285. </div>
  286. <div class="col-md-3">
  287. <span class="title-form d-block w-100">Anno</span>
  288. <div class="input-group mb-3">
  289. <input type="number" class="form-control" wire:model="multiYearFrom" {{$this->dataId > 0 ? 'disabled' : ''}}>
  290. </div>
  291. </div>
  292. <div class="col-md-3">
  293. <span class="title-form d-block w-100">Dal mese</span>
  294. <div class="input-group mb-3">
  295. <select class="form-select form-select-lg me-1" wire:model="multiMonthTo" {{$this->dataId > 0 ? 'disabled' : ''}}>
  296. <option value="1">Gennaio</option>
  297. <option value="2">Febbraio</option>
  298. <option value="3">Marzo</option>
  299. <option value="4">Aprile</option>
  300. <option value="5">Maggio</option>
  301. <option value="6">Giugno</option>
  302. <option value="7">Luglio</option>
  303. <option value="8">Agosto</option>
  304. <option value="9">Settembre</option>
  305. <option value="10">Ottobre</option>
  306. <option value="11">Novembre</option>
  307. <option value="12">Dicembre</option>
  308. </select>
  309. </div>
  310. </div>
  311. <div class="col-md-3">
  312. <span class="title-form d-block w-100">Anno</span>
  313. <div class="input-group mb-3">
  314. <input type="number" class="form-control" wire:model="multiYearTo" {{$this->dataId > 0 ? 'disabled' : ''}}>
  315. </div>
  316. </div>
  317. @if($this->dataId == 0)
  318. <div class="col-md-6">
  319. <button type="button" class="btn--ui primary" wire:click.prevent="multiPeriodCreate({{$idx}})" style="margin-top:20px">
  320. Crea multi periodo
  321. </button>
  322. </div>
  323. <div class="col-md-6">
  324. <button type="button" class="btn--ui primary" wire:click.prevent="multiPeriodCancel()" style="margin-top:20px">
  325. Annulla multi periodo
  326. </button>
  327. </div>
  328. @endif
  329. </div>
  330. @else
  331. @foreach($row["when"] as $xxx => $w)
  332. <div class="col-md-4">
  333. <span class="title-form d-block w-100">Mese</span>
  334. <div class="input-group mb-3">
  335. <select class="form-select form-select-lg me-1" wire:model="rows.{{$idx}}.when.{{$xxx}}.month" {{$this->dataId > 0 ? 'disabled' : ''}}>
  336. <option value="1">Gennaio</option>
  337. <option value="2">Febbraio</option>
  338. <option value="3">Marzo</option>
  339. <option value="4">Aprile</option>
  340. <option value="5">Maggio</option>
  341. <option value="6">Giugno</option>
  342. <option value="7">Luglio</option>
  343. <option value="8">Agosto</option>
  344. <option value="9">Settembre</option>
  345. <option value="10">Ottobre</option>
  346. <option value="11">Novembre</option>
  347. <option value="12">Dicembre</option>
  348. </select>
  349. </div>
  350. </div>
  351. <div class="col-md-3">
  352. <span class="title-form d-block w-100">Anno</span>
  353. <div class="input-group mb-3">
  354. <input type="number" class="form-control" wire:model="rows.{{$idx}}.when.{{$xxx}}.year" {{$this->dataId > 0 ? 'disabled' : ''}}>
  355. </div>
  356. </div>
  357. <div class="col-md-3">
  358. <span class="title-form d-block w-100">Valore</span>
  359. <span class="netprice_p total--wrapper_netprice"><b>{{$this->currencyToDouble($rows[$idx]["amount"]) > 0 ? formatPrice(($this->currencyToDouble($rows[$idx]["amount"]) + getVatValue($this->currencyToDouble($rows[$idx]["amount"]), $rows[$idx]["vat_id"])) / sizeof($rows[$idx]["when"])) : ""}}</b></span>
  360. </div>
  361. <div class="col-md-2"><br>
  362. @if($this->dataId == 0)
  363. <button type="button" class="btn--ui primary" wire:click.prevent="delPeriod({{$idx}}, {{$xxx}})" style="float:right">
  364. -
  365. </button>
  366. @endif
  367. </div>
  368. @endforeach
  369. @if($this->dataId == 0)
  370. <button type="button" class="btn--ui primary" wire:click.prevent="addPeriod({{$idx}})">
  371. Aggiungi periodo
  372. </button>
  373. <button type="button" class="btn--ui primary" wire:click.prevent="multiPeriod()" style="margin-top:20px">
  374. Imposta multi periodo
  375. </button>
  376. @endif
  377. @endif
  378. </div>
  379. </div>
  380. </div>
  381. <br><br>
  382. @if($this->dataId == 0)
  383. @if($idx > 0)
  384. <button type="button" class="btn--ui primary" wire:click.prevent="delRow({{$idx}})" style="float:right">
  385. Rimuovi causale
  386. </button>
  387. <br><br>
  388. @endif
  389. @endif
  390. <hr size="1">
  391. @endforeach
  392. @if($this->dataId == 0)
  393. <br>
  394. <button type="button" class="btn--ui primary" wire:click.prevent="addRow()">
  395. Aggiungi causale
  396. </button>
  397. @endif
  398. <div class="accountingEntry--btn d-flex align-items-center justify-content-between">
  399. <button class="btn--ui lightGrey" type="submit" wire:click.prevent="cancel()">annulla</button>
  400. @if($canSave)
  401. @if($add)
  402. @if($commercial)
  403. <button class="btn--ui primary" type="submit" wire:click.prevent="store(false)">inserisci</button>
  404. @else
  405. <button class="btn--ui primary sendInvoice mt-5 d-flex ms-auto" wire:click.prevent="store(true)"><i class="ico--ui sendingBtn"></i>inserisci e genera ricevuta</button>
  406. @endif
  407. @endif
  408. @if($update)
  409. <button class="btn--ui primary" type="submit" wire:click.prevent="update(false)">salva</button>
  410. @endif
  411. @else
  412. <span style="color:red">Attenzione : non c'è credito sufficiente sul borsellino virtuale</span>
  413. @endif
  414. </div>
  415. </form>
  416. </div>
  417. <div class="accountingEntry_resume card--ui" style="max-height:800px;">
  418. <header>
  419. <div class="username d-flex align-items-start">
  420. <i class="ico--ui accountingResume me-2"></i>
  421. <div class="user--resume_name d-flex flex-column"><span class="primary">Ricevuta {{$currentReceip ? $currentReceip->number . "/" . $currentReceip->year : ''}}</span></div></div>
  422. </header>
  423. <div class="resume--body d-flex justify-content-between flex-column">
  424. <header>
  425. @if($this->member)
  426. <ul class="resume-item mb-4 p-0">
  427. @if($this->member->isAdult())
  428. <li>
  429. <span class="evidence_name">{{$this->member->last_name}} {{$this->member->first_name}}</span> ({{$this->member->fiscal_code}})
  430. </li>
  431. @if (false)
  432. <li><span>Nato/a il {{$this->member->birth_date ? date("d/m/Y", strtotime($this->member->birth_date)) : ''}}</span></li>
  433. @endif
  434. @else
  435. <li>
  436. <span class="evidence_name">
  437. <select class="form-control" wire:model="parent">
  438. <option value="">Seleziona un genitore
  439. @if($this->member->father_name != '')
  440. <option value="{{$this->member->father_name}} {{$this->member->father_fiscal_code}}">{{$this->member->father_name}} {{$this->member->father_fiscal_code}}
  441. @endif
  442. @if($this->member->mother_name != '')
  443. <option value="{{$this->member->mother_name}} {{$this->member->mother_fiscal_code}}">{{$this->member->mother_name}} {{$this->member->mother_fiscal_code}}
  444. @endif
  445. </select>
  446. </span>
  447. </li>
  448. @endif
  449. </ul>
  450. @endif
  451. <ul class="resume-item date p-0">
  452. <li><strong>Data di Pagamento</strong></li>
  453. <li>{{ date("d/m/Y", strtotime($date)) }}</li>
  454. </ul>
  455. @if(sizeof($rows) > 0)
  456. <table width="100%">
  457. <tr>
  458. <td><b>Causale</b></td>
  459. @if($commercial == 1)
  460. <td><b>Imponibile</b></td>
  461. <td><b>% Iva</b></td>
  462. <td><b>Iva</b></td>
  463. @endif
  464. <td style="float:right"><b>Totale</b></td>
  465. </tr>
  466. @foreach($rows as $row)
  467. <tr>
  468. <td>
  469. {{$this->getCausal($row["causal_id"])}}<br>
  470. {{$row["note"]}}
  471. </td>
  472. @php
  473. $vat_value = 0;
  474. @endphp
  475. @if($commercial == 1)
  476. <td>{{$row["amount"]}}</td>
  477. @php
  478. $vat_name = '';
  479. if ($row["vat_id"] > 0)
  480. {
  481. $v = \App\Models\Vat::findOrFail(intval($row["vat_id"]));
  482. $vat_name = $v->name;
  483. $vat_value = $this->currencyToDouble($row["amount"]) / 100 * $v->value;
  484. }
  485. @endphp
  486. <td>{{$vat_name}}</td>
  487. <td>{{$vat_value > 0 ? formatPrice($vat_value) : ''}}</td>
  488. @endif
  489. <td style="float:right">{{formatPrice($this->currencyToDouble($row["amount"]) + $vat_value)}}</td>
  490. </tr>
  491. @endforeach
  492. </table>
  493. @endif
  494. </header>
  495. <footer>
  496. <div class="total--wrapper">
  497. <div class="total--wrapper_amount d-flex align-items-center justify-content-between w-100 mb-3">
  498. <span class="amount_p"><strong>Importo</strong></span><span class="amount_data"><strong>{{$this->getPrice()}}</strong></span>
  499. </div>
  500. @if(false)
  501. <div class="total--wrapper_amount d-flex align-items-center justify-content-between w-100 mb-3">
  502. <span class="amount_p"><strong>Iva</strong></span><span class="amount_data"><strong>{{$this->getVat()}}</strong></span>
  503. </div>
  504. @endif
  505. @foreach($this->getVats() as $k => $v)
  506. <div class="total--wrapper_amount d-flex align-items-center justify-content-between w-100 mb-3">
  507. <span class="amount_p"><strong>{{$k}}</strong></span><span class="amount_data"><strong>{{formatPrice($v)}}</strong></span>
  508. </div>
  509. @endforeach
  510. <!--<div class="total--wrapper_tax d-flex align-items-center justify-content-between w-100 mb-2 pb-3">
  511. <span class="taxt_p">Ritenuta d’acconto (20%):</span><span class="tax_data">€ 20,00</span>
  512. </div>-->
  513. <div class="total--wrapper_netprice d-flex align-items-center justify-content-between w-100">
  514. <span class="netprice_p"><strong>Totale</strong></span><span class="netprice_data"><strong>{{$this->getTotal()}}</strong></span>
  515. </div>
  516. </div>
  517. @if($update)
  518. @if($currentReceip)
  519. @if($currentReceip->status == 99)
  520. <br><b style="float:right">Annullata</b>
  521. <button class="btn--ui primary sendInvoice mt-5 d-flex ms-auto" wire:click.prevent="update(true)"><i class="ico--ui sendingBtn"></i>salva e rigenera ricevuta</button>
  522. @else
  523. <div class="mt-5">
  524. <a target="_blank" class="btn--ui" href="/receipt/{{$currentReceip->id}}"><i class="ico--ui sendingBtn"></i>stampa ricevuta</a>
  525. <button class="btn--ui " wire:click.prevent="removeReceipt()"><i class="ico--ui "></i>annulla ricevuta</button>
  526. </div>
  527. @endif
  528. @else
  529. <button class="btn--ui primary sendInvoice mt-5 d-flex ms-auto" wire:click.prevent="update(true)"><i class="ico--ui sendingBtn"></i>salva e genera ricevuta</button>
  530. @endif
  531. @endif
  532. </footer>
  533. </div>
  534. </div>
  535. </section>
  536. <div wire:ignore.self class="modal fade" id="userModal" tabindex="-1" aria-labelledby="userModalLabel" aria-hidden="true">
  537. <div class="modal-dialog">
  538. <div class="modal-content">
  539. <div class="modal-header">
  540. <h5 class="modal-title" id="userModalLabel">Inserimento nuovo utente</h5>
  541. <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
  542. </div>
  543. <div class="modal-body">
  544. <div class="row">
  545. <div class="col-md-6">
  546. <label for="newMemberFirstName" class="form-label">Nome</label>
  547. <input class="form-control @error('newMemberFirstName') is-invalid @enderror" type="text" id="newMemberFirstName" placeholder="Nome" wire:model="newMemberFirstName">
  548. </div>
  549. <div class="col-md-6">
  550. <label for="newMemberLastName" class="form-label">Cognome</label>
  551. <input class="form-control @error('newMemberLastName') is-invalid @enderror" type="text" id="newMemberLastName" placeholder="Cognome" wire:model="newMemberLastName">
  552. </div>
  553. </div>
  554. <div class="row">
  555. <div class="col-md-12">
  556. <label for="newMemberFiscalCode" class="form-label">Codice fiscale</label>
  557. <input class="form-control @error('newMemberFiscalCode') is-invalid @enderror" type="text" id="newMemberFiscalCode" placeholder="Codice fiscale" maxlength="16" wire:model="newMemberFiscalCode">
  558. @if($newMemberFiscalCodeExist)
  559. <span style="color:red">Il codice fiscale inserito esiste</span>
  560. @endif
  561. </div>
  562. </div>
  563. </div>
  564. <div class="modal-footer">
  565. <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Annulla</button>
  566. <button type="button" class="btn btn-primary" wire:click.prevent="createMember()">Salva</button>
  567. </div>
  568. </div>
  569. </div>
  570. </div>
  571. @endif
  572. </div>
  573. </div>
  574. </div>
  575. @push('scripts')
  576. <link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/css/select2.min.css" rel="stylesheet" />
  577. <style>
  578. .select2-container--default .select2-selection--single{
  579. background-color: #E9F0F5;
  580. border: 0.0625rem solid #DFE5EB;
  581. font-size: 0.75rem;
  582. }
  583. .select2-selection
  584. {
  585. height: 38px !important;
  586. }
  587. .select2-selection__rendered
  588. {
  589. padding-top:3px;
  590. }
  591. .select2 {
  592. width:100% !important;
  593. }
  594. .page-link.active, .active > .page-link {
  595. background-color:#006099 !important;
  596. }
  597. </style>
  598. <script src="https://code.jquery.com/jquery-2.2.4.min.js" integrity="sha256-BbhdlvQf/xTY9gja0Dq3HiwQF8LaCRTXxZKRutelT44=" crossorigin="anonymous"></script>
  599. <script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/js/select2.min.js"></script>
  600. @endpush
  601. @push('scripts')
  602. <script>
  603. function formatResult(node) {
  604. var output = node.text.split(/[,-]+/).pop();
  605. var $result = $('<span style="padding-left:' + (20 * (node.text.match(/-/g) || []).length) + 'px;">' + output + '</span>');
  606. return $result;
  607. };
  608. function matchStart(params, data) {
  609. params.term = params.term || '';
  610. if (data.text.toUpperCase().indexOf(params.term.toUpperCase()) == 0) {
  611. return data;
  612. }
  613. return false;
  614. }
  615. @if($refreshAfter == 1)
  616. setTimeout(() => {
  617. // $('.causalClass').select2();
  618. $('.causalClass').select2({
  619. matcher: function(params, data) {
  620. return matchStart(params, data);
  621. }
  622. });
  623. $('.memberClass').select2({
  624. tags: false
  625. });
  626. $('.paymentClass').select2({
  627. matcher: function(params, data) {
  628. return matchStart(params, data);
  629. }
  630. });
  631. }, 100);
  632. setTimeout(() => {
  633. var element = document.getElementById('causal_detail_0');
  634. element.dispatchEvent(new Event('input'));
  635. console.log("ASDASDSA");
  636. }, 1000);
  637. @endif
  638. window.livewire.on('refresh', () => {
  639. // $('.causalClass').select2();
  640. $('.memberClass').select2({
  641. tags: false
  642. });
  643. $('.paymentClass').select2({
  644. matcher: function(params, data) {
  645. return matchStart(params, data);
  646. }
  647. });
  648. });
  649. Livewire.on('load-select', () => {
  650. $('.causalClass').each(function(i, obj) {
  651. $(obj).select2({
  652. //data: data,
  653. /*formatSelection: function(item) {
  654. return item.text
  655. },*/
  656. templateResult: formatResult
  657. });
  658. $(obj).on('change', function (e) {
  659. var data = $(obj).select2("val");
  660. var name = $(obj).select2().attr("name");
  661. @this.set(name, data);
  662. });
  663. });
  664. $('.memberClass').select2({
  665. tags: false
  666. });
  667. $('.memberClass').on('change', function (e) {
  668. var data = $('.memberClass').select2("val");
  669. @this.set('member_id', data);
  670. });
  671. $('.paymentClass').select2({
  672. matcher: function(params, data) {
  673. return matchStart(params, data);
  674. }
  675. });
  676. $('.paymentClass').on('change', function (e) {
  677. var data = $('.paymentClass').select2("val");
  678. @this.set('payment_method_id', data);
  679. });
  680. $('.filterMember').select2();
  681. /*$('.filterMember').on('change', function (e) {
  682. var data = $('.filterMember').select2("val");
  683. @this.set('filterMember', data);
  684. @this.search();
  685. });*/
  686. $('.filterPaymentMethod').select2();
  687. /*$('.filterPaymentMethod').on('change', function (e) {
  688. var data = $('.filterPaymentMethod').select2("val");
  689. @this.set('filterPaymentMethod', data);
  690. });*/
  691. $('.filterCausals').select2();
  692. /*$('.filterCausals').on('change', function (e) {
  693. var data = $('.filterCausals').select2("val");
  694. @this.set('filterCausals', data);
  695. });*/
  696. });
  697. Livewire.on('hide-search', () => {
  698. pcsh2();
  699. });
  700. window.livewire.on('saved', () => {
  701. $('#userModal').modal('hide');
  702. });
  703. window.livewire.on('reloadMembers', () => {
  704. $('.memberClass').select2("destroy");
  705. $('.memberClass').select2({
  706. tags: false
  707. });
  708. });
  709. $('.filterMember').select2();
  710. /*$('.filterMember').on('change', function (e) {
  711. var data = $('.filterMember').select2("val");
  712. @this.set('filterMember', data);
  713. @this.search();
  714. });*/
  715. $('.filterPaymentMethod').select2();
  716. /*$('.filterPaymentMethod').on('change', function (e) {
  717. var data = $('.filterPaymentMethod').select2("val");
  718. @this.set('filterPaymentMethod', data);
  719. });*/
  720. $('.filterCausals').select2();
  721. /*$('.filterCausals').on('change', function (e) {
  722. var data = $('.filterCausals').select2("val");
  723. @this.set('filterCausals', data);
  724. });*/
  725. function onlyNumberAmount(input) {
  726. let v = input.value.replace(/\D+/g, '');
  727. if (v.length > 14) v = v.slice(0, 14);
  728. input.value = "€ " + v.replace(/(\d)(\d\d)$/, "$1,$2").replace(/(^\d{1,3}|\d{3})(?=(?:\d{3})+(?:,|$))/g, '$1.');
  729. }
  730. </script>
  731. <link href="/css/datatables.css" rel="stylesheet" />
  732. <script src="/assets/js/datatables.js"></script>
  733. <script src="https://cdn.datatables.net/buttons/3.0.2/js/buttons.dataTables.js"></script>
  734. <script src="https://cdnjs.cloudflare.com/ajax/libs/jszip/3.10.1/jszip.min.js"></script>
  735. <script src="https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.2.7/pdfmake.min.js"></script>
  736. <script src="https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.2.7/vfs_fonts.js"></script>
  737. <script>
  738. $(document).ready(function() {
  739. // Carico i dati dal local storage
  740. var filterCommercial = localStorage.getItem("filterCommercial");
  741. if (filterCommercial)
  742. {
  743. $('input[name="filterCommercial"]').val(filterCommercial);
  744. }
  745. var filterMember = localStorage.getItem("filterMember");
  746. if (filterMember)
  747. {
  748. $('.filterMember').val(filterMember);
  749. $('.filterMember').trigger('change');
  750. }
  751. var filterPaymentMethod = localStorage.getItem("filterPaymentMethod");
  752. if (filterPaymentMethod)
  753. {
  754. $('.filterPaymentMethod').val(filterPaymentMethod);
  755. $('.filterPaymentMethod').trigger('change');
  756. }
  757. var filterCausals = localStorage.getItem("filterCausals");
  758. if (filterCausals)
  759. {
  760. $('.filterCausals').val(filterCausals);
  761. $('.filterCausals').trigger('change');
  762. }
  763. var filterFrom = localStorage.getItem("filterFrom");
  764. if (filterFrom)
  765. {
  766. $('.filterFrom').val(filterFrom);
  767. }
  768. var filterTo = localStorage.getItem("filterTo");
  769. if (filterTo)
  770. {
  771. $('.filterTo').val(filterTo);
  772. }
  773. loadDataTable();
  774. } );
  775. function editData(id)
  776. {
  777. @this.edit(id);
  778. }
  779. function duplicateData(id)
  780. {
  781. @this.duplicate(id);
  782. }
  783. function deleteData(id)
  784. {
  785. if (confirm('Sei sicuro?'))
  786. @this.delete(id);
  787. }
  788. Livewire.on('load-data-table', () => {
  789. setTimeout(function() {loadDataTable()}, 100);
  790. });
  791. Livewire.on('destroy-data-table', () => {
  792. $('#tablesaw-350').DataTable().destroy();
  793. });
  794. function destroyDataTable()
  795. {
  796. $('#tablesaw-350').DataTable().destroy();
  797. }
  798. function reset()
  799. {
  800. $('input[name="filterCommercial"]').val(0);
  801. $('.filterMember').val('');
  802. $('.filterMember').trigger('change');
  803. $('.filterPaymentMethod').val('');
  804. $('.filterPaymentMethod').trigger('change');
  805. $('.filterCausals').val('');
  806. $('.filterCausals').trigger('change');
  807. $('.filterFrom').val('');
  808. $('.filterTo').val('');
  809. localStorage.clear();
  810. loadDataTable();
  811. }
  812. function loadDataTable(){
  813. if ( $.fn.DataTable.isDataTable('#tablesaw-350') ) {
  814. $('#tablesaw-350').DataTable().destroy();
  815. }
  816. var filterCommercial = $('input[name="filterCommercial"]:checked').val();
  817. var filterMember = $('.filterMember').val();
  818. var filterPaymentMethod = $('.filterPaymentMethod').val();
  819. var filterCausals = $('.filterCausals').val();
  820. var filterFrom = $('.filterFrom').val();
  821. var filterTo = $('.filterTo').val();
  822. // Salvo i filtri della ricerca
  823. localStorage.setItem("filterCommercial", filterCommercial);
  824. localStorage.setItem("filterMember", filterMember);
  825. localStorage.setItem("filterPaymentMethod", filterPaymentMethod);
  826. localStorage.setItem("filterCausals", filterCausals);
  827. localStorage.setItem("filterFrom", filterFrom);
  828. localStorage.setItem("filterTo", filterTo);
  829. $('#tablesaw-350').DataTable({
  830. searching: false,
  831. ajax: '/get_record_in?filterCommercial=' + filterCommercial + "&filterMember=" + filterMember + "&filterPaymentMethod=" + filterPaymentMethod + "&filterCausals=" + filterCausals + "&filterFrom=" + filterFrom + "&filterTo=" + filterTo,
  832. columns: [
  833. //{ data: 'id' },
  834. {
  835. data: "date",
  836. render: function (data, type){
  837. if (data == "")
  838. return " TOTALE";
  839. if (type == "sort"){
  840. return new Date(data).getTime();
  841. }
  842. // Split class and text
  843. const j = data.split(" ");
  844. const d = j[0].split("-");
  845. var ret = d[2] + "/" + d[1] + "/" + d[0];
  846. return ret;
  847. }
  848. },
  849. { data: 'total' },
  850. { data: 'first_name' },
  851. { data: 'last_name' },
  852. { data: 'commercial' },
  853. { data: 'causals' },
  854. { data: 'payment' },
  855. { data: 'status' },
  856. {
  857. data: "action",
  858. render: function (data){
  859. if (data == "")
  860. return "";
  861. const j = data.split("|");
  862. $(".totalDiv").html('Totale&nbsp;:&nbsp;<b>' + j[1] + '</b>');
  863. var ret = '';
  864. if (j[2] != 'x')
  865. {
  866. ret = '<button type="button" class="btn btn-outline-primary btn-sm" onclick="editData(' + j[0] + ')">Modifica</button>&nbsp;';
  867. ret += '<button type="button" class="btn btn-outline-danger btn-sm" onclick="deleteData(' + j[0] + ')">Annulla pagamento</button>';
  868. ret += '<button type="button" class="btn btn-outline-default btn-sm" onclick="duplicateData(' + j[0] + ')">Duplica</button>';
  869. }
  870. return ret;
  871. }
  872. },
  873. ],
  874. fixedHeader: false,
  875. order: [[0, 'desc']],
  876. thead: {
  877. 'th': {'background-color': 'blue'}
  878. },
  879. layout: {
  880. topStart: {
  881. buttons: [
  882. {
  883. extend: 'excelHtml5',
  884. title: 'Entrate',
  885. exportOptions: {
  886. columns: ":not(':last')"
  887. }
  888. },
  889. {
  890. extend: 'pdfHtml5',
  891. title: 'Entrate',
  892. exportOptions: {
  893. columns: ":not(':last')"
  894. }
  895. },
  896. {
  897. extend: 'print',
  898. text: 'Stampa',
  899. title: 'Entrate',
  900. exportOptions: {
  901. columns: ":not(':last')"
  902. }
  903. }
  904. ]
  905. }
  906. },
  907. pagingType: 'numbers',
  908. "language": {
  909. "url": "/assets/js/Italian.json"
  910. },
  911. });
  912. $('#tablesaw-350 thead tr th').addClass('col');
  913. $('#tablesaw-350 thead tr th').css("background-color", "#EDF0F2");
  914. }
  915. var isEdit = false;
  916. Livewire.on('showReceipt', (id) =>
  917. {
  918. window.open("{{env('APP_URL', '')}}/receipt/" + id, '_blank').focus();
  919. });
  920. Livewire.on('setEdit', (x) =>
  921. {
  922. isEdit = x;
  923. });
  924. Livewire.on('reload', (x) =>
  925. {
  926. location.reload();
  927. });
  928. window.onbeforeunload = function(){
  929. if (isEdit)
  930. return 'Cambiando pagina le eventuali modifiche andranno perse';
  931. };
  932. </script>
  933. @endpush