records_in.blade.php 71 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351
  1. <div class="col card--ui" id="card--dashboard">
  2. @if($fromPage != '')
  3. <a style="margin-top:20px" class="btn--ui lightGrey" href="/{{$fromPage}}?showFilters=1"><i class="fa-solid fa-arrow-left"></i></a><br><br>
  4. @endif
  5. <header id="title--section" style="display:none !important" class="d-flex align-items-center justify-content-between">
  6. <div class="title--section_name d-flex align-items-center justify-content-between">
  7. <i class="ico--ui title_section entrate me-2"></i>
  8. <h2 class="primary">@if(!$add && !$update)Entrate @else Inserimento/modifica entrata @endif</h2>
  9. </div>
  10. @if(!$add && !$update)
  11. <div class="title--section_addButton" wire:click="add()" style="cursor: pointer;">
  12. <div class="btn--ui entrata d-flex justify-items-between">
  13. <a href="#" wire:click="add()" style="color:white">Aggiungi</a>
  14. </div>
  15. </div>
  16. @endif
  17. </header>
  18. @if(!$add && !$update)
  19. <!--
  20. <button id="open-filter" onclick="pcsh1()"></button>
  21. <button id="close-filter" onclick="pcsh2()"></button>
  22. -->
  23. <section id="subheader" class="d-flex align-items-center justify-content-between">
  24. </section>
  25. @if (session()->has('receipt'))
  26. <div class="alert alert-success" role="alert">
  27. {{ session()->get('receipt') }}
  28. </div>
  29. @endif
  30. <div class="showFilter" style="display:none">
  31. <hr size="1">
  32. <div class="row g-3">
  33. <div class="col-md-2">
  34. <div class="row">
  35. <div class="col-md-12" style="margin-bottom:10px;">
  36. <b>Periodo</b>
  37. </div>
  38. <div class="col-12 mb-2">
  39. <input id="dateFrom" type="date" class="form-control filterFrom">
  40. </div>
  41. <div class="col-12">
  42. <input id="dateTo" type="date" class="form-control filterTo" >
  43. </div>
  44. <div class="col-6 mt-2">
  45. <button class="btn--ui lightGrey todayButton" style="width:100%" onclick="setToday('{{date("Y-m-d")}}')">OGGI</button>
  46. </div>
  47. <div class="col-6 mt-2">
  48. <button class="btn--ui lightGrey yesterdayButton" style="width:100%" onclick="setYesterday('{{date("Y-m-d",strtotime("-1 days"))}}')">IERI</button>
  49. </div>
  50. </div>
  51. </div>
  52. <div class="col-md-2">
  53. <div class="row">
  54. <div class="col-md-12" style="margin-bottom:10px;">
  55. <b>Tipologia</b>
  56. </div>
  57. <div class="col-12">
  58. <select name="filterCommercial" class="form-select filterCommercial">
  59. <option value="">Entrambe
  60. <option value="1">Commerciale
  61. <option value="2">Non commerciale
  62. </select>
  63. </div>
  64. </div>
  65. </div>
  66. <div class="col-md-2">
  67. <div class="row">
  68. <div class="col-md-12" style="margin-bottom:10px;">
  69. <b>Utente</b>
  70. </div>
  71. <div class="col-12">
  72. <select name="search_member_id" class="form-select filterMember">
  73. <option value="">--Seleziona--
  74. @foreach($members as $member)
  75. <option value="{{$member->id}}">{{$member->last_name}} {{$member->first_name}}
  76. @endforeach
  77. </select>
  78. </div>
  79. </div>
  80. </div>
  81. <div class="col-md-2">
  82. <div class="row">
  83. <div class="col-md-12" style="margin-bottom:10px;">
  84. <b>Metodi di pagamento</b>
  85. </div>
  86. <div class="col-12">
  87. <select name="search_payment_method_id" class="form-select filterPaymentMethod" multiple="multiple">
  88. @foreach($payments as $payment)
  89. <option value="{{$payment->id}}">{{$payment->name}}
  90. @endforeach
  91. </select>
  92. </div>
  93. </div>
  94. </div>
  95. <div class="col-md-2">
  96. <div class="row">
  97. <div class="col-md-12" style="margin-bottom:10px;">
  98. <b>Causali</b>
  99. </div>
  100. <div class="col-12">
  101. <select name="search_causal_id" class="form-select filterCausals" multiple="multiple">
  102. @foreach($causals as $causal)
  103. <option value="{{$causal["id"]}}">{!!$causal["name"]!!}
  104. @endforeach
  105. </select>
  106. </div>
  107. </div>
  108. </div>
  109. </div>
  110. <div class="row g-3">
  111. <div class="col-md-12" style="text-align:right">
  112. <button class="btn--ui lightGrey" onclick="reset()">Reset</button>
  113. <button class="btn--ui" onclick="loadDataTable()">FILTRA</button>
  114. </div>
  115. </div>
  116. <hr size="1">
  117. </div>
  118. <section id="resume-table">
  119. <div class="compare--chart_wrapper d-none"></div>
  120. <table class="table tablesaw tableHead tablesaw-stack table--lista_entrate tableHead" id="tablesaw-350" width="100%">
  121. <thead>
  122. <tr>
  123. <!--<th scope="col"></th>-->
  124. <th scope="col">Data pagamento</th>
  125. <th scope="col">Importo</th>
  126. <th scope="col">Cognome</th>
  127. <th scope="col">Nome</th>
  128. <th scope="col">Commerciale</th>
  129. <th scope="col">Causale</th>
  130. <th scope="col">Pagamento</th>
  131. <th scope="col">Stato</th>
  132. <th scope="col">...</th>
  133. </tr>
  134. </thead>
  135. <tbody id="checkall-target">
  136. </tbody>
  137. <!--<tfoot>
  138. <tr id="tfooter">
  139. <td colspan="9"><span class="total"></span></td>
  140. </tr>
  141. </tfoot>-->
  142. </table>
  143. <br><b class="totalDiv"></b>
  144. </section>
  145. @else
  146. <a name="top"></a>
  147. @if (session()->has('error'))
  148. <div class="alert alert-danger" role="alert">
  149. {{ session()->get('error') }}
  150. </div>
  151. @endif
  152. <section id="accountingEntry" class="d-flex">
  153. <div class="accountingEntry_data" wire:key='reload-{{$selectId}}'>
  154. <form class="form--accounting" >
  155. <div class="row gx-2">
  156. <div class="col-md-12">
  157. <span class="title-form d-block w-100">Tipologia</span>
  158. <div class="input-group mb-12">
  159. <div class="check--invoice d-flex align-items-center">
  160. <div class="form-check me-3">
  161. <input class="form-check-input" type="radio" value="1" wire:model="commercial" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  162. <label class="form-check-label" for="flexCheckChecked" {!!$this->dataId > 0 && !$isDuplicate ? '' : ' onclick="setCommercialType(1)"'!!}>&nbsp;Commerciale</label>
  163. </div>
  164. <div class="form-check">
  165. <input class="form-check-input" type="radio" value="0" wire:model="commercial" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  166. <label class="form-check-label" for="flexCheck" {!!$this->dataId > 0 && !$isDuplicate ? '' : ' onclick="setCommercialType(0)"'!!}>&nbsp;Non Commerciale</label>
  167. </div>
  168. </div>
  169. </div>
  170. </div>
  171. <div class="col-md-6 mt-3">
  172. <span class="title-form d-block w-100">Data pagamento</span>
  173. <div class="input-group mb-3">
  174. <input id="date" type="date" class="form-control" wire:model="date" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  175. </div>
  176. </div>
  177. <div class="col-md-6">&nbsp;</div>
  178. <div class="col-md-6">
  179. <span class="title-form d-block w-100">Utente</span>
  180. <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 && !$isDuplicate ? 'disabled' : ''}}>
  181. <option value="">--Seleziona--
  182. @foreach($members as $member)
  183. <option value="{{$member->id}}">{{$member->last_name}} {{$member->first_name}} ({{$member->fiscal_code}})
  184. @endforeach
  185. </select>
  186. @error('member_id')
  187. <div class="invalid-feedback">{{ $message }}</div>
  188. @enderror
  189. <br><br>
  190. </div>
  191. <div class="col-md-6">
  192. @if($this->dataId == 0 && !$isDuplicate)
  193. <span class="title-form d-block w-100">&nbsp;</span>
  194. <button type="button" class="btn--ui primary" data-bs-toggle="modal" data-bs-target="#userModal" style="width:50px">&nbsp;<i class="fa-solid fa-plus"></i></button>
  195. @endif
  196. @if(false && $this->member)
  197. <b>{{$this->member->first_name}} {{$this->member->last_name}}</b> {!! !$this->member->isAdult() ? '<span style="color:red;font-weight:bold">&nbsp;MINORENNE</span>' : '' !!}<br>
  198. <span class="title-form w-100">Codice fiscale</span> : {{$this->member->fiscal_code}}<br>
  199. <span class="title-form w-100">Email</span> : {{$this->member->email}}<br>
  200. <span class="title-form w-100">Borsellino virtuale</span>
  201. <b>{{number_format($virtual, 2, ".", "")}} &euro;</b><br>
  202. @if(sizeof($this->member->certificates) > 0)
  203. @php
  204. $cert = $this->member->certificates[0]
  205. @endphp
  206. @if($cert->expire_date < date("Y-m-d"))
  207. <span class="title-form w-100">Certificato medico </span><span class="badge tessera-badge suspended">scaduto</span>
  208. @endif
  209. @endif
  210. @php
  211. $status = $this->member->getStatus()["status"];
  212. $class = $status > 0 ? ($status == 2 ? 'active' : 'suspended') : 'due';
  213. $text = $status > 0 ? ($status == 2 ? 'Tesserato' : 'Sospeso') : 'Non tesserato';
  214. @endphp
  215. <span class="tablesaw-cell-content"><span class="badge tessera-badge {{$class}}">{{$text}}</span></span>
  216. @endif
  217. </div>
  218. </div>
  219. @if(false)
  220. <br>
  221. <div class="col-md-12">
  222. <div class="input-group mb-12">
  223. <div class="check--invoice d-flex align-items-center">
  224. <div class="form-check me-3">
  225. <input class="form-check-input" id="financial_movement" type="checkbox" wire:model="financial_movement" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  226. <label class="form-check-label" for="flexCheckChecked">&nbsp;&nbsp;&nbsp;Movimento finanziario</label>
  227. </div>
  228. </div>
  229. </div>
  230. </div>
  231. @endif
  232. @if($commercial)
  233. <br>
  234. <div class="col-md-12">
  235. <div class="input-group mb-12">
  236. <div class="check--invoice d-flex align-items-center">
  237. <div class="form-check me-3">
  238. <input class="form-check-input" id="corrispettivo_fiscale" type="checkbox" wire:model="corrispettivo_fiscale" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  239. <label class="form-check-label" for="flexCheckChecked">&nbsp;&nbsp;&nbsp;Corrispettivo fiscale</label>
  240. </div>
  241. </div>
  242. </div>
  243. </div>
  244. @endif
  245. @if($corrispettivo_fiscale)
  246. @if ($this->dataId > 0)
  247. <div class="row">
  248. <div class="col-md-9 mt-3">
  249. {{$this->getPaymentMethod($payment_method_id)}}
  250. </div>
  251. <div class="col-md-3 mt-3">
  252. {{formatPrice($amount)}}
  253. </div>
  254. </div>
  255. @else
  256. @foreach($payments as $payment)
  257. @if($payment->corrispettivo_fiscale)
  258. <div class="row">
  259. <div class="col-md-9 mt-3">
  260. {{$payment->name}}
  261. </div>
  262. <div class="col-md-3 mt-3">
  263. <input type="text" class="form-control totalInput text-end" id="corrispettivo_{{$payment->id}}" wire:model="corrispettivo.{{$payment->id}}" onkeyup="onlyNumberAmount(this)" placeholder="€ 0,00">
  264. </div>
  265. </div>
  266. @endif
  267. @endforeach
  268. <div class="row">
  269. <div class="col-md-9 mt-3" style="font-size: 18px;font-weight: bold;">
  270. <b>Totale</b>
  271. </div>
  272. <div class="col-md-3 mt-3" style="text-align:right;font-size: 18px;font-weight: bold;">
  273. <b>{{$this->getTotalCorrispettivo()}}</b>
  274. </div>
  275. </div>
  276. @endif
  277. @else
  278. <div class="row gx-2 mt-3">
  279. <span class="title-form d-block w-100">Metodo di pagamento</span>
  280. <div class="col-md-6" >
  281. <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%" {{$this->dataId > 0 && $deleted ? 'disabled' : ''}}>
  282. <option value="">--Seleziona--
  283. @foreach($payments as $payment)
  284. <option value="{{$payment->id}}">{{$payment->name}}
  285. @endforeach
  286. </select>
  287. @error('payment_method_id')
  288. <div class="invalid-feedback">{{ $message }}</div>
  289. @enderror
  290. </div>
  291. </div>
  292. @foreach($rows as $idx => $row)
  293. <div class="row gx-2 mt-3" >
  294. <span class="title-form d-block w-100">Causale</span>
  295. <div class="col-md-12">
  296. @if($this->dataId > 0 && !$isDuplicate)
  297. {{$this->getCausal($rows[$idx]['causal_id'])}}<br>
  298. @else
  299. <livewire:causals :type="$typeIN" :idx="$idx" :causal_id="$rows[$idx]['causal_id']" :wire:key="$idx"/>
  300. @endif
  301. @error('rows.'. $idx . '.causal_id')
  302. <span style="argin-top: 0.25rem; font-size: 0.875em; color: var(--bs-form-invalid-color);">{{ $message }}</span>
  303. @enderror
  304. </div>
  305. </div>
  306. <div class="row gx-2 mt-3">
  307. <span class="title-form d-block w-100">Dettaglio causale</span>
  308. <div class="col-md-6">
  309. <input class="form-control " id="causal_detail_{{$idx}}" type="text" placeholder="Dettaglio causale" wire:model="rows.{{$idx}}.note" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  310. </div>
  311. </div>
  312. <div class="row gx-2 mt-3 align-items-center">
  313. <div class="col-md-6">
  314. <span class="total primary">Importo</span>
  315. </div>
  316. @if ($commercial)
  317. <div class="col-md-3">
  318. <select id="rows.{{$idx}}.vat_id" class="form-select" wire:model="rows.{{$idx}}.vat_id" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  319. <option value="0">
  320. @foreach($vats as $vat)
  321. <option value="{{$vat->id}}">{{$vat->name}}
  322. @endforeach
  323. </select>
  324. </div>
  325. @else
  326. <div class="col-md-3"></div>
  327. @endif
  328. <div class="col-md-3">
  329. @if($add)
  330. <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)" onchange="setChangedAmount()" placeholder="€ 0,00" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}} >
  331. @endif
  332. @if($update)
  333. <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)" onchange="setChangedAmount()" wire:keydown.enter="update(false)" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  334. @endif
  335. @error('rows.'. $idx . '.amount')
  336. <span style="argin-top: 0.25rem; font-size: 0.875em; color: var(--bs-form-invalid-color);">{{ $message }}</span>
  337. @enderror
  338. </div>
  339. </div>
  340. <div class="row gx-2 mt-3 align-items-center">
  341. <div class="col-md-4">
  342. <span class="total primary comp">Competenza</span>
  343. </div>
  344. <div class="col-md-8">
  345. <div class="row">
  346. @if($multiP)
  347. <div class="row">
  348. <h4>Seleziona inizio e fine multiperiodo</h4>
  349. <div class="col-lg-6 col-xxl-3">
  350. <span class="title-form d-block w-100">Dal mese</span>
  351. <div class="input-group mb-3">
  352. <select class="form-select form-select-lg me-1" wire:model="multiMonthFrom" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  353. <option value="1">Gennaio</option>
  354. <option value="2">Febbraio</option>
  355. <option value="3">Marzo</option>
  356. <option value="4">Aprile</option>
  357. <option value="5">Maggio</option>
  358. <option value="6">Giugno</option>
  359. <option value="7">Luglio</option>
  360. <option value="8">Agosto</option>
  361. <option value="9">Settembre</option>
  362. <option value="10">Ottobre</option>
  363. <option value="11">Novembre</option>
  364. <option value="12">Dicembre</option>
  365. </select>
  366. </div>
  367. </div>
  368. <div class="col-lg-6 col-xxl-3">
  369. <span class="title-form d-block w-100">Anno</span>
  370. <div class="input-group mb-3">
  371. <input type="number" class="form-control" wire:model="multiYearFrom" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  372. </div>
  373. </div>
  374. <div class="col-lg-6 col-xxl-3">
  375. <span class="title-form d-block w-100">Dal mese</span>
  376. <div class="input-group mb-3">
  377. <select class="form-select form-select-lg me-1" wire:model="multiMonthTo" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  378. <option value="1">Gennaio</option>
  379. <option value="2">Febbraio</option>
  380. <option value="3">Marzo</option>
  381. <option value="4">Aprile</option>
  382. <option value="5">Maggio</option>
  383. <option value="6">Giugno</option>
  384. <option value="7">Luglio</option>
  385. <option value="8">Agosto</option>
  386. <option value="9">Settembre</option>
  387. <option value="10">Ottobre</option>
  388. <option value="11">Novembre</option>
  389. <option value="12">Dicembre</option>
  390. </select>
  391. </div>
  392. </div>
  393. <div class="col-lg-6 col-xxl-3">
  394. <span class="title-form d-block w-100">Anno</span>
  395. <div class="input-group mb-3">
  396. <input type="number" class="form-control" wire:model="multiYearTo" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  397. </div>
  398. </div>
  399. @if($this->dataId == 0 && !$isDuplicate)
  400. <div class="col-lg-6">
  401. <button type="button" class="btn--ui primary" wire:click.prevent="multiPeriodCreate({{$idx}})" style="margin-top:20px">
  402. Crea multi periodo
  403. </button>
  404. </div>
  405. <div class="col-lg-6">
  406. <button type="button" class="btn--ui lightGrey" wire:click.prevent="multiPeriodCancel()" style="margin-top:20px">
  407. Annulla multi periodo
  408. </button>
  409. </div>
  410. @endif
  411. </div>
  412. @else
  413. @foreach($row["when"] as $xxx => $w)
  414. <div class="col-md-4">
  415. <span class="title-form d-block w-100">Mese</span>
  416. <div class="input-group mb-3">
  417. <select class="form-select form-select-lg me-1" wire:model="rows.{{$idx}}.when.{{$xxx}}.month" onchange="setYear({{$idx}}, {{$xxx}})" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  418. <option value="1">Gennaio</option>
  419. <option value="2">Febbraio</option>
  420. <option value="3">Marzo</option>
  421. <option value="4">Aprile</option>
  422. <option value="5">Maggio</option>
  423. <option value="6">Giugno</option>
  424. <option value="7">Luglio</option>
  425. <option value="8">Agosto</option>
  426. <option value="9">Settembre</option>
  427. <option value="10">Ottobre</option>
  428. <option value="11">Novembre</option>
  429. <option value="12">Dicembre</option>
  430. </select>
  431. </div>
  432. </div>
  433. <div class="col-md-3">
  434. <span class="title-form d-block w-100">Anno</span>
  435. <div class="input-group mb-3">
  436. <input type="number" class="form-control" wire:model="rows.{{$idx}}.when.{{$xxx}}.year" {{$this->dataId > 0 && !$isDuplicate ? 'disabled' : ''}}>
  437. </div>
  438. </div>
  439. <div class="col-md-3">
  440. <span class="title-form d-block w-100">Valore</span>
  441. <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>
  442. </div>
  443. <div class="col-md-2"><br>
  444. @if($this->dataId == 0)
  445. <button type="button" class="btn--ui primary" wire:click.prevent="delPeriod({{$idx}}, {{$xxx}})" style="float:right">
  446. -
  447. </button>
  448. @endif
  449. </div>
  450. @endforeach
  451. @if($this->dataId == 0)
  452. <div class="d-flex justify-content-between mt-3">
  453. <button type="button" class="btn--ui lightGrey order-2" wire:click.prevent="addPeriod({{$idx}})">
  454. Aggiungi periodo
  455. </button>
  456. <button type="button" class="btn--ui_tertiary primary order-1" wire:click.prevent="multiPeriod()">
  457. Imposta multi periodo
  458. </button>
  459. </div>
  460. @endif
  461. @endif
  462. </div>
  463. </div>
  464. </div>
  465. <br><br>
  466. @if($this->dataId == 0)
  467. @if($idx > 0)
  468. <button type="button" class="btn--ui primary" wire:click.prevent="delRow({{$idx}})" style="float:right">
  469. Rimuovi causale
  470. </button>
  471. <br><br>
  472. @endif
  473. @endif
  474. <hr size="1">
  475. @endforeach
  476. @if($this->dataId == 0)
  477. <br>
  478. <button type="button" class="btn--ui primary" wire:click.prevent="addRow()">
  479. Aggiungi causale
  480. </button>
  481. @endif
  482. @endif
  483. <div class="accountingEntry--btn d-flex align-items-center justify-content-between mt-5">
  484. <a class="btn--ui lightGrey" href="/{{$fromPage}}?showFilters=1">annulla</a>
  485. @if(!$deleted)
  486. @if($canSave)
  487. @if($add)
  488. @if($commercial)
  489. @if($corrispettivo_fiscale)
  490. @if($corrispettivo_causal_id > 0)
  491. <button class="btn--ui primary" type="submit" wire:click.prevent="storeCorrispettivo()">inserisci corrispettivo fiscale</button>
  492. @else
  493. Non hai configurato una causale per il corrispettivo fiscale
  494. @endif
  495. @else
  496. <button class="btn--ui primary" type="submit" wire:click.prevent="store(false)" onclick='window.location.href = "#top";'>inserisci</button>
  497. @endif
  498. @else
  499. @if($this->member && !$commercial && !$this->member->isAdult() && $parent == '')
  500. <span style="color:red">Devi selezionare un genitore</span>
  501. @else
  502. <button class="btn--ui primary sendInvoice d-flex ms-auto" wire:click.prevent="store(true)" onclick='window.location.href = "#top";'><i class="ico--ui sendingBtn"></i><span>inserisci {{!$commercial ? 'genera ricevuta' : ''}}</span></button>
  503. @endif
  504. @endif
  505. @endif
  506. @if($update && !$corrispettivo_fiscale)
  507. @if($this->member && !$commercial && !$this->member->isAdult() && $parent == '')
  508. <span style="color:red">Devi selezionare un genitore</span>
  509. @else
  510. <button class="btn--ui primary sendInvoice d-flex ms-auto" wire:click.prevent="update({{!$commercial}})"><i class="ico--ui sendingBtn"></i><span>inserisci {{!$commercial ? 'genera ricevuta' : ''}}</span></button>
  511. @endif
  512. @endif
  513. @else
  514. <span style="color:red">Attenzione : non c'è credito sufficiente sul borsellino virtuale</span>
  515. @endif
  516. @endif
  517. </div>
  518. </form>
  519. </div>
  520. @if(!$corrispettivo_fiscale)
  521. <div class="accountingEntry_resume card--ui" style="max-height:800px;">
  522. <header>
  523. <div class="username d-flex align-items-start">
  524. <i class="ico--ui accountingResume me-2"></i>
  525. <div class="user--resume_name d-flex flex-column"><span class="primary">{{!$commercial ? 'Ricevuta' : 'Promemoria pagamento'}} {{$currentReceip ? $currentReceip->number . "/" . $currentReceip->year : ''}}</span></div></div>
  526. </header>
  527. <div class="resume--body d-flex justify-content-between flex-column">
  528. <header>
  529. @if($this->member)
  530. <ul class="resume-item mb-4 p-0">
  531. <li>
  532. <div style="background-color:#ffffff; padding:10px;">
  533. <b>{{$this->member->first_name}} {{$this->member->last_name}}</b> {!! !$this->member->isAdult() ? '<span style="color:red;font-weight:bold">&nbsp;MINORENNE</span>' : '' !!}<br>
  534. <span class="title-form w-100">Codice fiscale</span> : {{$this->member->fiscal_code}}<br>
  535. <span class="title-form w-100">Email</span> : {{$this->member->email}}<br>
  536. <span class="title-form w-100">Borsellino virtuale</span>
  537. <b>{{number_format($virtual, 2, ".", "")}} &euro;</b><br>
  538. @if(sizeof($this->member->certificates) > 0)
  539. @php
  540. $cert = $this->member->certificates[0]
  541. @endphp
  542. @if($cert->expire_date < date("Y-m-d"))
  543. <span class="title-form w-100">Certificato medico </span><span class="badge tessera-badge suspended">scaduto</span>
  544. @endif
  545. @endif
  546. @php
  547. $status = $this->member->getStatus()["status"];
  548. $class = $status > 0 ? ($status == 2 ? 'active' : 'suspended') : 'due';
  549. $text = $status > 0 ? ($status == 2 ? 'Tesserato' : 'Sospeso') : 'Non tesserato';
  550. @endphp
  551. <span class="tablesaw-cell-content"><span class="badge tessera-badge {{$class}}">{{$text}}</span></span>
  552. </div>
  553. </li>
  554. @if(!$this->member->isAdult())
  555. <li>
  556. <span class="evidence_name">
  557. <br>Seleziona un genitore
  558. <select class="form-control" wire:model="parent">
  559. <option value="">Seleziona un genitore
  560. @if($this->member->father_name != '')
  561. <option value="{{$this->member->father_name}} (C.F. {{$this->member->father_fiscal_code}})">{{$this->member->father_name}} (C.F. {{$this->member->father_fiscal_code}})
  562. @endif
  563. @if($this->member->mother_name != '')
  564. <option value="{{$this->member->mother_name}} (C.F. {{$this->member->mother_fiscal_code}})">{{$this->member->mother_name}} (C.F. {{$this->member->mother_fiscal_code}})
  565. @endif
  566. </select>
  567. </span>
  568. </li>
  569. @endif
  570. </ul>
  571. @endif
  572. <ul class="resume-item date p-0">
  573. <li><strong>Data di Pagamento</strong></li>
  574. <li>{{ date("d/m/Y", strtotime($date)) }}</li>
  575. </ul>
  576. @if(sizeof($rows) > 0)
  577. <table width="100%">
  578. <tr>
  579. <td><b>Causale</b></td>
  580. @if($commercial == 1)
  581. <td><b>Imponibile</b></td>
  582. <td><b>% Iva</b></td>
  583. <td><b>Iva</b></td>
  584. @endif
  585. <td style="float:right"><b>Totale</b></td>
  586. </tr>
  587. @foreach($rows as $row)
  588. <tr>
  589. <td>
  590. {{$this->getCausal($row["causal_id"])}}<br>
  591. {{$row["note"]}}
  592. </td>
  593. @php
  594. $vat_value = 0;
  595. @endphp
  596. @if($commercial == 1)
  597. <td>{{$row["amount"]}}</td>
  598. @php
  599. $vat_name = '';
  600. if ($row["vat_id"] > 0)
  601. {
  602. $v = \App\Models\Vat::findOrFail(intval($row["vat_id"]));
  603. $vat_name = $v->name;
  604. $vat_value = $this->currencyToDouble($row["amount"]) / 100 * $v->value;
  605. }
  606. @endphp
  607. <td>{{$vat_name}}</td>
  608. <td>{{$vat_value > 0 ? formatPrice($vat_value) : ''}}</td>
  609. @endif
  610. <td style="float:right">{{formatPrice($this->currencyToDouble($row["amount"]) + $vat_value)}}</td>
  611. </tr>
  612. @endforeach
  613. </table>
  614. @endif
  615. </header>
  616. <footer>
  617. <div class="total--wrapper">
  618. <div class="total--wrapper_amount d-flex align-items-center justify-content-between w-100 mb-3">
  619. <span class="amount_p"><strong>Importo</strong></span><span class="amount_data"><strong>{{$this->getPrice()}}</strong></span>
  620. </div>
  621. @if(false)
  622. <div class="total--wrapper_amount d-flex align-items-center justify-content-between w-100 mb-3">
  623. <span class="amount_p"><strong>Iva</strong></span><span class="amount_data"><strong>{{$this->getVat()}}</strong></span>
  624. </div>
  625. @endif
  626. @foreach($this->getVats() as $k => $v)
  627. <div class="total--wrapper_amount d-flex align-items-center justify-content-between w-100 mb-3">
  628. <span class="amount_p"><strong>{{$k}}</strong></span><span class="amount_data"><strong>{{formatPrice($v)}}</strong></span>
  629. </div>
  630. @endforeach
  631. <!--<div class="total--wrapper_tax d-flex align-items-center justify-content-between w-100 mb-2 pb-3">
  632. <span class="taxt_p">Ritenuta d’acconto (20%):</span><span class="tax_data">€ 20,00</span>
  633. </div>-->
  634. <div class="total--wrapper_netprice d-flex align-items-center justify-content-between w-100">
  635. <span class="netprice_p"><strong>Totale</strong></span><span class="netprice_data"><strong>{{$this->getTotal()}}</strong></span>
  636. </div>
  637. </div>
  638. @if($update && !$isDuplicate && !$deleted)
  639. @if($currentReceip)
  640. @if($currentReceip->status == 99)
  641. <br><b style="float:right">Annullata</b>
  642. @if($this->member && !$commercial && !$this->member->isAdult() && $parent == '')
  643. <span style="color:red">Devi selezionare un genitore</span>
  644. @else
  645. <button class="btn--ui primary sendInvoice mt-5 d-flex ms-auto" wire:click.prevent="update(true)"><i class="ico--ui sendingBtn"></i><span>salva e rigenera ricevuta</span></button>
  646. @endif
  647. @else
  648. <div class="mt-5 buttons--ricevuta d-flex align-items-center">
  649. <a target="_blank" class="btn--ui me-2 mb-2 mb-xxl-0" href="/receipt/{{$currentReceip->id}}"><i class="fa-regular fa-file-lines"></i><span>stampa ricevuta</span></a>
  650. <button class="btn--ui " wire:click.prevent="removeReceipt()"><i class="ico--ui annulla_ricevuta light"></i><span>annulla ricevuta</span></button>
  651. </div>
  652. @endif
  653. @else
  654. @if(!$corrispettivo_fiscale)
  655. @if($this->member && !$commercial && !$this->member->isAdult() && $parent == '')
  656. <span style="color:red">Devi selezionare un genitore</span>
  657. @else
  658. <button class="btn--ui primary sendInvoice mt-5 d-flex ms-auto" wire:click.prevent="update(true)"><i class="ico--ui sendingBtn"></i><span>salva {{!$commercial ? ' e genera ricevuta' : ''}}</span></button>
  659. @endif
  660. @endif
  661. @endif
  662. @endif
  663. </footer>
  664. </div>
  665. </div>
  666. @endif
  667. </section>
  668. <div wire:ignore.self class="modal fade" id="userModal" tabindex="-1" aria-labelledby="userModalLabel" aria-hidden="true">
  669. <div class="modal-dialog">
  670. <div class="modal-content">
  671. <div class="modal-header">
  672. <h5 class="modal-title" id="userModalLabel">Inserimento nuovo utente</h5>
  673. <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
  674. </div>
  675. <div class="modal-body">
  676. <div class="row">
  677. <div class="col-md-6">
  678. <label for="newMemberFirstName" class="form-label">Nome</label>
  679. <input class="form-control @error('newMemberFirstName') is-invalid @enderror" type="text" id="newMemberFirstName" placeholder="Nome" wire:model="newMemberFirstName">
  680. </div>
  681. <div class="col-md-6">
  682. <label for="newMemberLastName" class="form-label">Cognome</label>
  683. <input class="form-control @error('newMemberLastName') is-invalid @enderror" type="text" id="newMemberLastName" placeholder="Cognome" wire:model="newMemberLastName">
  684. </div>
  685. </div>
  686. <div class="row mt-2">
  687. <div class="col-md-6">
  688. <label for="newMemberEmail" class="form-label">Email</label>
  689. <input class="form-control @error('newMemberEmail') is-invalid @enderror" type="text" id="newMemberEmail" placeholder="Email" wire:model="newMemberEmail">
  690. </div>
  691. <div class="col-md-6">
  692. <label for="newMemberFiscalCode" class="form-label">Codice fiscale</label>
  693. <input class="form-control @error('newMemberFiscalCode') is-invalid @enderror" type="text" id="newMemberFiscalCode" placeholder="Codice fiscale" maxlength="16" wire:model="newMemberFiscalCode">
  694. @if($newMemberFiscalCodeExist)
  695. <span style="color:red">Il codice fiscale inserito esiste</span>
  696. @endif
  697. </div>
  698. </div>
  699. <div class="row mt-2">
  700. <div class="col-md-6">
  701. <input type="checkbox" id="newMemberToComplete" wire:model="newMemberToComplete">
  702. <label for="newMemberToComplete" class="form-label">Tesserato</label>
  703. </div>
  704. <div class="col-md-6"></div>
  705. </div>
  706. </div>
  707. <div class="modal-footer">
  708. <button type="button" class="btn--ui lightGrey" data-bs-dismiss="modal">Annulla</button>
  709. <button type="button" class="btn--ui btn-primary" wire:click.prevent="createMember()">Salva</button>
  710. </div>
  711. </div>
  712. </div>
  713. </div>
  714. @endif
  715. </div>
  716. @push('scripts')
  717. <link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/css/select2.min.css" rel="stylesheet" />
  718. <style>
  719. table.tableHead thead {
  720. /* Important */
  721. position: sticky;
  722. z-index: 100;
  723. top: 0;
  724. }
  725. .select2-container--default .select2-selection--single{
  726. background-color: #E9F0F5;
  727. border: 0.0625rem solid #DFE5EB;
  728. font-size: 0.75rem;
  729. }
  730. .select2-selection
  731. {
  732. height: 38px !important;
  733. }
  734. .select2-selection__rendered
  735. {
  736. padding-top:3px;
  737. }
  738. .select2 {
  739. width:100% !important;
  740. }
  741. .page-link.active, .active > .page-link {
  742. background-color:#006099 !important;
  743. }
  744. /* .total.primary
  745. {
  746. font-size:38px !important;
  747. } */
  748. /* .total.primary.comp
  749. {
  750. font-size:32px !important;
  751. } */
  752. </style>
  753. <script src="https://code.jquery.com/jquery-2.2.4.min.js" integrity="sha256-BbhdlvQf/xTY9gja0Dq3HiwQF8LaCRTXxZKRutelT44=" crossorigin="anonymous"></script>
  754. <script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/js/select2.min.js"></script>
  755. @endpush
  756. @push('scripts')
  757. <script>
  758. function formatResult(node) {
  759. var output = node.text.split(/[,-]+/).pop();
  760. var $result = $('<span style="padding-left:' + (20 * (node.text.match(/-/g) || []).length) + 'px;">' + output + '</span>');
  761. return $result;
  762. };
  763. function matchStart(params, data) {
  764. params.term = params.term || '';
  765. if (data.text.toUpperCase().indexOf(params.term.toUpperCase()) == 0) {
  766. return data;
  767. }
  768. return false;
  769. }
  770. @if($refreshAfter == 1)
  771. setTimeout(() => {
  772. // $('.causalClass').select2();
  773. $('.causalClass').select2({
  774. matcher: function(params, data) {
  775. return matchStart(params, data);
  776. }
  777. });
  778. $('.memberClass').select2({
  779. tags: false
  780. });
  781. $('.paymentClass').select2({
  782. matcher: function(params, data) {
  783. return matchStart(params, data);
  784. }
  785. });
  786. }, 100);
  787. setTimeout(() => {
  788. var element = document.getElementById('causal_detail_0');
  789. element.dispatchEvent(new Event('input'));
  790. console.log("ASDASDSA");
  791. }, 1000);
  792. @endif
  793. window.livewire.on('refresh', () => {
  794. // $('.causalClass').select2();
  795. $('.memberClass').select2({
  796. tags: false
  797. });
  798. $('.paymentClass').select2({
  799. matcher: function(params, data) {
  800. return matchStart(params, data);
  801. }
  802. });
  803. });
  804. Livewire.on('load-select', () => {
  805. $('.causalClass').each(function(i, obj) {
  806. $(obj).select2({
  807. //data: data,
  808. /*formatSelection: function(item) {
  809. return item.text
  810. },*/
  811. templateResult: formatResult
  812. });
  813. $(obj).on('change', function (e) {
  814. var data = $(obj).select2("val");
  815. var name = $(obj).select2().attr("name");
  816. @this.set(name, data);
  817. });
  818. });
  819. $('.memberClass').select2({
  820. tags: false
  821. });
  822. $('.memberClass').on('change', function (e) {
  823. var data = $('.memberClass').select2("val");
  824. @this.set('member_id', data);
  825. });
  826. $('.paymentClass').select2({
  827. matcher: function(params, data) {
  828. return matchStart(params, data);
  829. }
  830. });
  831. $('.paymentClass').on('change', function (e) {
  832. var data = $('.paymentClass').select2("val");
  833. @this.set('payment_method_id', data);
  834. });
  835. $('.filterCommercial').select2();
  836. $('.filterMember').select2();
  837. /*$('.filterMember').on('change', function (e) {
  838. var data = $('.filterMember').select2("val");
  839. @this.set('filterMember', data);
  840. @this.search();
  841. });*/
  842. $('.filterPaymentMethod').select2();
  843. $('.filterPaymentMethod').on('change', function (e) {
  844. //var data = $('.filterPaymentMethod').select2("val");
  845. //@this.set('filterPaymentMethod', data);
  846. });
  847. $('.filterCausals').select2();
  848. $('.filterCausals').on('change', function (e) {
  849. //var data = $('.filterCausals').select2("val");
  850. //@this.set('filterCausals', data);
  851. });
  852. });
  853. Livewire.on('hide-search', () => {
  854. //pcsh2();
  855. });
  856. $('.filterPaymentMethod').select2();
  857. $('.filterPaymentMethod').on('change', function (e) {
  858. //var data = $('.filterPaymentMethod').select2("val");
  859. //@this.set('filterPaymentMethod', data);
  860. });
  861. $('.filterCausals').select2();
  862. $('.filterCausals').on('change', function (e) {
  863. //var data = $('.filterCausals').select2("val");
  864. //@this.set('filterCausals', data);
  865. });
  866. window.livewire.on('saved', () => {
  867. $('#userModal').modal('hide');
  868. });
  869. window.livewire.on('reloadMembers', () => {
  870. $('.memberClass').select2("destroy");
  871. $('.memberClass').select2({
  872. tags: false
  873. });
  874. });
  875. $('.filterCommercial').select2();
  876. $('.filterMember').select2();
  877. /*$('.filterMember').on('change', function (e) {
  878. var data = $('.filterMember').select2("val");
  879. @this.set('filterMember', data);
  880. @this.search();
  881. });*/
  882. //$('.filterPaymentMethod').select2();
  883. function onlyNumberAmount(input) {
  884. let v = input.value.replace(/\D+/g, '');
  885. if (v.length > 14) v = v.slice(0, 14);
  886. input.value = "€ " + v.replace(/(\d)(\d\d)$/, "$1,$2").replace(/(^\d{1,3}|\d{3})(?=(?:\d{3})+(?:,|$))/g, '$1.');
  887. }
  888. function setChangedAmount() {
  889. @this.setAmount();
  890. }
  891. </script>
  892. <link href="/css/datatables.css" rel="stylesheet" />
  893. <script src="/assets/js/datatables.js"></script>
  894. <script src="https://cdn.datatables.net/buttons/3.0.2/js/buttons.dataTables.js"></script>
  895. <script src="https://cdnjs.cloudflare.com/ajax/libs/jszip/3.10.1/jszip.min.js"></script>
  896. <script src="https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.2.7/pdfmake.min.js"></script>
  897. <script src="https://cdnjs.cloudflare.com/ajax/libs/pdfmake/0.2.7/vfs_fonts.js"></script>
  898. <script>
  899. $(document).ready(function() {
  900. // Carico i dati dal local storage
  901. /*var filterCommercial = localStorage.getItem("filterCommercial");
  902. if (filterCommercial)
  903. {
  904. //$('input[name="filterCommercial"]').val(filterCommercial);
  905. $('input[name="filterCommercial"]').filter('[value="' + filterCommercial + '"]').attr('checked', true);
  906. setFilterCommercial(filterCommercial);
  907. }
  908. var filterMember = localStorage.getItem("filterMember");
  909. if (filterMember)
  910. {
  911. $('.filterMember').val(filterMember);
  912. $('.filterMember').trigger('change');
  913. }
  914. var filterPaymentMethod = localStorage.getItem("filterPaymentMethod");
  915. if (filterPaymentMethod)
  916. {
  917. $('.filterPaymentMethod').val(filterPaymentMethod);
  918. $('.filterPaymentMethod').trigger('change');
  919. }
  920. var filterCausals = localStorage.getItem("filterCausals");
  921. if (filterCausals)
  922. {
  923. $('.filterCausals').val(filterCausals);
  924. $('.filterCausals').trigger('change');
  925. }
  926. var filterFrom = localStorage.getItem("filterFrom");
  927. if (filterFrom)
  928. {
  929. $('.filterFrom').val(filterFrom);
  930. }
  931. var filterTo = localStorage.getItem("filterTo");
  932. if (filterTo)
  933. {
  934. $('.filterTo').val(filterTo);
  935. }
  936. */
  937. loadDataTable();
  938. } );
  939. @if(isset($_GET["showFilters"]))
  940. var filterCommercial = localStorage.getItem("filterCommercialRecordIn");
  941. if (filterCommercial)
  942. {
  943. $('.filterCommercial').val(filterCommercial);
  944. $('.filterCommercial').trigger('change');
  945. }
  946. var filterMember = localStorage.getItem("filterMemberRecordIn");
  947. if (filterMember)
  948. {
  949. $('.filterMember').val(filterMember);
  950. $('.filterMember').trigger('change');
  951. }
  952. var filterPaymentMethod = localStorage.getItem("filterPaymentMethodRecordIn");
  953. if (filterPaymentMethod)
  954. {
  955. $('.filterPaymentMethod').val(filterPaymentMethod);
  956. $('.filterPaymentMethod').trigger('change');
  957. }
  958. var filterCausals = localStorage.getItem("filterCausalsRecordIn");
  959. if (filterCausals)
  960. {
  961. $('.filterCausals').val(filterCausals);
  962. $('.filterCausals').trigger('change');
  963. }
  964. var filterFrom = localStorage.getItem("filterFromRecordIn");
  965. if (filterFrom)
  966. {
  967. $('.filterFrom').val(filterFrom);
  968. }
  969. var filterTo = localStorage.getItem("filterToRecordIn");
  970. if (filterTo)
  971. {
  972. $('.filterTo').val(filterTo);
  973. }
  974. @endif
  975. var isFilter = false;
  976. $(document).ready(function() {
  977. $(document).on("click",".showHideFilter",function() {
  978. if (isFilter)
  979. {
  980. isFilter = false;
  981. $(".showFilter").hide();
  982. }
  983. else
  984. {
  985. isFilter = true;
  986. $(".showFilter").show();
  987. }
  988. });
  989. } );
  990. function editData(id)
  991. {
  992. @this.edit(id);
  993. }
  994. function duplicateData(id)
  995. {
  996. @this.duplicate(id);
  997. }
  998. function deleteData(id)
  999. {
  1000. if (confirm('Sei sicuro?'))
  1001. @this.delete(id);
  1002. }
  1003. Livewire.on('load-data-table', () => {
  1004. setTimeout(function() {loadDataTable()}, 100);
  1005. });
  1006. Livewire.on('destroy-data-table', () => {
  1007. $('#tablesaw-350').DataTable().destroy();
  1008. });
  1009. function destroyDataTable()
  1010. {
  1011. $('#tablesaw-350').DataTable().destroy();
  1012. }
  1013. function reset()
  1014. {
  1015. $(".todayButton").addClass("lightGrey");
  1016. $(".yesterdayButton").addClass("lightGrey");
  1017. $('.filterCommercial').val('').trigger('change');
  1018. $('.filterMember').val('');
  1019. $('.filterMember').trigger('change');
  1020. $('.filterPaymentMethod').val('');
  1021. $('.filterPaymentMethod').trigger('change');
  1022. $('.filterCausals').val('');
  1023. $('.filterCausals').trigger('change');
  1024. $('.filterFrom').val('');
  1025. $('.filterTo').val('');
  1026. //localStorage.clear();
  1027. loadDataTable();
  1028. }
  1029. function loadDataTable(){
  1030. if ( $.fn.DataTable.isDataTable('#tablesaw-350') ) {
  1031. $('#tablesaw-350').DataTable().destroy();
  1032. }
  1033. // filterCommercial = $('input[name="filterCommercial"]:checked').val();
  1034. var filterCommercial = $('.filterCommercial').val();
  1035. var filterMember = $('.filterMember').val();
  1036. var filterPaymentMethod = $('.filterPaymentMethod').val();
  1037. var filterCausals = $('.filterCausals').val();
  1038. var filterFrom = $('.filterFrom').val();
  1039. var filterTo = $('.filterTo').val();
  1040. // Salvo i filtri della ricerca
  1041. localStorage.setItem("filterCommercialRecordIn", filterCommercial);
  1042. localStorage.setItem("filterMemberRecordIn", filterMember);
  1043. localStorage.setItem("filterPaymentMethodRecordIn", filterPaymentMethod);
  1044. localStorage.setItem("filterCausalsRecordIn", filterCausals);
  1045. localStorage.setItem("filterFromRecordIn", filterFrom);
  1046. localStorage.setItem("filterToRecordIn", filterTo);
  1047. var totalString = "";
  1048. $('#tablesaw-350').DataTable({
  1049. //searching: false,
  1050. /*fixedHeader: {
  1051. header: true,
  1052. footer: true
  1053. },
  1054. scrollCollapse: true,
  1055. scrollX: true,
  1056. scrollY: 800,*/
  1057. serverSide: true,
  1058. ajax: {
  1059. url : '/get_record_in?filterCommercial=' + filterCommercial + "&filterMember=" + filterMember + "&filterPaymentMethod=" + filterPaymentMethod + "&filterCausals=" + filterCausals + "&filterFrom=" + filterFrom + "&filterTo=" + filterTo,
  1060. dataSrc: function (json){
  1061. if(json.totals){
  1062. $(".totalDiv").html('Totale&nbsp;:&nbsp;<b>' + json.totals + '</b>');
  1063. }
  1064. return json.data;
  1065. }
  1066. },
  1067. columns: [
  1068. //{ data: 'id' },
  1069. {
  1070. data: "date",
  1071. render: function (data, type){
  1072. if (data == "")
  1073. return " TOTALE";
  1074. if (type == "sort"){
  1075. return new Date(data).getTime();
  1076. }
  1077. // Split class and text
  1078. const j = data.split(" ");
  1079. const d = j[0].split("-");
  1080. var ret = d[2] + "/" + d[1] + "/" + d[0];
  1081. return ret;
  1082. }
  1083. },
  1084. { data: 'total', className: "numericCol" },
  1085. { data: 'last_name' },
  1086. { data: 'first_name' },
  1087. { data: 'commercial' },
  1088. { data: 'causals', "orderable": false, },
  1089. { data: 'payment', "orderable": false, },
  1090. { data: 'status', "orderable": false, },
  1091. {
  1092. data: "action",
  1093. render: function (data){
  1094. if (data == "")
  1095. return "";
  1096. const j = data.split("|");
  1097. //$(".totalDiv").html('Totale&nbsp;:&nbsp;<b>' + j[1] + '</b>');
  1098. //$(".total").html('Totale&nbsp;:&nbsp;<b>' + j[1] + '</b>');
  1099. //totalString = j[1];
  1100. var ret = '';
  1101. if (j[2] != 'x')
  1102. {
  1103. ret = '<button type="button" class="btn" onclick="editData(' + j[0] + ')" data-bs-toggle="popover" data-bs-trigger="hover focus" data-bs-placement="bottom" data-bs-content="Modifica"><i class="fa-regular fa-pen-to-square"></i></button>&nbsp;';
  1104. ret += '<button type="button" class="btn" onclick="deleteData(' + j[0] + ')" data-bs-toggle="popover" data-bs-trigger="hover focus" data-bs-placement="bottom" data-bs-content="Elimina"><i class="fa-regular fa-trash-can"></i></button>';
  1105. ret += '<button type="button" class="btn btn-outline-default btn-sm" onclick="duplicateData(' + j[0] + ')" data-bs-toggle="popover" data-bs-trigger="hover focus" data-bs-placement="bottom" data-bs-content="Duplica"><i class="fa-regular fa-copy"></i></button>';
  1106. }
  1107. else
  1108. {
  1109. ret = '<button type="button" class="btn" onclick="editData(' + j[0] + ')" data-bs-toggle="popover" data-bs-trigger="hover focus" data-bs-placement="bottom" data-bs-content="Visualizza"><i class="fa-regular fa-file"></i></button>&nbsp;';
  1110. }
  1111. return ret;
  1112. }
  1113. },
  1114. ],
  1115. rowCallback: function( row, data, index ) {
  1116. if (data["last_name"] == '') {
  1117. $(row).hide();
  1118. $(row).remove();
  1119. }
  1120. },
  1121. fixedHeader: false,
  1122. order: [[0, 'desc']],
  1123. thead: {
  1124. 'th': {'background-color': 'blue'}
  1125. },
  1126. layout: {
  1127. topStart : null,
  1128. topEnd : null,
  1129. top1A: {
  1130. buttons: [
  1131. {
  1132. extend: 'collection',
  1133. text: 'Esporta',
  1134. buttons: [
  1135. {
  1136. extend: 'excelHtml5',"action":newexportaction,
  1137. title: 'Entrate',
  1138. exportOptions: {
  1139. columns: ":not(':last')"
  1140. }
  1141. },
  1142. {
  1143. extend: 'pdfHtml5',"action":newexportaction,
  1144. title: 'Entrate',
  1145. exportOptions: {
  1146. columns: ":not(':last')"
  1147. }
  1148. },
  1149. {
  1150. extend: 'print',"action":newexportaction,
  1151. text: 'Stampa',
  1152. title: 'Entrate',
  1153. exportOptions: {
  1154. columns: ":not(':last')"
  1155. }
  1156. }
  1157. ],
  1158. dropup: true
  1159. }
  1160. ]
  1161. },
  1162. top1B : {
  1163. pageLength: {
  1164. menu: [[10, 25, 50, 100, 100000], [10, 25, 50, 100, "Tutti"]]
  1165. }
  1166. },
  1167. top1C :'search',
  1168. },
  1169. pagingType: 'numbers',
  1170. "language": {
  1171. "url": "/assets/js/Italian.json"
  1172. },
  1173. "fnInitComplete": function (oSettings, json) {
  1174. var html = '&nbsp;<a href="#" class="showHideFilter btn--ui"><i class="fa-solid fa-sliders"></i></a>';
  1175. html += '&nbsp;<a href="#" class="addData btn--ui"><i class="fa-solid fa-plus"></i></a>';
  1176. $(".dt-search").append(html);
  1177. }
  1178. });
  1179. $('#tablesaw-350 thead tr th').addClass('col');
  1180. $('#tablesaw-350 thead tr th').css("background-color", "#f6f8fa");
  1181. $('#tablesaw-350').on('draw.dt', function() {
  1182. $('[data-bs-toggle="popover"]').popover()
  1183. });
  1184. }
  1185. $(document).ready(function() {
  1186. $(document).on("click",".addData",function() {
  1187. $(".title--section_addButton").trigger("click")
  1188. });
  1189. } );
  1190. var isEdit = false;
  1191. Livewire.on('showReceipt', (id) =>
  1192. {
  1193. window.open("{{env('APP_URL', '')}}/receipt/" + id, '_blank').focus();
  1194. });
  1195. Livewire.on('setEdit', (x) =>
  1196. {
  1197. isEdit = x;
  1198. });
  1199. Livewire.on('reload', (x) =>
  1200. {
  1201. location.reload();
  1202. });
  1203. window.onbeforeunload = function(){
  1204. if (isEdit)
  1205. return 'Cambiando pagina le eventuali modifiche andranno perse';
  1206. };
  1207. function setCommercialType(t)
  1208. {
  1209. @this.set('commercial', t);
  1210. }
  1211. Livewire.on('goToAnchor', () =>
  1212. {
  1213. console.log("aaa");
  1214. window.location.href = "#top";
  1215. });
  1216. function setYear(idx, xxx)
  1217. {
  1218. @this.setYear(idx, xxx);
  1219. }
  1220. </script>
  1221. @endpush