resource-file-edit.tsx 3.5 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118
/*
 * 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 { useRouter } from 'vue-router'
import { defineComponent, onMounted, ref, toRefs } from 'vue'
import { NButton, NForm, NFormItem, NSpace } from 'naive-ui'
import { useI18n } from 'vue-i18n'
import Card from '@/components/card'
import MonacoEditor from '@/components/monaco-editor'
import { useForm } from './use-form'
import { useEdit } from './use-edit'

import styles from '../index.module.scss'
import type { Router } from 'vue-router'

export default defineComponent({
  name: 'ResourceFileEdit',
  setup() {
    const router: Router = useRouter()

    const resourceViewRef = ref()
    const codeEditorRef = ref()
    const routeNameRef = ref(router.currentRoute.value.name)
    const idRef = ref(Number(router.currentRoute.value.params.id))

    const { state } = useForm()
    const { getResourceView, handleUpdateContent } = useEdit(state)

    const handleFileContent = () => {
      state.fileForm.content = codeEditorRef.value?.getValue()
      handleUpdateContent(idRef.value)
    }

    const handleReturn = () => {
      router.go(-1)
    }

    onMounted(() => {
      resourceViewRef.value = getResourceView(idRef.value)
    })

    return {
      idRef,
      routeNameRef,
      codeEditorRef,
      resourceViewRef,
      handleReturn,
      handleFileContent,
      ...toRefs(state),
    }
  },
  render() {
    const { t } = useI18n()
    return (
      <Card title={t('resource.file.file_details')}>
        <div class={styles['file-edit-content']}>
          <h2>
            <span>{this.resourceViewRef?.value.alias}</span>
          </h2>
          <NForm
            rules={this.rules}
            ref='fileFormRef'
            class={styles['form-content']}
          >
            <NFormItem path='content'>
              <div
                class={styles.cont}
                style={{
                  width: '90%',
                }}
              >
                <MonacoEditor
                  ref='codeEditorRef'
                  modelValue={this.resourceViewRef?.value.content}
                />
              </div>
            </NFormItem>
            {this.routeNameRef === 'resource-file-edit' && (
              <NSpace>
                <NButton
                  type='info'
                  size='small'
                  text
                  style={{ marginRight: '15px' }}
                  onClick={this.handleReturn}
                >
                  {t('resource.file.return')}
                </NButton>
                <NButton
                  type='info'
                  size='small'
                  round
                  onClick={() => this.handleFileContent()}
                >
                  {t('resource.file.save')}
                </NButton>
              </NSpace>
            )}
          </NForm>
        </div>
      </Card>
    )
  },
})