feat(donations): Donations reactive create and load into datatable
This commit is contained in:
		| @@ -1,7 +1,7 @@ | ||||
| <script> | ||||
|   import { _ } from "svelte-i18n"; | ||||
|   import { clickOutside } from "../base/outsideclick"; | ||||
|    | ||||
|  | ||||
|   import { | ||||
|     DonationService, | ||||
|     DonorService, | ||||
| @@ -9,9 +9,10 @@ | ||||
|   } from "@odit/lfk-client-js"; | ||||
|   import Select from "svelte-select"; | ||||
|   import Toastify from "toastify-js"; | ||||
| import { is_promise } from "svelte/internal"; | ||||
|   import { is_promise } from "svelte/internal"; | ||||
|   import { createEventDispatcher } from "svelte"; | ||||
|   export let modal_open; | ||||
|   export let current_donations; | ||||
|   const dispatch = createEventDispatcher(); | ||||
|   const getDonorLabel = (option) => | ||||
|     option.firstname + " " + (option.middlename || "") + " " + option.lastname; | ||||
|   const filterDonors = (label, filterText, option) => | ||||
| @@ -59,16 +60,16 @@ import { is_promise } from "svelte/internal"; | ||||
|       let amount_cent = Math.floor(amount_input * 100); | ||||
|       processed_last_submit = false; | ||||
|       const toast = Toastify({ | ||||
|         text: $_('adding-donation'), | ||||
|         text: $_("adding-donation"), | ||||
|         duration: -1, | ||||
|       }).showToast(); | ||||
|       if (is_fixed) { | ||||
|         let postdata = { | ||||
|           donor, | ||||
|           amount: amount_cent, | ||||
|           paidAmount: 0 | ||||
|           paidAmount: 0, | ||||
|         }; | ||||
|         if(is_paid){ | ||||
|         if (is_paid) { | ||||
|           postdata.paidAmount = amount_cent; | ||||
|         } | ||||
|         DonationService.donationControllerPostFixed(postdata) | ||||
| @@ -79,12 +80,11 @@ import { is_promise } from "svelte/internal"; | ||||
|             modal_open = false; | ||||
|             // | ||||
|             Toastify({ | ||||
|               text: $_('donation_added'), | ||||
|               text: $_("donation_added"), | ||||
|               duration: 500, | ||||
|               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||
|             }).showToast(); | ||||
|             current_donations.push(result); | ||||
|             current_donations = current_donations; | ||||
|             dispatch("created", { donations: [result] }); | ||||
|           }) | ||||
|           .catch((err) => { | ||||
|             // | ||||
| @@ -108,12 +108,11 @@ import { is_promise } from "svelte/internal"; | ||||
|             modal_open = false; | ||||
|             // | ||||
|             Toastify({ | ||||
|               text: $_('donation_added'), | ||||
|               text: $_("donation_added"), | ||||
|               duration: 500, | ||||
|               backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||
|             }).showToast(); | ||||
|             current_donations.push(result); | ||||
|             current_donations = current_donations; | ||||
|             dispatch("created", { donations: [result] }); | ||||
|           }) | ||||
|           .catch((err) => { | ||||
|             // | ||||
| @@ -128,6 +127,207 @@ import { is_promise } from "svelte/internal"; | ||||
|   } | ||||
| </script> | ||||
|  | ||||
| {#if modal_open} | ||||
|   <div | ||||
|     class="fixed z-10 inset-0 overflow-y-auto" | ||||
|     use:clickOutside | ||||
|     on:click_outside={() => { | ||||
|       modal_open = false; | ||||
|     }} | ||||
|   > | ||||
|     <div | ||||
|       class="flex items-end justify-center min-h-screen pt-4 px-4 pb-20 text-center sm:block sm:p-0" | ||||
|     > | ||||
|       <div class="fixed inset-0 transition-opacity" aria-hidden="true"> | ||||
|         <div | ||||
|           class="absolute inset-0 bg-gray-500 opacity-75" | ||||
|           data-id="modal_backdrop" | ||||
|         /> | ||||
|       </div> | ||||
|       <span | ||||
|         class="hidden sm:inline-block sm:align-middle sm:h-screen" | ||||
|         aria-hidden="true">​</span | ||||
|       > | ||||
|       <div | ||||
|         class="inline-block align-bottom bg-white rounded-lg text-left shadow-xl transform transition-all sm:my-8 sm:align-middle sm:max-w-lg sm:w-full" | ||||
|         role="dialog" | ||||
|         aria-modal="true" | ||||
|         aria-labelledby="modal-headline" | ||||
|       > | ||||
|         <div class="bg-white px-4 pt-5 pb-4 sm:p-6 sm:pb-4"> | ||||
|           <div class="sm:flex sm:items-start"> | ||||
|             <div | ||||
|               class="mx-auto flex-shrink-0 flex items-center justify-center h-12 w-12 rounded-full bg-blue-100 sm:mx-0 sm:h-10 sm:w-10" | ||||
|             > | ||||
|               <svg | ||||
|                 class="h-6 w-6 text-blue-600" | ||||
|                 fill="currentColor" | ||||
|                 xmlns="http://www.w3.org/2000/svg" | ||||
|                 viewBox="0 0 24 24" | ||||
|                 width="24" | ||||
|                 height="24" | ||||
|                 ><path fill="none" d="M0 0h24v24H0z" /> | ||||
|                 <path | ||||
|                   d="M14 2a8 8 0 013.3 15.3A8 8 0 116.7 6.7 8 8 0 0114 2zm-3 7H9v1a2.5 2.5 0 00-.16 5h2.25a.5.5 0 010 1H7v2h2v1h2v-1a2.5 2.5 0 00.16-5H8.91a.5.5 0 010-1H13v-2h-2V9zm3-5a5.99 5.99 0 00-4.48 2.01 8 8 0 018.47 8.47A6 6 0 0014 4z" | ||||
|                 /></svg | ||||
|               > | ||||
|             </div> | ||||
|             <div class="mt-3 text-center sm:mt-0 sm:ml-4 sm:text-left"> | ||||
|               <h3 class="text-lg leading-6 font-medium text-gray-900"> | ||||
|                 {#if is_fixed} | ||||
|                   {$_("create-a-new-fixed-donation")} | ||||
|                 {:else}{$_("create-a-new-distance-donation")}{/if} | ||||
|               </h3> | ||||
|               <label class="content-center align-middle object-center"> | ||||
|                 <span class="ml-2 text-base" class:text-gray-300={is_fixed} | ||||
|                   >{$_("distance-donation")}</span | ||||
|                 > | ||||
|                 <input | ||||
|                   class="toggle relative w-10 h-5 transition-all duration-200 ease-in-out bg-gray-400 rounded-full shadow-inner outline-none appearance-none align-middle" | ||||
|                   type="checkbox" | ||||
|                   bind:checked={is_fixed} | ||||
|                 /> | ||||
|                 <span class="ml-2 text-base" class:text-gray-300={!is_fixed} | ||||
|                   >{$_("fixed-donation")}</span | ||||
|                 > | ||||
|               </label> | ||||
|               <div class="mt-2 mb-6"> | ||||
|                 <p class="text-sm text-gray-500"> | ||||
|                   {$_( | ||||
|                     "please-provide-the-nessecary-information-to-create-a-new-donation" | ||||
|                   )} | ||||
|                 </p> | ||||
|               </div> | ||||
|               <div class="grid grid-cols-6 gap-6"> | ||||
|                 <div class="col-span-6"> | ||||
|                   <label | ||||
|                     for="donor" | ||||
|                     class="block text-sm font-medium text-gray-700" | ||||
|                     >{$_("donor")}</label | ||||
|                   > | ||||
|                   <Select | ||||
|                     containerClasses="rounded-l-md mt-1 focus:ring-indigo-500 focus:border-indigo-500 block w-full shadow-sm rounded-l-md sm:text-sm border-gray-300 border bg-gray-50 text-gray-500 rounded-md p-2" | ||||
|                     itemFilter={(label, filterText, option) => | ||||
|                       filterDonors(label, filterText, option)} | ||||
|                     items={donors} | ||||
|                     showChevron={true} | ||||
|                     placeholder={$_("search-for-donor-name-or-id")} | ||||
|                     noOptionsMessage={$_("no-donors-found")} | ||||
|                     on:select={(selectedValue) => | ||||
|                       (donor = selectedValue.detail.value.id)} | ||||
|                     on:clear={() => (donors = null)} | ||||
|                   /> | ||||
|                 </div> | ||||
|                 {#if !is_fixed} | ||||
|                   <div class="col-span-6"> | ||||
|                     <label | ||||
|                       for="donor" | ||||
|                       class="block text-sm font-medium text-gray-700" | ||||
|                       >{$_("runner")}</label | ||||
|                     > | ||||
|                     <Select | ||||
|                       containerClasses="rounded-l-md mt-1 focus:ring-indigo-500 focus:border-indigo-500 block w-full shadow-sm rounded-l-md sm:text-sm border-gray-300 border bg-gray-50 text-gray-500 rounded-md p-2" | ||||
|                       itemFilter={(label, filterText, option) => | ||||
|                         filterDonors(label, filterText, option)} | ||||
|                       items={runners} | ||||
|                       showChevron={true} | ||||
|                       placeholder={$_("search-for-runner-by-name-or-id")} | ||||
|                       noOptionsMessage={$_("no-runners-found")} | ||||
|                       on:select={(selectedValue) => | ||||
|                         (runner = selectedValue.detail.value.id)} | ||||
|                       on:clear={() => (runner = null)} | ||||
|                     /> | ||||
|                   </div> | ||||
|                 {/if} | ||||
|                 <div class="col-span-6"> | ||||
|                   <label | ||||
|                     for="donation_amount_eur" | ||||
|                     class="block text-sm font-medium text-gray-700" | ||||
|                   > | ||||
|                     {#if !is_fixed} | ||||
|                       {$_("amount-per-kilometer")} | ||||
|                     {:else}{$_("donation-amount")}{/if}</label | ||||
|                   > | ||||
|                   <div class="mt-1 flex rounded-md shadow-sm"> | ||||
|                     <input | ||||
|                       autocomplete="off" | ||||
|                       class:border-red-500={!is_amount_valid} | ||||
|                       class:focus:border-red-500={!is_amount_valid} | ||||
|                       class:focus:ring-red-500={!is_amount_valid} | ||||
|                       bind:value={amount_input} | ||||
|                       type="number" | ||||
|                       step="0.01" | ||||
|                       name="donation_amount_eur" | ||||
|                       class="focus:ring-indigo-500 focus:border-indigo-500 flex-1 block w-full rounded-none rounded-l-md sm:text-sm border-gray-300 border bg-gray-50 text-gray-500 p-2" | ||||
|                       placeholder="2.00" | ||||
|                     /> | ||||
|                     <span | ||||
|                       class="inline-flex items-center px-3 rounded-r-md border border-gray-300 bg-gray-50 text-gray-500 text-sm" | ||||
|                       >€</span | ||||
|                     > | ||||
|                   </div> | ||||
|                   {#if !is_amount_valid} | ||||
|                     <span | ||||
|                       class="flex items-center font-medium tracking-wide text-red-500 text-xs mt-1 ml-1" | ||||
|                     > | ||||
|                       {$_("donation-amount-must-be-greater-that-0-00eur")} | ||||
|                     </span> | ||||
|                   {/if} | ||||
|                 </div> | ||||
|                 {#if is_fixed} | ||||
|                   <div class="col-span-6"> | ||||
|                     <label | ||||
|                       for="paid" | ||||
|                       class="block text-sm font-medium text-gray-700" | ||||
|                       >{$_("already-paid")}</label | ||||
|                     > | ||||
|                     <p class="text-gray-500"> | ||||
|                       <input | ||||
|                         id="paid" | ||||
|                         bind:checked={is_paid} | ||||
|                         name="paid" | ||||
|                         type="checkbox" | ||||
|                         class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300 rounded" | ||||
|                       /> | ||||
|                       <span class="align-text-bottom"> | ||||
|                         {#if is_paid} | ||||
|                           {$_("paid")} | ||||
|                         {:else} | ||||
|                           {$_("open")} | ||||
|                         {/if} | ||||
|                       </span> | ||||
|                     </p> | ||||
|                   </div> | ||||
|                 {/if} | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|         <div class="bg-gray-50 px-4 py-3 sm:px-6 sm:flex sm:flex-row-reverse"> | ||||
|           <button | ||||
|             disabled={!createbtnenabled} | ||||
|             class:opacity-50={!createbtnenabled} | ||||
|             on:click={submit} | ||||
|             type="button" | ||||
|             class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-600 text-base font-medium text-white hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm" | ||||
|           > | ||||
|             {$_("create")} | ||||
|           </button> | ||||
|           <button | ||||
|             on:click={() => { | ||||
|               modal_open = false; | ||||
|             }} | ||||
|             type="button" | ||||
|             class="mt-3 w-full inline-flex justify-center rounded-md border border-gray-300 shadow-sm px-4 py-2 bg-white text-base font-medium text-gray-700 hover:bg-gray-50 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-indigo-500 sm:mt-0 sm:ml-3 sm:w-auto sm:text-sm" | ||||
|           > | ||||
|             {$_("cancel")} | ||||
|           </button> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| {/if} | ||||
|  | ||||
| <style> | ||||
|   .toggle:before { | ||||
|     content: ""; | ||||
| @@ -152,173 +352,3 @@ import { is_promise } from "svelte/internal"; | ||||
|     left: 1.25rem; | ||||
|   } | ||||
| </style> | ||||
|  | ||||
| {#if modal_open} | ||||
|   <div | ||||
|     class="fixed z-10 inset-0 overflow-y-auto" | ||||
|      | ||||
|     use:clickOutside | ||||
|     on:click_outside={() => { | ||||
|       modal_open = false; | ||||
|     }}> | ||||
|     <div | ||||
|       class="flex items-end justify-center min-h-screen pt-4 px-4 pb-20 text-center sm:block sm:p-0"> | ||||
|       <div class="fixed inset-0 transition-opacity" aria-hidden="true"> | ||||
|         <div | ||||
|           class="absolute inset-0 bg-gray-500 opacity-75" | ||||
|           data-id="modal_backdrop" /> | ||||
|       </div> | ||||
|       <span | ||||
|         class="hidden sm:inline-block sm:align-middle sm:h-screen" | ||||
|         aria-hidden="true">​</span> | ||||
|       <div | ||||
|         class="inline-block align-bottom bg-white rounded-lg text-left shadow-xl transform transition-all sm:my-8 sm:align-middle sm:max-w-lg sm:w-full" | ||||
|         role="dialog" | ||||
|         aria-modal="true" | ||||
|         aria-labelledby="modal-headline"> | ||||
|         <div class="bg-white px-4 pt-5 pb-4 sm:p-6 sm:pb-4"> | ||||
|           <div class="sm:flex sm:items-start"> | ||||
|             <div | ||||
|               class="mx-auto flex-shrink-0 flex items-center justify-center h-12 w-12 rounded-full bg-blue-100 sm:mx-0 sm:h-10 sm:w-10"> | ||||
|               <svg | ||||
|                 class="h-6 w-6 text-blue-600" | ||||
|                 fill="currentColor" | ||||
|                 xmlns="http://www.w3.org/2000/svg" | ||||
|                 viewBox="0 0 24 24" | ||||
|                 width="24" | ||||
|                 height="24"><path fill="none" d="M0 0h24v24H0z" /> | ||||
|                 <path | ||||
|                   d="M14 2a8 8 0 013.3 15.3A8 8 0 116.7 6.7 8 8 0 0114 2zm-3 7H9v1a2.5 2.5 0 00-.16 5h2.25a.5.5 0 010 1H7v2h2v1h2v-1a2.5 2.5 0 00.16-5H8.91a.5.5 0 010-1H13v-2h-2V9zm3-5a5.99 5.99 0 00-4.48 2.01 8 8 0 018.47 8.47A6 6 0 0014 4z" /></svg> | ||||
|             </div> | ||||
|             <div class="mt-3 text-center sm:mt-0 sm:ml-4 sm:text-left"> | ||||
|               <h3 class="text-lg leading-6 font-medium text-gray-900"> | ||||
|                 {#if is_fixed} | ||||
|                   {$_('create-a-new-fixed-donation')} | ||||
|                 {:else}{$_('create-a-new-distance-donation')}{/if} | ||||
|               </h3> | ||||
|               <label class="content-center align-middle object-center"> | ||||
|                 <span | ||||
|                   class="ml-2 text-base" | ||||
|                   class:text-gray-300={is_fixed}>{$_('distance-donation')}</span> | ||||
|                 <input | ||||
|                   class="toggle relative w-10 h-5 transition-all duration-200 ease-in-out bg-gray-400 rounded-full shadow-inner outline-none appearance-none align-middle" | ||||
|                   type="checkbox" | ||||
|                   bind:checked={is_fixed} /> | ||||
|                 <span | ||||
|                   class="ml-2 text-base	" | ||||
|                   class:text-gray-300={!is_fixed}>{$_('fixed-donation')}</span> | ||||
|               </label> | ||||
|               <div class="mt-2 mb-6"> | ||||
|                 <p class="text-sm text-gray-500"> | ||||
|                   {$_('please-provide-the-nessecary-information-to-create-a-new-donation')} | ||||
|                 </p> | ||||
|               </div> | ||||
|               <div class="grid grid-cols-6 gap-6"> | ||||
|                 <div class="col-span-6"> | ||||
|                   <label | ||||
|                     for="donor" | ||||
|                     class="block text-sm font-medium text-gray-700">{$_('donor')}</label> | ||||
|                   <Select | ||||
|                     containerClasses="rounded-l-md mt-1 focus:ring-indigo-500 focus:border-indigo-500 block w-full shadow-sm rounded-l-md sm:text-sm border-gray-300 border bg-gray-50 text-gray-500 rounded-md p-2" | ||||
|                     itemFilter={(label, filterText, option) => filterDonors(label, filterText, option)} | ||||
|                     items={donors} | ||||
|                     showChevron={true} | ||||
|                     placeholder={$_('search-for-donor-name-or-id')} | ||||
|                     noOptionsMessage={$_('no-donors-found')} | ||||
|                     on:select={(selectedValue) => (donor = selectedValue.detail.value.id)} | ||||
|                     on:clear={() => (donors = null)} /> | ||||
|                 </div> | ||||
|                 {#if !is_fixed} | ||||
|                   <div class="col-span-6"> | ||||
|                     <label | ||||
|                       for="donor" | ||||
|                       class="block text-sm font-medium text-gray-700">{$_('runner')}</label> | ||||
|                     <Select | ||||
|                       containerClasses="rounded-l-md mt-1 focus:ring-indigo-500 focus:border-indigo-500 block w-full shadow-sm rounded-l-md sm:text-sm border-gray-300 border bg-gray-50 text-gray-500 rounded-md p-2" | ||||
|                       itemFilter={(label, filterText, option) => filterDonors(label, filterText, option)} | ||||
|                       items={runners} | ||||
|                       showChevron={true} | ||||
|                       placeholder={$_('search-for-runner-by-name-or-id')} | ||||
|                       noOptionsMessage={$_('no-runners-found')} | ||||
|                       on:select={(selectedValue) => (runner = selectedValue.detail.value.id)} | ||||
|                       on:clear={() => (runner = null)} /> | ||||
|                   </div> | ||||
|                 {/if} | ||||
|                 <div class="col-span-6"> | ||||
|                   <label | ||||
|                     for="donation_amount_eur" | ||||
|                     class="block text-sm font-medium text-gray-700"> | ||||
|                     {#if !is_fixed} | ||||
|                       {$_('amount-per-kilometer')} | ||||
|                     {:else}{$_('donation-amount')}{/if}</label> | ||||
|                   <div class="mt-1 flex rounded-md shadow-sm"> | ||||
|                     <input | ||||
|                       autocomplete="off" | ||||
|                       class:border-red-500={!is_amount_valid} | ||||
|                       class:focus:border-red-500={!is_amount_valid} | ||||
|                       class:focus:ring-red-500={!is_amount_valid} | ||||
|                       bind:value={amount_input} | ||||
|                       type="number" | ||||
|                       step="0.01" | ||||
|                       name="donation_amount_eur" | ||||
|                       class="focus:ring-indigo-500 focus:border-indigo-500 flex-1 block w-full rounded-none rounded-l-md sm:text-sm border-gray-300 border bg-gray-50 text-gray-500 p-2" | ||||
|                       placeholder="2.00" /> | ||||
|                     <span | ||||
|                       class="inline-flex items-center px-3 rounded-r-md border border-gray-300 bg-gray-50 text-gray-500 text-sm">€</span> | ||||
|                   </div> | ||||
|                   {#if !is_amount_valid} | ||||
|                     <span | ||||
|                       class="flex items-center font-medium tracking-wide text-red-500 text-xs mt-1 ml-1"> | ||||
|                       {$_('donation-amount-must-be-greater-that-0-00eur')} | ||||
|                     </span> | ||||
|                   {/if} | ||||
|                 </div> | ||||
|                 {#if is_fixed} | ||||
|                 <div class="col-span-6"> | ||||
|                   <label | ||||
|                     for="paid" | ||||
|                     class="block text-sm font-medium text-gray-700">{$_('already-paid')}</label> | ||||
|                     <p class="text-gray-500"> | ||||
|                       <input | ||||
|                         id="paid" | ||||
|                         bind:checked={is_paid} | ||||
|                         name="paid" | ||||
|                         type="checkbox" | ||||
|                         class="focus:ring-indigo-500 h-4 w-4 text-indigo-600 border-gray-300 rounded" > | ||||
|                         <span class="align-text-bottom"> | ||||
|  | ||||
|                       {#if is_paid} | ||||
|                       {$_('paid')} | ||||
|                       {:else} | ||||
|                       {$_('open')} | ||||
|                       {/if} | ||||
|                         </span> | ||||
|                     </p> | ||||
|                 </div> | ||||
|                 {/if} | ||||
|               </div> | ||||
|             </div> | ||||
|           </div> | ||||
|         </div> | ||||
|         <div class="bg-gray-50 px-4 py-3 sm:px-6 sm:flex sm:flex-row-reverse"> | ||||
|           <button | ||||
|             disabled={!createbtnenabled} | ||||
|             class:opacity-50={!createbtnenabled} | ||||
|             on:click={submit} | ||||
|             type="button" | ||||
|             class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-600 text-base font-medium text-white hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm"> | ||||
|             {$_('create')} | ||||
|           </button> | ||||
|           <button | ||||
|             on:click={() => { | ||||
|               modal_open = false; | ||||
|             }} | ||||
|             type="button" | ||||
|             class="mt-3 w-full inline-flex justify-center rounded-md border border-gray-300 shadow-sm px-4 py-2 bg-white text-base font-medium text-gray-700 hover:bg-gray-50 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-indigo-500 sm:mt-0 sm:ml-3 sm:w-auto sm:text-sm"> | ||||
|             {$_('cancel')} | ||||
|           </button> | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
| {/if} | ||||
|   | ||||
| @@ -4,11 +4,13 @@ | ||||
|    | ||||
|   import { DonationService } from "@odit/lfk-client-js"; | ||||
|   import Toastify from "toastify-js"; | ||||
|   import { createEventDispatcher } from "svelte"; | ||||
|   export let payment_modal_open = false; | ||||
|   export let current_donations = []; | ||||
|   export let editable = {}; | ||||
|   export let original_data = {}; | ||||
|   export let paid_amount_input = 0; | ||||
|   const dispatch = createEventDispatcher(); | ||||
|   $:processed_last_submit=true; | ||||
|   function focus(el) { | ||||
|     el.focus(); | ||||
| @@ -52,8 +54,7 @@ | ||||
|             duration: 500, | ||||
|             backgroundColor: "linear-gradient(to right, #00b09b, #96c93d)", | ||||
|           }).showToast(); | ||||
|           current_donations[current_donations.findIndex((c) => c.id === id)] = result; | ||||
|           current_donations = current_donations; | ||||
|           dispatch("created", {donation: response}) | ||||
|         }) | ||||
|         .catch((err) => { | ||||
|           // | ||||
|   | ||||
| @@ -5,25 +5,33 @@ | ||||
|   import DonationsOverview from "./DonationsOverview.svelte"; | ||||
|   $: current_donations = []; | ||||
|   export let modal_open = false; | ||||
|   let addDonations; | ||||
| </script> | ||||
|  | ||||
| <section class="container p-5"> | ||||
|   <span class="mb-1 text-3xl font-extrabold leading-tight"> | ||||
|     {$_('donations')} | ||||
|     {#if store.state.jwtinfo.userdetails.permissions.includes('DONATION:CREATE')} | ||||
|     {$_("donations")} | ||||
|     {#if store.state.jwtinfo.userdetails.permissions.includes("DONATION:CREATE")} | ||||
|       <button | ||||
|         on:click={() => { | ||||
|           modal_open = true; | ||||
|         }} | ||||
|         type="button" | ||||
|         class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-600 text-base font-medium text-white hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm"> | ||||
|         {$_('add-donation')} | ||||
|         class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 bg-blue-600 text-base font-medium text-white hover:bg-blue-700 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-blue-500 sm:ml-3 sm:w-auto sm:text-sm" | ||||
|       > | ||||
|         {$_("add-donation")} | ||||
|       </button> | ||||
|     {/if} | ||||
|   </span> | ||||
|   <DonationsOverview bind:current_donations /> | ||||
|   <DonationsOverview bind:current_donations bind:addDonations /> | ||||
| </section> | ||||
|  | ||||
| {#if store.state.jwtinfo.userdetails.permissions.includes('DONATION:CREATE')} | ||||
|   <AddDonationModal bind:current_donations bind:modal_open /> | ||||
| {#if store.state.jwtinfo.userdetails.permissions.includes("DONATION:CREATE")} | ||||
|   <AddDonationModal | ||||
|     on:created={(event) => { | ||||
|       console.log(event) | ||||
|       addDonations(event.detail.donations); | ||||
|     }} | ||||
|     bind:modal_open | ||||
|   /> | ||||
| {/if} | ||||
|   | ||||
| @@ -36,6 +36,13 @@ | ||||
|   export let editable = {}; | ||||
|   export let original_data = {}; | ||||
|   export let paid_amount_input = 0; | ||||
|   export const addDonations = (donations) => { | ||||
|     current_donations = current_donations.concat(...donations); | ||||
|     options.update((options) => ({ | ||||
|       ...options, | ||||
|       data: current_donations, | ||||
|     })); | ||||
|   }; | ||||
|  | ||||
|   function open_payment_modal(donation) { | ||||
|     editable = Object.assign({}, donation); | ||||
| @@ -104,7 +111,7 @@ | ||||
|       accessorKey: "status", | ||||
|       header: () => $_("status"), | ||||
|       cell: (info) => { | ||||
|         return renderComponent(DonationStatus, {status: info.getValue()}); | ||||
|         return renderComponent(DonationStatus, { status: info.getValue() }); | ||||
|       }, | ||||
|       enableColumnFilter: false, | ||||
|     }, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user