diff options
author | Joas Schilling <coding@schilljs.com> | 2022-08-30 22:25:59 +0300 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2022-08-31 09:15:39 +0300 |
commit | 20e513b590603e7dd6b5d775b1470774e62ad1c2 (patch) | |
tree | e94cc46250ada35890466d6fc829960a3f0b1248 /src | |
parent | e1f9b5a99bc628b355eac9e8fd9df12fa8982840 (diff) |
Load the template list from the files app
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/components/NewMessageForm/NewMessageForm.vue | 45 | ||||
-rw-r--r-- | src/services/filesSharingServices.js | 5 | ||||
-rw-r--r-- | src/store/fileUploadStore.js | 32 |
3 files changed, 66 insertions, 16 deletions
diff --git a/src/components/NewMessageForm/NewMessageForm.vue b/src/components/NewMessageForm/NewMessageForm.vue index 8072de93d..c3d62a70d 100644 --- a/src/components/NewMessageForm/NewMessageForm.vue +++ b/src/components/NewMessageForm/NewMessageForm.vue @@ -63,14 +63,15 @@ </template> {{ shareFromNextcloudLabel }} </NcActionButton> - <NcActionButton v-if="canShareFiles" - :close-after-click="true" - @click.prevent="showTextFileDialog = true"> - <template #icon> - <TextBox :size="20" /> - </template> - {{ t('spreed', 'Create text file') }} - </NcActionButton> + <template v-if="canShareFiles"> + <NcActionButton v-for="(fileTemplate, i) in fileTemplateOptions" + :key="i" + :close-after-click="true" + :icon="fileTemplate.iconClass" + @click.prevent="showTextFileDialog = i"> + {{ fileTemplate.label }} + </NcActionButton> + </template> <NcActionButton v-if="canCreatePoll" :close-after-click="true" @click.prevent="toggleSimplePollsEditor(true)"> @@ -160,12 +161,12 @@ @close="toggleSimplePollsEditor(false)" /> <!-- Text file creation dialog --> - <NcModal v-if="showTextFileDialog" + <NcModal v-if="showTextFileDialog !== false" size="small" @close="dismissTextFileCreation"> <div class="new-text-file"> <h2> - {{ t('spreed', 'Create and share a text file') }} + {{ t('spreed', 'Create and share a new file') }} </h2> <form class="new-text-file__form" @submit.prevent="handleCreateTextFile"> @@ -178,7 +179,7 @@ </NcButton> <NcButton type="primary" @click="handleCreateTextFile"> - {{ t('spreed', 'Create text file') }} + {{ t('spreed', 'Create file') }} </NcButton> </div> </div> @@ -205,7 +206,6 @@ import BellOff from 'vue-material-design-icons/BellOff.vue' import AudioRecorder from './AudioRecorder/AudioRecorder.vue' import SimplePollsEditor from './SimplePollsEditor/SimplePollsEditor.vue' import Poll from 'vue-material-design-icons/Poll.vue' -import TextBox from 'vue-material-design-icons/TextBox.vue' import NcModal from '@nextcloud/vue/dist/Components/NcModal.js' import Folder from 'vue-material-design-icons/Folder.vue' import Upload from 'vue-material-design-icons/Upload.vue' @@ -236,7 +236,6 @@ export default { BellOff, SimplePollsEditor, Poll, - TextBox, NcModal, Folder, Upload, @@ -362,6 +361,10 @@ export default { shareFromNextcloudLabel() { return t('spreed', 'Share from {nextcloud}', { nextcloud: window.oc_defaults.productName }) }, + + fileTemplateOptions() { + return this.$store.getters.getFileTemplates() + }, }, watch: { @@ -382,7 +385,9 @@ export default { }, showTextFileDialog(newValue) { - if (newValue) { + if (newValue !== false) { + const fileTemplate = this.fileTemplateOptions[newValue] + this.textFileTitle = fileTemplate.label + fileTemplate.extension this.$nextTick(() => { this.focusTextDialogInput() }) @@ -395,6 +400,10 @@ export default { EventBus.$on('retry-message', this.handleRetryMessage) this.text = this.$store.getters.currentMessageInput(this.token) || '' // this.startRecording() + + if (!this.$store.getters.areFileTemplatesInitialised) { + this.$store.dispatch('getFileTemplates') + } }, beforeDestroy() { @@ -642,7 +651,13 @@ export default { // Create text file and share it to a conversation async handleCreateTextFile() { - const filePath = this.textFileTitle + '.md' + let filePath = this.textFileTitle + const fileTemplate = this.fileTemplateOptions[this.showTextFileDialog] + + if (!filePath.endsWith(fileTemplate.extension)) { + filePath += fileTemplate.extension + } + await createTextFile(filePath) // FIXME If creation failed we should not share, as it could be an old/other file with the same name. const response = await shareFile(filePath, this.token) diff --git a/src/services/filesSharingServices.js b/src/services/filesSharingServices.js index 04e6cf492..213c76c50 100644 --- a/src/services/filesSharingServices.js +++ b/src/services/filesSharingServices.js @@ -55,6 +55,10 @@ const shareFile = async function(path, token, referenceId, metadata) { } } +const getFileTemplates = async () => { + return await axios.get(generateOcsUrl('apps/files/api/v1/templates')) +} + /** * Share a text file to a conversation * @@ -82,5 +86,6 @@ const createTextFile = async function(filePath) { export { shareFile, + getFileTemplates, createTextFile, } diff --git a/src/store/fileUploadStore.js b/src/store/fileUploadStore.js index 38810179a..581949d99 100644 --- a/src/store/fileUploadStore.js +++ b/src/store/fileUploadStore.js @@ -27,7 +27,10 @@ import fromStateOr from './helper.js' import { findUniquePath, getFileExtension } from '../utils/fileUpload.js' import moment from '@nextcloud/moment' import { EventBus } from '../services/EventBus.js' -import { shareFile } from '../services/filesSharingServices.js' +import { + getFileTemplates, + shareFile, +} from '../services/filesSharingServices.js' import { setAttachmentFolder } from '../services/settingsService.js' const state = { @@ -36,6 +39,9 @@ const state = { uploads: { }, currentUploadId: undefined, + + fileTemplatesInitialised: false, + fileTemplates: [], } const getters = { @@ -93,6 +99,14 @@ const getters = { currentUploadId: (state) => { return state.currentUploadId }, + + areFileTemplatesInitialised: (state) => { + return state.fileTemplatesInitialised + }, + + getFileTemplates: (state) => () => { + return state.fileTemplates + }, } const mutations = { @@ -182,6 +196,11 @@ const mutations = { discardUpload(state, { uploadId }) { Vue.delete(state.uploads, uploadId) }, + + storeFilesTemplates(state, { template }) { + state.fileTemplates.push(template) + state.fileTemplatesInitialised = true + }, } const actions = { @@ -406,6 +425,17 @@ const actions = { commit('removeFileFromSelection', temporaryMessageId) }, + async getFileTemplates({ commit }) { + try { + const response = await getFileTemplates() + + response.data.ocs.data.forEach(template => { + commit('storeFilesTemplates', { template }) + }) + } catch (error) { + console.error('An error happened when trying to load the templates', error) + } + }, } export default { state, mutations, getters, actions } |