mirror of
https://github.com/firefly-iii/firefly-iii.git
synced 2025-10-24 04:41:01 +00:00
212 lines
7.2 KiB
Vue
212 lines
7.2 KiB
Vue
<!--
|
|
- Edit.vue
|
|
- Copyright (c) 2022 james@firefly-iii.org
|
|
-
|
|
- This file is part of Firefly III (https://github.com/firefly-iii).
|
|
-
|
|
- This program is free software: you can redistribute it and/or modify
|
|
- it under the terms of the GNU Affero General Public License as
|
|
- published by the Free Software Foundation, either version 3 of the
|
|
- License, or (at your option) any later version.
|
|
-
|
|
- This program 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 Affero General Public License for more details.
|
|
-
|
|
- You should have received a copy of the GNU Affero General Public License
|
|
- along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
-->
|
|
|
|
<template>
|
|
<form accept-charset="UTF-8" class="form-horizontal" enctype="multipart/form-data">
|
|
<input name="_token" type="hidden" value="xxx">
|
|
|
|
<div v-if="error_message !== ''" class="row">
|
|
<div class="col-lg-12">
|
|
<div class="alert alert-danger alert-dismissible" role="alert">
|
|
<button class="close" data-dismiss="alert" type="button" v-bind:aria-label="$t('firefly.close')"><span
|
|
aria-hidden="true">×</span></button>
|
|
<strong>{{ $t("firefly.flash_error") }}</strong> {{ error_message }}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div v-if="success_message !== ''" class="row">
|
|
<div class="col-lg-12">
|
|
<div class="alert alert-success alert-dismissible" role="alert">
|
|
<button class="close" data-dismiss="alert" type="button" v-bind:aria-label="$t('firefly.close')"><span
|
|
aria-hidden="true">×</span></button>
|
|
<strong>{{ $t("firefly.flash_success") }}</strong> <span v-html="success_message"></span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row">
|
|
<div class="col-lg-6 col-md-12 col-sm-12">
|
|
<div class="box box-primary">
|
|
<div class="box-header with-border">
|
|
<h3 class="box-title">
|
|
{{ $t('firefly.edit_webhook_js', {title: this.title}) }}
|
|
</h3>
|
|
</div>
|
|
<div class="box-body">
|
|
<div class="row">
|
|
<div class="col-lg-12">
|
|
<Title :value=this.title :error="errors.title" v-on:input="title = $event"></Title>
|
|
<WebhookTrigger :value=this.trigger :error="errors.trigger"
|
|
v-on:input="trigger = $event"></WebhookTrigger>
|
|
<WebhookResponse :value=this.response :error="errors.response"
|
|
v-on:input="response = $event"></WebhookResponse>
|
|
<WebhookDelivery :value=this.delivery :error="errors.delivery"
|
|
v-on:input="delivery = $event"></WebhookDelivery>
|
|
<URL :value=this.url :error="errors.url" v-on:input="url = $event"></URL>
|
|
<Checkbox :value=this.active :error="errors.active" help="ACTIVE HELP TODO" :title="$t('form.active')"
|
|
v-on:input="active = $event"></Checkbox>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="box-footer">
|
|
<div class="btn-group">
|
|
<button id="submitButton" ref="submitButton" class="btn btn-success" @click="submit">
|
|
{{ $t('firefly.submit') }}
|
|
</button>
|
|
</div>
|
|
<p class="text-success" v-html="success_message"></p>
|
|
<p class="text-danger" v-html="error_message"></p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</template>
|
|
|
|
<script>
|
|
import Title from "../form/Title";
|
|
import WebhookTrigger from "../form/WebhookTrigger";
|
|
import WebhookResponse from "../form/WebhookResponse";
|
|
import WebhookDelivery from "../form/WebhookDelivery";
|
|
import URL from "../form/URL";
|
|
import Checkbox from "../form/Checkbox";
|
|
|
|
export default {
|
|
name: "Edit",
|
|
components: {URL, Title, WebhookTrigger, WebhookResponse, WebhookDelivery, Checkbox},
|
|
data() {
|
|
return {
|
|
error_message: '',
|
|
success_message: '',
|
|
title: '',
|
|
trigger: 100,
|
|
response: 200,
|
|
delivery: 300,
|
|
id: 0,
|
|
active: false,
|
|
url: '',
|
|
errors: {
|
|
title: [],
|
|
trigger: [],
|
|
response: [],
|
|
delivery: [],
|
|
url: [],
|
|
active: []
|
|
}
|
|
};
|
|
},
|
|
mounted() {
|
|
this.getWebhook();
|
|
},
|
|
methods: {
|
|
getWebhook: function () {
|
|
const page = window.location.href.split('/');
|
|
const webhookId = page[page.length - 1];
|
|
this.downloadWebhook(webhookId);
|
|
},
|
|
downloadWebhook: function (id) {
|
|
axios.get('./api/v1/webhooks/' + id).then(response => {
|
|
console.log(response.data.data.attributes);
|
|
this.title = response.data.data.attributes.title;
|
|
this.id = parseInt(response.data.data.id);
|
|
|
|
// trigger value on content
|
|
if ('STORE_TRANSACTION' === response.data.data.attributes.trigger) {
|
|
this.trigger = 100;
|
|
}
|
|
if ('UPDATE_TRANSACTION' === response.data.data.attributes.trigger) {
|
|
this.trigger = 110;
|
|
}
|
|
if ('DESTROY_TRANSACTION' === response.data.data.attributes.trigger) {
|
|
this.trigger = 120;
|
|
}
|
|
|
|
// response value
|
|
if ('TRANSACTIONS' === response.data.data.attributes.response) {
|
|
this.response = 200;
|
|
}
|
|
if ('ACCOUNTS' === response.data.data.attributes.response) {
|
|
this.response = 210;
|
|
}
|
|
if ('NONE' === response.data.data.attributes.response) {
|
|
this.response = 220;
|
|
}
|
|
if ('JSON' === response.data.data.attributes.delivery) {
|
|
this.delivery = 300;
|
|
}
|
|
|
|
this.active = response.data.data.attributes.active;
|
|
this.url = response.data.data.attributes.url;
|
|
}).catch(error => {
|
|
this.error_message = error.response.data.message;
|
|
});
|
|
},
|
|
submit: function (e) {
|
|
// reset messages
|
|
this.error_message = '';
|
|
this.success_message = '';
|
|
this.errors = {
|
|
title: [],
|
|
trigger: [],
|
|
response: [],
|
|
delivery: [],
|
|
url: [],
|
|
active: [],
|
|
};
|
|
|
|
// disable button
|
|
$('#submitButton').prop("disabled", true);
|
|
|
|
// collect data
|
|
let data = {
|
|
title: this.title,
|
|
trigger: this.trigger,
|
|
response: this.response,
|
|
delivery: this.delivery,
|
|
url: this.url,
|
|
active: this.active,
|
|
};
|
|
|
|
// post!
|
|
axios.put('./api/v1/webhooks/' + this.id, data).then((response) => {
|
|
let webhookId = response.data.data.id;
|
|
window.location.href = window.previousUrl + '?webhook_id=' + webhookId + '&message=updated';
|
|
}).catch((error) => {
|
|
|
|
this.error_message = error.response.data.message;
|
|
this.errors.title = error.response.data.errors.title;
|
|
this.errors.trigger = error.response.data.errors.trigger;
|
|
this.errors.response = error.response.data.errors.response;
|
|
this.errors.delivery = error.response.data.errors.delivery;
|
|
this.errors.url = error.response.data.errors.url;
|
|
|
|
// enable button again
|
|
$('#submitButton').prop("disabled", false);
|
|
|
|
});
|
|
if (e) {
|
|
e.preventDefault();
|
|
}
|
|
}
|
|
},
|
|
}
|
|
</script>
|