mirror of
https://github.com/scinote-eln/scinote-web.git
synced 2025-10-24 21:24:52 +08:00
249 lines
6.9 KiB
Vue
249 lines
6.9 KiB
Vue
<template>
|
|
<div class="grid w-full h-full gap-6" :class="{ 'grid-cols-[auto_1fr]': withGrid }">
|
|
<div v-if="withGrid" class="max-w-[40vw]">
|
|
<Grid
|
|
:gridSize="gridSize"
|
|
:assignedItems="assignedItems"
|
|
:selectedItems="selectedItems"
|
|
@assign="assignRowToPosition"
|
|
@select="selectRow"
|
|
/>
|
|
</div>
|
|
<div class="h-full bg-white px-4">
|
|
<DataTable :columnDefs="columnDefs"
|
|
tableId="StorageLocationsContainer"
|
|
:dataUrl="dataSource"
|
|
ref="table"
|
|
:reloadingTable="reloadingTable"
|
|
:toolbarActions="toolbarActions"
|
|
:actionsUrl="actionsUrl"
|
|
:scrollMode="paginationMode"
|
|
@assign="assignRow"
|
|
@move="moveRow"
|
|
@import="openImportModal = true"
|
|
@unassign="unassignRows"
|
|
@tableReloaded="handleTableReload"
|
|
@selectionChanged="selectedItems = $event"
|
|
/>
|
|
</div>
|
|
<Teleport to="body">
|
|
<AssignModal
|
|
v-if="openAssignModal"
|
|
:assignMode="assignMode"
|
|
:selectedContainer="assignToContainer"
|
|
:selectedPosition="assignToPosition"
|
|
:selectedRow="rowIdToMove"
|
|
:cellId="cellIdToUnassign"
|
|
@close="openAssignModal = false; this.reloadingTable = true"
|
|
></AssignModal>
|
|
<ImportModal
|
|
v-if="openImportModal"
|
|
:containerId="containerId"
|
|
@close="openImportModal = false"
|
|
@reloadTable="reloadingTable = true"
|
|
></ImportModal>
|
|
<ConfirmationModal
|
|
:title="i18n.t('storage_locations.show.unassign_modal.title')"
|
|
:description="storageLocationUnassignDescription"
|
|
confirmClass="btn btn-danger"
|
|
:confirmText="i18n.t('storage_locations.show.unassign_modal.button')"
|
|
ref="unassignStorageLocationModal"
|
|
></ConfirmationModal>
|
|
</Teleport>
|
|
</div>
|
|
</template>
|
|
|
|
<script>
|
|
/* global HelperModule */
|
|
|
|
import axios from '../../packs/custom_axios.js';
|
|
import DataTable from '../shared/datatable/table.vue';
|
|
import Grid from './grid.vue';
|
|
import AssignModal from './modals/assign.vue';
|
|
import ImportModal from './modals/import.vue';
|
|
import ConfirmationModal from '../shared/confirmation_modal.vue';
|
|
import RemindersRender from './renderers/reminders.vue';
|
|
|
|
export default {
|
|
name: 'StorageLocationsContainer',
|
|
components: {
|
|
DataTable,
|
|
Grid,
|
|
AssignModal,
|
|
ConfirmationModal,
|
|
RemindersRender,
|
|
ImportModal
|
|
},
|
|
props: {
|
|
canManage: {
|
|
type: String,
|
|
required: true
|
|
},
|
|
dataSource: {
|
|
type: String,
|
|
required: true
|
|
},
|
|
actionsUrl: {
|
|
type: String,
|
|
required: true
|
|
},
|
|
withGrid: {
|
|
type: Boolean,
|
|
default: false
|
|
},
|
|
containerId: {
|
|
type: Number,
|
|
default: null
|
|
},
|
|
gridSize: Array
|
|
},
|
|
data() {
|
|
return {
|
|
reloadingTable: false,
|
|
openEditModal: false,
|
|
openImportModal: false,
|
|
editModalMode: null,
|
|
editStorageLocation: null,
|
|
objectToMove: null,
|
|
moveToUrl: null,
|
|
assignedItems: [],
|
|
selectedItems: [],
|
|
openAssignModal: false,
|
|
assignToPosition: null,
|
|
assignToContainer: null,
|
|
rowIdToMove: null,
|
|
cellIdToUnassign: null,
|
|
assignMode: 'assign',
|
|
storageLocationUnassignDescription: ''
|
|
};
|
|
},
|
|
computed: {
|
|
paginationMode() {
|
|
return this.withGrid ? 'none' : 'pages';
|
|
},
|
|
|
|
columnDefs() {
|
|
const columns = [{
|
|
field: 'position_formatted',
|
|
headerName: this.i18n.t('storage_locations.show.table.position'),
|
|
sortable: true,
|
|
notSelectable: true
|
|
},
|
|
{
|
|
field: 'reminders',
|
|
headerName: this.i18n.t('storage_locations.show.table.reminders'),
|
|
sortable: true,
|
|
cellRenderer: RemindersRender
|
|
},
|
|
{
|
|
field: 'row_id',
|
|
headerName: this.i18n.t('storage_locations.show.table.row_id'),
|
|
sortable: true
|
|
},
|
|
{
|
|
field: 'row_name',
|
|
headerName: this.i18n.t('storage_locations.show.table.row_name'),
|
|
sortable: true,
|
|
cellRenderer: this.rowNameRenderer
|
|
},
|
|
{
|
|
field: 'stock',
|
|
headerName: this.i18n.t('storage_locations.show.table.stock'),
|
|
sortable: true
|
|
}];
|
|
|
|
return columns;
|
|
},
|
|
toolbarActions() {
|
|
const left = [];
|
|
|
|
if (this.canManage) {
|
|
left.push({
|
|
name: 'assign',
|
|
icon: 'sn-icon sn-icon-new-task',
|
|
label: this.i18n.t('storage_locations.show.toolbar.assign'),
|
|
type: 'emit',
|
|
buttonStyle: 'btn btn-primary'
|
|
});
|
|
}
|
|
|
|
left.push({
|
|
name: 'import',
|
|
icon: 'sn-icon sn-icon-import',
|
|
label: this.i18n.t('storage_locations.show.import_modal.import_button'),
|
|
type: 'emit',
|
|
buttonStyle: 'btn btn-light'
|
|
});
|
|
|
|
return {
|
|
left,
|
|
right: []
|
|
};
|
|
}
|
|
},
|
|
methods: {
|
|
rowNameRenderer(params) {
|
|
const { row_name: rowName, hidden } = params.data;
|
|
if (hidden) {
|
|
return `
|
|
<span class="text-sn-grey-700">
|
|
<i class="sn-icon sn-icon-locked-task"></i> ${this.i18n.t('storage_locations.show.hidden')}
|
|
</span>
|
|
`;
|
|
}
|
|
return rowName;
|
|
},
|
|
handleTableReload(items) {
|
|
this.reloadingTable = false;
|
|
this.assignedItems = items;
|
|
},
|
|
selectRow(row) {
|
|
if (this.$refs.table.selectedRows.includes(row)) {
|
|
this.$refs.table.selectedRows = this.$refs.table.selectedRows.filter((r) => r !== row);
|
|
} else {
|
|
this.$refs.table.selectedRows.push(row);
|
|
}
|
|
this.$refs.table.restoreSelection();
|
|
},
|
|
assignRow() {
|
|
this.openAssignModal = true;
|
|
this.rowIdToMove = null;
|
|
this.assignToContainer = this.containerId;
|
|
this.assignToPosition = null;
|
|
this.cellIdToUnassign = null;
|
|
this.assignMode = 'assign';
|
|
},
|
|
assignRowToPosition(position) {
|
|
this.openAssignModal = true;
|
|
this.rowIdToMove = null;
|
|
this.assignToContainer = this.containerId;
|
|
this.assignToPosition = position;
|
|
this.cellIdToUnassign = null;
|
|
this.assignMode = 'assign';
|
|
},
|
|
moveRow(_event, data) {
|
|
this.openAssignModal = true;
|
|
this.rowIdToMove = data[0].row_id;
|
|
this.assignToContainer = null;
|
|
this.assignToPosition = null;
|
|
this.cellIdToUnassign = data[0].id;
|
|
this.assignMode = 'move';
|
|
},
|
|
async unassignRows(event, rows) {
|
|
this.storageLocationUnassignDescription = this.i18n.t(
|
|
'storage_locations.show.unassign_modal.description',
|
|
{ items: rows.length }
|
|
);
|
|
const ok = await this.$refs.unassignStorageLocationModal.show();
|
|
if (ok) {
|
|
axios.post(event.path).then(() => {
|
|
this.reloadingTable = true;
|
|
}).catch((error) => {
|
|
HelperModule.flashAlertMsg(error.response.data.error, 'danger');
|
|
});
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
</script>
|