zs
2025-04-28 adbd9157eeff10b3212417550525d8ff3102edae
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
import { defineComponent, Fragment, onMounted, ref, Ref } from 'vue'
import sdk from 'sdk'
const { request } = sdk.utils
import { _t, Language } from '@/libs/Language/Language'
import styles from './BaseConfigSelect.module.scss'
import { getXProject } from '@/api'
export default defineComponent({
  name: 'BaseConfigSelect',
  props: {
    language: String,
  },
  setup(props) {
    const options: Ref<any[]> = ref([])
    const langValue = ref()
    const getOptions = async () => {
      const resp = await request.get(`/api/v1/multiplelanguage/languagelist`)
      const defaultOptions = [
        {
          id: 0,
          languageType: 'auto',
          enable: true,
          createDateTime: new Date().toDateString(),
          name: '跟随系统',
        },
      ]
 
      defaultOptions.unshift({
        id: 0,
        languageType: 'original',
        enable: true,
        createDateTime: new Date().toDateString(),
        name: '原始文本',
      })
 
      options.value.push(...defaultOptions, ...resp)
      langValue.value = options.value?.[0]?.languageType
    }
 
    const getProject = async () => {
      const tree = await getXProject()
      // console.log(tree, 'tree')
    }
 
    onMounted(() => {
      // getProject()
      getOptions()
    })
    const change = (val: any) => {
      window.app.current.project.current.language = new Language({
        lang: langValue.value,
        running: true,
      })
    }
    return () => (
      <Fragment>
        <el-select
          v-model={langValue.value}
          class={styles.select}
          filterable
          size="small"
          onChange={change}
        >
          {options.value.map((item) => {
            return (
              <el-option
                key={item.id}
                label={_t(item.name)}
                value={item.languageType}
              ></el-option>
            )
          })}
        </el-select>
        {/* <el-select
          v-model={langValue.value}
          class={styles.project}
          filterable
          size="small"
          onChange={change}
        >
          {options.value.map((item) => {
            return (
              <el-option
                key={item.id}
                label={_t(item.name)}
                value={item.languageType}
              ></el-option>
            )
          })}
        </el-select> */}
      </Fragment>
    )
  },
})