mirror of
https://git.friendi.ca/friendica/friendica-addons.git
synced 2024-12-22 18:50:15 +00:00
[advancedcontentfilter] Move from vue-resource to jQuery ajax
- Remove commented code - Add custom $.ajaxJSON function - Add error message display when showVariables fails - Use Friendica core vue script path
This commit is contained in:
parent
4c4a8da612
commit
faad559799
3 changed files with 56 additions and 48 deletions
|
@ -1,4 +1,16 @@
|
|||
Vue.http.headers.common['X-CSRF-Token'] = document.querySelector('#csrf').getAttribute('value');
|
||||
$.ajaxSetup({headers: {'X-CSRF-Token': document.querySelector('#csrf').getAttribute('value')}});
|
||||
|
||||
$.extend({
|
||||
ajaxJSON: function(method, url, data) {
|
||||
return $.ajax({
|
||||
type: method.toUpperCase(),
|
||||
url: url,
|
||||
data: JSON.stringify(data),
|
||||
contentType: 'application/json; charset=utf-8',
|
||||
dataType: 'json'
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
new Vue({
|
||||
el: '#rules',
|
||||
|
@ -23,10 +35,6 @@ new Vue({
|
|||
}
|
||||
},
|
||||
|
||||
//created: function () {
|
||||
// this.fetchRules();
|
||||
//},
|
||||
|
||||
methods: {
|
||||
resetForm: function() {
|
||||
this.rule = {id: '', name: '', expression: '', created: ''};
|
||||
|
@ -34,24 +42,17 @@ new Vue({
|
|||
this.editedIndex = null;
|
||||
},
|
||||
|
||||
//fetchRules: function () {
|
||||
// this.$http.get('/advancedcontentfilter/api/rules')
|
||||
// .then(function (response) {
|
||||
// this.rules = response.body;
|
||||
// }, function (err) {
|
||||
// console.log(err);
|
||||
// });
|
||||
//},
|
||||
|
||||
addRule: function () {
|
||||
if (this.rule.name.trim()) {
|
||||
this.errorMessage = '';
|
||||
this.$http.post('/advancedcontentfilter/api/rules', this.rule)
|
||||
.then(function (res) {
|
||||
this.rules.push(res.body.rule);
|
||||
this.resetForm();
|
||||
}, function (err) {
|
||||
this.errorMessage = err.body.message;
|
||||
|
||||
var self = this;
|
||||
$.ajaxJSON('post', '/advancedcontentfilter/api/rules', this.rule)
|
||||
.then(function (responseJSON) {
|
||||
self.rules.push(responseJSON.rule);
|
||||
self.resetForm();
|
||||
}, function (response) {
|
||||
self.errorMessage = response.responseJSON.message;
|
||||
});
|
||||
}
|
||||
},
|
||||
|
@ -64,47 +65,55 @@ new Vue({
|
|||
|
||||
saveRule: function (rule) {
|
||||
this.errorMessage = '';
|
||||
this.$http.put('/advancedcontentfilter/api/rules/' + rule.id, rule)
|
||||
.then(function (res) {
|
||||
this.rules[this.editedIndex] = rule;
|
||||
this.resetForm();
|
||||
}, function (err) {
|
||||
this.errorMessage = err.body.message;
|
||||
|
||||
var self = this;
|
||||
$.ajaxJSON('put', '/advancedcontentfilter/api/rules/' + rule.id, rule)
|
||||
.then(function () {
|
||||
self.rules[self.editedIndex] = rule;
|
||||
self.resetForm();
|
||||
}, function (response) {
|
||||
self.errorMessage = response.responseJSON.message;
|
||||
});
|
||||
},
|
||||
|
||||
toggleActive: function (rule) {
|
||||
this.$http.put('/advancedcontentfilter/api/rules/' + rule.id, {'active': Math.abs(parseInt(rule.active) - 1)})
|
||||
.then(function (res) {
|
||||
this.rules[this.rules.indexOf(rule)].active = Math.abs(parseInt(rule.active) - 1);
|
||||
}, function (err) {
|
||||
console.log(err);
|
||||
var previousValue = this.rules[this.rules.indexOf(rule)].active;
|
||||
var newValue = Math.abs(parseInt(rule.active) - 1);
|
||||
|
||||
this.rules[this.rules.indexOf(rule)].active = newValue;
|
||||
|
||||
var self = this;
|
||||
$.ajaxJSON('put', '/advancedcontentfilter/api/rules/' + rule.id, {'active': newValue})
|
||||
.fail(function (response) {
|
||||
self.rules[self.rules.indexOf(rule)].active = previousValue;
|
||||
console.log(response.responseJSON.message);
|
||||
});
|
||||
},
|
||||
|
||||
deleteRule: function (rule) {
|
||||
if (confirm('Are you sure you want to delete this rule?')) {
|
||||
this.$http.delete('/advancedcontentfilter/api/rules/' + rule.id)
|
||||
.then(function (res) {
|
||||
this.rules.splice(this.rules.indexOf(rule), 1);
|
||||
}, function (err) {
|
||||
console.log(err);
|
||||
var self = this;
|
||||
$.ajaxJSON('delete', '/advancedcontentfilter/api/rules/' + rule.id)
|
||||
.then(function () {
|
||||
self.rules.splice(self.rules.indexOf(rule), 1);
|
||||
}, function (response) {
|
||||
console.log(response.responseJSON.message);
|
||||
});
|
||||
}
|
||||
},
|
||||
|
||||
showVariables: function () {
|
||||
var guid = '';
|
||||
|
||||
var urlParts = this.itemUrl.split('/');
|
||||
var guid = urlParts[urlParts.length - 1];
|
||||
|
||||
guid = urlParts[urlParts.length - 1];
|
||||
this.itemJson = '';
|
||||
|
||||
this.$http.get('/advancedcontentfilter/api/variables/' + guid)
|
||||
.then(function (response) {
|
||||
this.itemJson = response.bodyText;
|
||||
}, function (err) {
|
||||
console.log(err);
|
||||
var self = this;
|
||||
$.ajaxJSON('get', '/advancedcontentfilter/api/variables/' + guid)
|
||||
.then(function (responseJSON) {
|
||||
self.itemJson = responseJSON.variables;
|
||||
}, function (response) {
|
||||
self.itemJson = response.responseJSON.message;
|
||||
});
|
||||
|
||||
return false;
|
||||
|
|
|
@ -416,5 +416,5 @@ function advancedcontentfilter_get_variables_guid(ServerRequestInterface $reques
|
|||
$return[str_replace('-', '_', $key)] = $value;
|
||||
}
|
||||
|
||||
return str_replace('\\\'', '\'', var_export($return, true));
|
||||
return json_encode(['variables' => str_replace('\\\'', '\'', var_export($return, true))]);
|
||||
}
|
|
@ -85,7 +85,7 @@
|
|||
<button type="submit" class="btn btn-primary">Show Variables</button>
|
||||
</fieldset>
|
||||
</form>
|
||||
<pre>
|
||||
<pre v-cloak>
|
||||
{{ itemJson }}
|
||||
</pre>
|
||||
</div>
|
||||
|
@ -93,7 +93,6 @@
|
|||
<script> var existingRules = {{$rules}};</script>
|
||||
|
||||
<!-- JS -->
|
||||
<script src="{{$baseurl}}/addon/advancedcontentfilter/vendor/asset/vue/dist/vue.min.js"></script>
|
||||
<script src="{{$baseurl}}/addon/advancedcontentfilter/vendor/asset/vue-resource/dist/vue-resource.min.js"></script>
|
||||
<script src="{{$baseurl}}/view/asset/vue/dist/vue.min.js"></script>
|
||||
<script src="{{$baseurl}}/addon/advancedcontentfilter/advancedcontentfilter.js"></script>
|
||||
</div>
|
||||
|
|
Loading…
Reference in a new issue