records_in.blade.php 77 KB

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