|
|
@ -1,18 +1,12 @@
|
|
|
|
<template>
|
|
|
|
<template>
|
|
|
|
<page-view :title="sheetToStage.title ? sheetToStage.title : '新页面'" affix>
|
|
|
|
<page-view
|
|
|
|
|
|
|
|
:sub-title="sheetToStage.inProgress ? '当前内容已保存,但还未发布。' : ''"
|
|
|
|
|
|
|
|
:title="sheetToStage.title ? sheetToStage.title : '新页面'"
|
|
|
|
|
|
|
|
affix
|
|
|
|
|
|
|
|
>
|
|
|
|
<template slot="extra">
|
|
|
|
<template slot="extra">
|
|
|
|
<a-space>
|
|
|
|
<a-space>
|
|
|
|
<ReactiveButton
|
|
|
|
<a-button :loading="previewSaving" @click="handlePreviewClick">预览</a-button>
|
|
|
|
:errored="draftSaveErrored"
|
|
|
|
|
|
|
|
:loading="draftSaving"
|
|
|
|
|
|
|
|
erroredText="保存失败"
|
|
|
|
|
|
|
|
loadedText="保存成功"
|
|
|
|
|
|
|
|
text="保存草稿"
|
|
|
|
|
|
|
|
type="danger"
|
|
|
|
|
|
|
|
@callback="draftSaveErrored = false"
|
|
|
|
|
|
|
|
@click="handleSaveDraft(false)"
|
|
|
|
|
|
|
|
></ReactiveButton>
|
|
|
|
|
|
|
|
<a-button :loading="previewSaving" @click="handlePreview">预览</a-button>
|
|
|
|
|
|
|
|
<a-button type="primary" @click="sheetSettingVisible = true">发布</a-button>
|
|
|
|
<a-button type="primary" @click="sheetSettingVisible = true">发布</a-button>
|
|
|
|
</a-space>
|
|
|
|
</a-space>
|
|
|
|
</template>
|
|
|
|
</template>
|
|
|
@ -26,7 +20,7 @@
|
|
|
|
<MarkdownEditor
|
|
|
|
<MarkdownEditor
|
|
|
|
:originalContent="sheetToStage.originalContent"
|
|
|
|
:originalContent="sheetToStage.originalContent"
|
|
|
|
@onContentChange="onContentChange"
|
|
|
|
@onContentChange="onContentChange"
|
|
|
|
@onSaveDraft="handleSaveDraft(true)"
|
|
|
|
@onSaveDraft="handleSaveDraft()"
|
|
|
|
/>
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</a-col>
|
|
|
|
</a-col>
|
|
|
@ -42,12 +36,16 @@
|
|
|
|
</template>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
<script>
|
|
|
|
import { mixin, mixinDevice, mixinPostEdit } from '@/mixins/mixin.js'
|
|
|
|
// components
|
|
|
|
import { datetimeFormat } from '@/utils/datetime'
|
|
|
|
|
|
|
|
import { PageView } from '@/layouts'
|
|
|
|
import { PageView } from '@/layouts'
|
|
|
|
import SheetSettingModal from './components/SheetSettingModal'
|
|
|
|
import SheetSettingModal from './components/SheetSettingModal'
|
|
|
|
import MarkdownEditor from '@/components/Editor/MarkdownEditor'
|
|
|
|
import MarkdownEditor from '@/components/Editor/MarkdownEditor'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// libs
|
|
|
|
|
|
|
|
import { mixin, mixinDevice, mixinPostEdit } from '@/mixins/mixin.js'
|
|
|
|
|
|
|
|
import { datetimeFormat } from '@/utils/datetime'
|
|
|
|
import apiClient from '@/utils/api-client'
|
|
|
|
import apiClient from '@/utils/api-client'
|
|
|
|
|
|
|
|
import debounce from 'lodash.debounce'
|
|
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
export default {
|
|
|
|
components: {
|
|
|
|
components: {
|
|
|
@ -61,8 +59,6 @@ export default {
|
|
|
|
sheetSettingVisible: false,
|
|
|
|
sheetSettingVisible: false,
|
|
|
|
sheetToStage: {},
|
|
|
|
sheetToStage: {},
|
|
|
|
contentChanges: 0,
|
|
|
|
contentChanges: 0,
|
|
|
|
draftSaving: false,
|
|
|
|
|
|
|
|
draftSaveErrored: false,
|
|
|
|
|
|
|
|
previewSaving: false
|
|
|
|
previewSaving: false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
@ -70,11 +66,10 @@ export default {
|
|
|
|
// Get sheetId id from query
|
|
|
|
// Get sheetId id from query
|
|
|
|
const sheetId = to.query.sheetId
|
|
|
|
const sheetId = to.query.sheetId
|
|
|
|
|
|
|
|
|
|
|
|
next(vm => {
|
|
|
|
next(async vm => {
|
|
|
|
if (sheetId) {
|
|
|
|
if (sheetId) {
|
|
|
|
apiClient.sheet.get(sheetId).then(response => {
|
|
|
|
const { data } = await apiClient.sheet.get(Number(sheetId))
|
|
|
|
vm.sheetToStage = response.data
|
|
|
|
vm.sheetToStage = data
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
})
|
|
|
|
},
|
|
|
|
},
|
|
|
@ -109,100 +104,74 @@ export default {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
methods: {
|
|
|
|
handleSaveDraft(draftOnly = false) {
|
|
|
|
handleSaveDraft: debounce(async function () {
|
|
|
|
this.$log.debug('Draft only: ' + draftOnly)
|
|
|
|
|
|
|
|
this.sheetToStage.status = 'DRAFT'
|
|
|
|
|
|
|
|
if (!this.sheetToStage.title) {
|
|
|
|
|
|
|
|
this.sheetToStage.title = datetimeFormat(new Date(), 'YYYY-MM-DD-HH-mm-ss')
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
this.draftSaving = true
|
|
|
|
|
|
|
|
if (this.sheetToStage.id) {
|
|
|
|
if (this.sheetToStage.id) {
|
|
|
|
if (draftOnly) {
|
|
|
|
try {
|
|
|
|
apiClient.sheet
|
|
|
|
const { data } = await apiClient.sheet.updateDraftById(
|
|
|
|
.updateDraftById(this.sheetToStage.id, this.sheetToStage.originalContent)
|
|
|
|
this.sheetToStage.id,
|
|
|
|
.then(() => {
|
|
|
|
this.sheetToStage.originalContent
|
|
|
|
this.handleRestoreSavedStatus()
|
|
|
|
)
|
|
|
|
})
|
|
|
|
this.sheetToStage.inProgress = data.inProgress
|
|
|
|
.catch(() => {
|
|
|
|
this.handleRestoreSavedStatus()
|
|
|
|
this.draftSaveErrored = true
|
|
|
|
this.$message.success({
|
|
|
|
})
|
|
|
|
content: '内容已保存',
|
|
|
|
.finally(() => {
|
|
|
|
duration: 0.5
|
|
|
|
setTimeout(() => {
|
|
|
|
})
|
|
|
|
this.draftSaving = false
|
|
|
|
} catch (e) {
|
|
|
|
}, 400)
|
|
|
|
this.$log.error('Failed to update sheet content', e)
|
|
|
|
})
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
apiClient.sheet
|
|
|
|
|
|
|
|
.update(this.sheetToStage.id, this.sheetToStage)
|
|
|
|
|
|
|
|
.then(response => {
|
|
|
|
|
|
|
|
this.sheetToStage = response.data
|
|
|
|
|
|
|
|
this.handleRestoreSavedStatus()
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
.catch(() => {
|
|
|
|
|
|
|
|
this.draftSaveErrored = true
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
.finally(() => {
|
|
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
|
|
this.draftSaving = false
|
|
|
|
|
|
|
|
}, 400)
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
apiClient.sheet
|
|
|
|
await this.handleCreateSheet()
|
|
|
|
.create(this.sheetToStage)
|
|
|
|
|
|
|
|
.then(response => {
|
|
|
|
|
|
|
|
this.sheetToStage = response.data
|
|
|
|
|
|
|
|
this.handleRestoreSavedStatus()
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
.catch(() => {
|
|
|
|
|
|
|
|
this.draftSaveErrored = true
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
.finally(() => {
|
|
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
|
|
this.draftSaving = false
|
|
|
|
|
|
|
|
}, 400)
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}, 300),
|
|
|
|
handlePreview() {
|
|
|
|
|
|
|
|
this.sheetToStage.status = 'DRAFT'
|
|
|
|
async handleCreateSheet() {
|
|
|
|
if (!this.sheetToStage.title) {
|
|
|
|
if (!this.sheetToStage.title) {
|
|
|
|
this.sheetToStage.title = datetimeFormat(new Date(), 'YYYY-MM-DD-HH-mm-ss')
|
|
|
|
this.sheetToStage.title = datetimeFormat(new Date(), 'YYYY-MM-DD-HH-mm-ss')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
const { data } = await apiClient.sheet.create(this.sheetToStage)
|
|
|
|
|
|
|
|
this.sheetToStage = data
|
|
|
|
|
|
|
|
this.handleRestoreSavedStatus()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// add params to url
|
|
|
|
|
|
|
|
const path = this.$router.history.current.path
|
|
|
|
|
|
|
|
this.$router.replace({ path, query: { sheetId: this.sheetToStage.id } }).catch(err => err)
|
|
|
|
|
|
|
|
this.$message.success({
|
|
|
|
|
|
|
|
content: '页面已创建',
|
|
|
|
|
|
|
|
duration: 0.5
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
} catch (e) {
|
|
|
|
|
|
|
|
this.$log.error('Failed to create sheet', e)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async handlePreviewClick() {
|
|
|
|
this.previewSaving = true
|
|
|
|
this.previewSaving = true
|
|
|
|
if (this.sheetToStage.id) {
|
|
|
|
if (this.sheetToStage.id) {
|
|
|
|
apiClient.sheet.update(this.sheetToStage.id, this.sheetToStage).then(response => {
|
|
|
|
// Update the sheet content
|
|
|
|
this.$log.debug('Updated sheet', response.data)
|
|
|
|
const { data } = await apiClient.sheet.updateDraftById(this.sheetToStage.id, this.sheetToStage.originalContent)
|
|
|
|
apiClient.sheet
|
|
|
|
this.sheetToStage.inProgress = data.inProgress
|
|
|
|
.getPreviewLinkById(this.sheetToStage.id)
|
|
|
|
|
|
|
|
.then(response => {
|
|
|
|
|
|
|
|
window.open(response, '_blank')
|
|
|
|
|
|
|
|
this.handleRestoreSavedStatus()
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
.finally(() => {
|
|
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
|
|
this.previewSaving = false
|
|
|
|
|
|
|
|
}, 400)
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
apiClient.sheet.create(this.sheetToStage).then(response => {
|
|
|
|
await this.handleCreateSheet()
|
|
|
|
this.$log.debug('Created sheet', response.data)
|
|
|
|
}
|
|
|
|
this.sheetToStage = response.data
|
|
|
|
await this.handleOpenPreview()
|
|
|
|
apiClient.sheet
|
|
|
|
},
|
|
|
|
.getPreviewLinkById(this.sheetToStage.id)
|
|
|
|
|
|
|
|
.then(response => {
|
|
|
|
async handleOpenPreview() {
|
|
|
|
window.open(response, '_blank')
|
|
|
|
try {
|
|
|
|
this.handleRestoreSavedStatus()
|
|
|
|
const response = await apiClient.sheet.getPreviewLinkById(this.sheetToStage.id)
|
|
|
|
})
|
|
|
|
window.open(response, '_blank')
|
|
|
|
.finally(() => {
|
|
|
|
this.handleRestoreSavedStatus()
|
|
|
|
setTimeout(() => {
|
|
|
|
} catch (e) {
|
|
|
|
this.previewSaving = false
|
|
|
|
this.$log.error('Failed to get preview link', e)
|
|
|
|
}, 400)
|
|
|
|
} finally {
|
|
|
|
})
|
|
|
|
setTimeout(() => {
|
|
|
|
})
|
|
|
|
this.previewSaving = false
|
|
|
|
|
|
|
|
}, 400)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
handleRestoreSavedStatus() {
|
|
|
|
handleRestoreSavedStatus() {
|
|
|
|
this.contentChanges = 0
|
|
|
|
this.contentChanges = 0
|
|
|
|
},
|
|
|
|
},
|
|
|
|