records_in.blade.php 81 KB

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