mirror of
				https://github.com/firefly-iii/firefly-iii.git
				synced 2025-10-26 05:26:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			117 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <!--
 | |
|   - CustomTransactionFields.vue
 | |
|   - Copyright (c) 2019 thegrumpydictator@gmail.com
 | |
|   -
 | |
|   - This file is part of Firefly III.
 | |
|   -
 | |
|   - Firefly III is free software: you can redistribute it and/or modify
 | |
|   - it under the terms of the GNU General Public License as published by
 | |
|   - the Free Software Foundation, either version 3 of the License, or
 | |
|   - (at your option) any later version.
 | |
|   -
 | |
|   - Firefly III is distributed in the hope that it will be useful,
 | |
|   - but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|   - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|   - GNU General Public License for more details.
 | |
|   -
 | |
|   - You should have received a copy of the GNU General Public License
 | |
|   - along with Firefly III. If not, see <http://www.gnu.org/licenses/>.
 | |
|   -->
 | |
| 
 | |
| <template>
 | |
|     <div>
 | |
|         <component
 | |
|                 :error="error.interest_date"
 | |
|                 v-model="value.interest_date" v-if="this.fields.interest_date" name="interest_date[]" title="Interest date" v-bind:is="dateComponent"></component>
 | |
|         <component
 | |
|                 :error="error.book_date"
 | |
|                 v-model="value.book_date" v-if="this.fields.book_date" name="book_date[]" title="Book date" v-bind:is="dateComponent"></component>
 | |
|         <component
 | |
|                 :error="error.process_date"
 | |
|                 v-model="value.process_date" v-if="this.fields.process_date" name="process_date[]" title="Process date" v-bind:is="dateComponent"></component>
 | |
|         <component
 | |
|                 :error="error.due_date"
 | |
|                 v-model="value.due_date" v-if="this.fields.due_date" name="due_date[]" title="Due date" v-bind:is="dateComponent"></component>
 | |
|         <component
 | |
|                 :error="error.payment_date"
 | |
|                 v-model="value.payment_date" v-if="this.fields.payment_date" name="payment_date[]" title="Payment date" v-bind:is="dateComponent"></component>
 | |
|         <component v-model="value.invoice_date" v-if="this.fields.invoice_date" name="invoice_date[]" title="Invoice date" v-bind:is="dateComponent"></component>
 | |
| 
 | |
|         <component
 | |
|                 :error="error.internal_reference"
 | |
|                 v-model="value.internal_reference" v-if="this.fields.internal_reference" name="internal_reference[]" title="Internal reference" v-bind:is="stringComponent"></component>
 | |
| 
 | |
|         <component
 | |
|                 :error="error.attachments"
 | |
|                 v-model="value.attachments" v-if="this.fields.attachments" name="attachments[]" title="Attachments" v-bind:is="attachmentComponent"></component>
 | |
| 
 | |
|         <component
 | |
|                 :error="error.notes"
 | |
|                 v-model="value.notes" v-if="this.fields.notes" name="notes[]" title="Notes" v-bind:is="textareaComponent"></component>
 | |
| 
 | |
| 
 | |
|     </div>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
|     export default {
 | |
|         name: "CustomTransactionFields",
 | |
|         props: ['value','error'],
 | |
|         mounted() {
 | |
|             this.getPreference();
 | |
|         },
 | |
|         data() {
 | |
|             return {
 | |
|                 customInterestDate: null,
 | |
|                 fields: [
 | |
|                     {
 | |
|                         "interest_date": false,
 | |
|                         "book_date": false,
 | |
|                         "process_date": false,
 | |
|                         "due_date": false,
 | |
|                         "payment_date": false,
 | |
|                         "invoice_date": false,
 | |
|                         "internal_reference": false,
 | |
|                         "notes": false,
 | |
|                         "attachments": false
 | |
|                     }
 | |
|                 ]
 | |
|             };
 | |
|         },
 | |
|         computed: {
 | |
|             // TODO this seems a pretty weird way of doing it.
 | |
|             dateComponent () {
 | |
|                 return 'custom-date';
 | |
|             },
 | |
|             stringComponent () {
 | |
|                 return 'custom-string';
 | |
|             },
 | |
|             attachmentComponent () {
 | |
|                 return 'custom-attachments';
 | |
|             },
 | |
|             textareaComponent () {
 | |
|                 return 'custom-textarea';
 | |
|             }
 | |
|         },
 | |
|         methods: {
 | |
|             handleInput(e) {
 | |
|                 this.$emit('input', this.value);
 | |
|             },
 | |
|             getPreference() {
 | |
| 
 | |
|                // Vue.component('custom-date', (resolve) => {
 | |
|                //      console.log('loaded');
 | |
|                //  });
 | |
| 
 | |
|                 const url = document.getElementsByTagName('base')[0].href + 'api/v1/preferences/transaction_journal_optional_fields';
 | |
|                 axios.get(url).then(response => {
 | |
|                     this.fields = response.data.data.attributes.data;
 | |
|                 }).catch(() => console.warn('Oh. Something went wrong'));
 | |
|             },
 | |
|         }
 | |
|     }
 | |
| </script>
 | |
| 
 | |
| <style scoped>
 | |
| 
 | |
| </style> |