300 lines
9.3 KiB
JavaScript
Raw Normal View History

2019-11-19 10:37:08 +03:00
/**
* First we will load all of this project's JavaScript dependencies which
* includes Vue and other libraries. It is a great starting point when
* building robust, powerful web applications using Vue and Laravel.
*/
require('./../../bootstrap');
import Vue from 'vue';
2020-01-03 12:10:07 +03:00
import DashboardPlugin from './../../plugins/dashboard-plugin';
2019-11-19 10:37:08 +03:00
import Global from './../../mixins/global';
import Form from './../../plugins/form';
2022-06-01 10:15:55 +03:00
import { Progress } from 'element-ui';
import AkauntingSlider from './../../components/AkauntingSlider.vue';
2019-11-19 10:37:08 +03:00
2020-01-03 12:10:07 +03:00
// plugin setup
2022-06-01 10:15:55 +03:00
Vue.use(DashboardPlugin, Progress);
2020-01-03 12:10:07 +03:00
2019-11-19 10:37:08 +03:00
const app = new Vue({
el: '#app',
2019-11-20 17:45:19 +03:00
2019-11-19 10:37:08 +03:00
mixins: [
Global
],
2019-11-20 17:45:19 +03:00
2022-06-01 10:15:55 +03:00
components: {
[Progress.name]: Progress,
AkauntingSlider
},
mounted() {
if (typeof app_slug !== 'undefined') {
this.onReleases(1);
this.onReviews(1);
}
},
2019-11-19 10:37:08 +03:00
data: function () {
return {
2022-06-01 10:15:55 +03:00
keyword: '',
form: new Form('form-app'),
page: 2,
current_page: 1,
releases: {
status: false,
html: '',
pagination: {
current_page: 1,
last_page: 1
}
},
reviews: {
status: false,
html: '',
pagination: {
current_page: 1,
last_page: 1
}
},
page: {
reviews: 2,
releases: 2,
},
reviewPage: 2,
faq: false,
installation: {
show: false,
steps: [],
steps_total: 0,
total: 0,
path: '',
alias: '',
version: '',
status: 'success',
html: ''
},
loadMoreLoading: false,
2019-11-19 10:37:08 +03:00
}
2019-11-20 17:45:19 +03:00
},
methods: {
2022-06-01 10:15:55 +03:00
addToCart(alias, subscription_type) {
let add_to_cart_promise = Promise.resolve(axios.get(url + '/apps/' + alias + '/' + subscription_type +'/add'));
add_to_cart_promise.then(response => {
if (response.data.success) {
this.$notify({
message: response.data.message,
timeout: 0,
icon: "fas fa-bell",
type: 'success'
});
}
if (response.data.error) {
this.installation.status = 'exception';
this.installation.html = '<div class="text-red">' + response.data.message + '</div>';
}
// Set steps
if (response.data.data) {
this.installation.steps = response.data.data;
this.installation.steps_total = this.installation.steps.length;
this.next();
}
})
.catch(error => {
});
},
async onloadMore() {
this.loadMoreLoading = true;
this.current_page++;
let path = document.getElementById('see_more_path').value;
let alias = '';
let keyword = '';
if (document.getElementById('see_more_alias')) {
alias = document.getElementById('see_more_alias').value;
2020-09-07 10:57:29 +03:00
}
2022-06-01 10:15:55 +03:00
if (document.getElementById('see_more_keyword')) {
keyword = document.getElementById('see_more_keyword').value;
}
2019-11-20 17:45:19 +03:00
2022-06-01 10:15:55 +03:00
if (this.keyword !== '') {
keyword = this.keyword;
2019-11-20 17:45:19 +03:00
}
2022-06-01 10:15:55 +03:00
document.getElementById("button-pre-load").setAttribute("disabled", true);
let more_promise = Promise.resolve(window.axios.post(path, {
page: this.current_page,
alias: alias,
keyword: keyword,
}));
more_promise.then(response => {
if (response.data.success) {
document.querySelector("[data-apps-content]").innerHTML += response.data.html;
}
if (response.data.last_page == this.current_page) {
document.getElementById("button-pre-load").remove();
}
this.loadMoreLoading = false;
})
.catch(error => {
this.loadMoreLoading = false;
});
},
async onReleases(page) {
let releases_promise = Promise.resolve(window.axios.post(url + '/apps/' + app_slug + '/releases', {
page: page
}));
releases_promise.then(response => {
if (response.data.success) {
this.releases.status= true;
this.releases.html = response.data.html;
this.releases.pagination.current_page = page;
this.releases.pagination.last_page = response.data.data.last_page;
}
})
.catch(error => {
});
},
async onReviews(page) {
let reviews_promise = Promise.resolve(window.axios.post(url + '/apps/' + app_slug + '/reviews', {
page: page
}));
reviews_promise.then(response => {
if (response.data.success) {
this.reviews.status= true;
this.reviews.html = response.data.html;
this.reviews.pagination.current_page = page;
this.reviews.pagination.last_page = response.data.data.last_page;
}
})
.catch(error => {
});
},
onShowFaq() {
this.faq = true;
},
async onInstall(path, alias, name, version) {
this.installation.alias = alias;
this.installation.show = true;
this.installation.total = 0;
this.installation.path = path;
this.installation.version = version;
let steps_promise = Promise.resolve(axios.post(url + '/apps/steps', {
name: name,
alias: alias,
version: version
}));
steps_promise.then(response => {
if (response.data.error) {
this.installation.status = 'exception';
this.installation.html = '<div class="text-danger">' + response.data.message + '</div>';
}
// Set steps
if (response.data.data) {
this.installation.steps = response.data.data;
this.installation.steps_total = this.installation.steps.length;
this.next();
}
})
.catch(error => {
});
},
async next() {
let data = this.installation.steps.shift();
if (data) {
this.installation.total = parseInt((100 - ((this.installation.steps.length / this.installation.steps_total) * 100)).toFixed(0));
this.installation.html = '<span class="text-default"><i class="submit-spin absolute w-2 h-2 rounded-full left-0 right-0 -top-3.5 m-auto"></i> ' + data['text'] + '</span> </br>';
let step_promise = Promise.resolve(axios.post(data.url, {
alias: this.installation.alias,
version: this.installation.version,
path: this.installation.path,
}));
step_promise.then(response => {
if (response.data.error) {
this.installation.status = 'exception';
this.installation.html = '<div class="text-danger"><i class="submit-spin absolute w-2 h-2 rounded-full left-0 right-0 -top-3.5 m-auto"></i> ' + response.data.message + '</div>';
}
if (response.data.success) {
this.installation.status = 'success';
}
if (response.data.data.path) {
this.installation.path = response.data.data.path;
}
if (!response.data.error && !response.data.redirect) {
setTimeout(function() {
this.next();
}.bind(this), 800);
}
if (response.data.redirect) {
window.location = response.data.redirect;
}
})
.catch(error => {
});
}
},
async onModuleLoadMore(type) {
this.loadMoreLoading = true;
let module_promise = Promise.resolve(window.axios.post(url + '/apps/' + app_slug + '/' + type, {
page: this.page[type]
}));
module_promise.then(response => {
if (response.data.success) {
this.page[type]++;
document.querySelector('.js-'+ type + '-content').innerHTML += response.data.html;
this.loadMoreLoading = false;
}
})
.catch(error => {
this.loadMoreLoading = false;
});
},
2019-11-19 10:37:08 +03:00
}
});