diff --git a/app/Http/Controllers/Api/TagController.php b/app/Http/Controllers/Api/TagController.php new file mode 100644 index 00000000..3ad7bf7a --- /dev/null +++ b/app/Http/Controllers/Api/TagController.php @@ -0,0 +1,18 @@ +get('apiKey'); + + return TagResource::collection($apiKey->user->spaces()->first()->tags); + } +} diff --git a/app/Http/Controllers/Api/TransactionController.php b/app/Http/Controllers/Api/TransactionController.php index 9da16e54..61a76b9d 100644 --- a/app/Http/Controllers/Api/TransactionController.php +++ b/app/Http/Controllers/Api/TransactionController.php @@ -37,7 +37,7 @@ public function store(Request $request) $request->validate([ 'type' => ['required', 'in:earning,spending'], - // 'tag_id' => ['nullable', 'exists:tags,id'], // TODO CHECK IF TAG BELONGS TO USER + 'tag_id' => ['nullable', 'exists:tags,id'], // TODO: CHECK IF TAG BELONGS TO USER 'happened_on' => ['required', 'date', 'date_format:Y-m-d'], 'description' => ['required', 'max:255'], 'amount' => ['required', 'regex:/^\d*(\.\d{1,2})?$/'], @@ -58,7 +58,7 @@ public function store(Request $request) 'space_id' => $spaceId, 'import_id' => null, // TODO 'recurring_id' => null, // TODO - 'tag_id' => null, // TODO + 'tag_id' => $request->input('tag_id'), 'happened_on' => $request->input('happened_on'), 'description' => $request->input('description'), 'amount' => (int) ($request->input('amount') * 100), diff --git a/resources/assets/js/prototype/screens/Transactions/Create.vue b/resources/assets/js/prototype/screens/Transactions/Create.vue index d3ee78a3..f9dfd8d6 100644 --- a/resources/assets/js/prototype/screens/Transactions/Create.vue +++ b/resources/assets/js/prototype/screens/Transactions/Create.vue @@ -6,14 +6,26 @@ import Navigation from '../../components/Navigation.vue'; const router = getCurrentInstance().proxy.$router; +const tags = ref([]); + const type = ref('earning'); +const tagId = ref(null); const happened_on = ref(new Date().toJSON().slice(0, 10)); const description = ref(''); const amount = ref(10.00); +const fetchTags = () => { + fetch('/api/tags', { headers: { 'api-key': localStorage.getItem('api_key') } }) + .then(response => response.json()) + .then(data => { + tags.value = data; + }); +}; + const create = () => { axios.post('/api/transactions', { type: type.value, + tag_id: tagId.value, happened_on: happened_on.value, description: description.value, amount: amount.value, @@ -29,6 +41,8 @@ const create = () => { alert('Something went wrong'); }); }; + +fetchTags();