/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { useI18n } from 'vue-i18n' import { IEmit } from '../types' import { useRouter } from 'vue-router' import type { Router } from 'vue-router' import { useFileStore } from '@/store/file/file' import { createDirectory } from '@/service/modules/resources' export function useFolder(state: any) { const { t } = useI18n() const router: Router = useRouter() const fileStore = useFileStore() const handleCreateFolder = ( emit: IEmit, hideModal: () => void, resetForm: () => void, ) => { const pid = router.currentRoute.value.params.id || -1 const currentDir = fileStore.getCurrentDir || '/' state.folderFormRef.validate(async (valid: any) => { if (!valid) { try { await createDirectory({ ...state.folderForm, ...{ pid, currentDir }, }) window.$message.success(t('resource.file.success')) emit('updateList') } catch (error: any) { window.$message.error(error.message) } hideModal() resetForm() } }) } return { handleCreateFolder, } }