records_in.blade.php 72 KB

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