<template lang="pug"> .editor nav-header template(slot='actions') v-btn(outline, color='green', @click.native.stop='save') v-icon(color='green', left) check span.white--text(v-if='mode === "create"') {{ $t('common:actions.create') }} span.white--text(v-else) {{ $t('common:actions.save') }} v-btn.is-icon(outline, color='red').mx-0: v-icon(color='red') close v-btn(outline, color='blue', @click.native.stop='openModal(`properties`)', dark) v-icon(left) sort_by_alpha span.white--text {{ $t('editor:page') }} v-content editor-code component(:is='currentModal') v-dialog(v-model='dialogProgress', persistent, max-width='350') v-card(color='blue darken-3', dark) v-card-text.text-xs-center.py-4 atom-spinner.is-inline( :animation-duration='1000' :size='60' color='#FFF' ) .subheading {{ $t('editor:save.processing') }} .caption.blue--text.text--lighten-3 {{ $t('editor:save.pleaseWait') }} v-snackbar( :color='notification.style' bottom, right, multi-line, v-model='notificationState' ) .text-xs-left v-icon.mr-3(dark) {{ notification.icon }} span {{ notification.message }} </template> <script> import _ from 'lodash' import { get, sync } from 'vuex-pathify' import { AtomSpinner } from 'epic-spinners' import createPageMutation from 'gql/editor/create.gql' import editorStore from '@/store/editor' /* global WIKI */ WIKI.$store.registerModule('editor', editorStore) export default { components: { AtomSpinner, editorCode: () => import(/* webpackChunkName: "editor-code" */ './editor/editor-code.vue'), editorModalProperties: () => import(/* webpackChunkName: "editor" */ './editor/editor-modal-properties.vue') }, data() { return { currentModal: '', dialogProgress: false } }, computed: { mode: get('editor/mode'), notification: get('notification'), notificationState: sync('notification@isActive') }, mounted() { if (this.mode === 'create') { _.delay(() => { this.openModal('properties') }, 500) } }, methods: { openModal(name) { this.currentModal = `editorModal${_.startCase(name)}` }, closeModal() { _.delay(() => { this.currentModal = `` }, 500) }, showProgressDialog(textKey) { this.dialogProgress = true }, hideProgressDialog() { this.dialogProgress = false }, async save() { this.showProgressDialog('saving') if (this.$store.get('editor/mode') === 'create') { const resp = await this.$apollo.mutate({ mutation: createPageMutation, variables: { content: this.$store.get('editor/content'), description: this.$store.get('editor/description'), editor: 'markdown', locale: this.$store.get('editor/locale'), isPrivate: false, isPublished: this.$store.get('editor/isPublished'), path: this.$store.get('editor/path'), publishEndDate: this.$store.get('editor/publishEndDate'), publishStartDate: this.$store.get('editor/publishStartDate'), tags: this.$store.get('editor/tags'), title: this.$store.get('editor/title') } }) if (_.get(resp, 'data.pages.create.responseResult.succeeded')) { this.$store.commit('showNotification', { message: this.$t('editor:save.success'), style: 'success', icon: 'check' }) this.$store.set('editor/mode', 'update') } else { } } else { } this.hideProgressDialog() } } } </script> <style lang='scss'> .atom-spinner.is-inline { display: inline-block; } </style>