records_in.blade.php 85 KB

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