2023-04-26 17:20:10 +08:00
|
|
|
<template>
|
2023-05-04 17:29:19 +08:00
|
|
|
<div v-if="actions.length" class="sn-action-toolbar p-4 w-full fixed bottom-0 rounded-t-md shadow-[0_-12px_24px_-12px_rgba(35,31,32,0.2)]" :style="`width: ${width}px`">
|
2023-04-26 17:20:10 +08:00
|
|
|
<div class="sn-action-toolbar__actions flex">
|
|
|
|
<div v-for="action in actions" :key="action.name" class="sn-action-toolbar__action">
|
|
|
|
<a :class="`btn btn-light ${action.button_class}`"
|
2023-04-26 21:51:22 +08:00
|
|
|
:href="(['link', 'remote-modal']).includes(action.type) ? action.path : '#'"
|
2023-04-26 17:20:10 +08:00
|
|
|
:id="action.button_id"
|
|
|
|
:data-url="action.path"
|
|
|
|
:data-object-type="action.item_type"
|
|
|
|
:data-object-id="action.item_id"
|
2023-04-26 21:51:22 +08:00
|
|
|
:data-action="action.type"
|
2023-04-26 17:20:10 +08:00
|
|
|
@click="doAction(action)">
|
|
|
|
<i :class="action.icon"></i>
|
|
|
|
{{ action.label }}
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
export default {
|
|
|
|
name: 'ActionToolbar',
|
|
|
|
props: {
|
|
|
|
actionsUrl: { type: String, required: true }
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
actions: [],
|
|
|
|
shown: false,
|
|
|
|
multiple: false,
|
|
|
|
params: {},
|
|
|
|
reloadCallback: null,
|
|
|
|
width: 0
|
|
|
|
}
|
|
|
|
},
|
|
|
|
created() {
|
|
|
|
window.actionToolbarComponent = this;
|
|
|
|
window.onresize = this.setWidth;
|
|
|
|
},
|
|
|
|
mounted() {
|
|
|
|
this.setWidth();
|
|
|
|
},
|
|
|
|
beforeDestroy() {
|
|
|
|
delete window.actionToolbarComponent;
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
setWidth() {
|
|
|
|
this.width = $(this.$el).parent().width();
|
|
|
|
},
|
|
|
|
fetchActions(params) {
|
|
|
|
this.params = params;
|
|
|
|
|
|
|
|
$.get(`${this.actionsUrl}?${new URLSearchParams(this.params).toString()}`, (data) => {
|
|
|
|
this.actions = data.actions;
|
|
|
|
});
|
|
|
|
},
|
|
|
|
setReloadCallback(func) {
|
|
|
|
this.reloadCallback = func;
|
|
|
|
},
|
|
|
|
doAction(action) {
|
|
|
|
switch(action.type) {
|
|
|
|
case 'legacy':
|
|
|
|
// do nothing, this is handled by legacy code based on the button class
|
|
|
|
break;
|
|
|
|
case 'link':
|
2023-04-26 21:51:22 +08:00
|
|
|
// do nothing, already handled by href
|
|
|
|
break;
|
|
|
|
case 'remote-modal':
|
|
|
|
// do nothing, handled by the data-action="remote-modal" binding
|
2023-04-26 17:20:10 +08:00
|
|
|
break;
|
|
|
|
case 'request':
|
|
|
|
$.ajax({
|
|
|
|
type: action.request_method,
|
|
|
|
url: action.path,
|
|
|
|
data: this.params
|
|
|
|
}).done((data) => {
|
2023-04-26 21:51:22 +08:00
|
|
|
HelperModule.flashAlertMsg(data.responseJSON && data.responseJSON.message || data.message, 'success');
|
2023-04-26 17:20:10 +08:00
|
|
|
}).fail((data) => {
|
2023-04-26 21:51:22 +08:00
|
|
|
HelperModule.flashAlertMsg(data.responseJSON && data.responseJSON.message || data.message, 'danger');
|
2023-04-26 17:20:10 +08:00
|
|
|
}).complete(() => {
|
|
|
|
if (this.reloadCallback) this.reloadCallback();
|
|
|
|
});
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|