完善前端默认模板文件,确保创建的模板vue文件不会引起错误

This commit is contained in:
jingrow 2025-10-28 00:36:55 +08:00
parent bef1955fde
commit 7d2959b708

View File

@ -77,29 +77,40 @@ async def create_pagetypes(payload: Dict[str, Any]):
frontend_exists = True
else:
# 创建字段类型组件的模板
field_content = f'''<script setup lang="ts">
import {{ computed }} from 'vue'
field_content = '''<script setup lang="ts">
import { computed } from 'vue'
import { NInput } from 'naive-ui'
const props = defineProps<{{
const props = defineProps<{
df: any;
record: Record<string, any>;
canEdit: boolean;
ctx: any
}}>()
}>()
// TODO: 实现 {field_type_name} 字段类型逻辑
// Label布局上下结构(vertical) 左右结构(horizontal)
const labelLayout = computed(() => props.df.label_layout || 'vertical')
</script>
<template>
<div class="field-{field_type_name.lower()}">
<!-- TODO: 实现 {field_type_name} 界面 -->
<div :class="['field-wrapper', `layout-${labelLayout}`]">
<label class="field-label">
{{ ctx.t(df.label || df.fieldname) }}
<span v-if="df.reqd" class="required">*</span>
</label>
<n-input
v-model:value="record[df.fieldname]"
type="text"
:placeholder="ctx.t(df.fieldname)"
:disabled="!canEdit"
/>
</div>
</template>
<style scoped>
.field-{field_type_name.lower()} {{
/* TODO: 添加样式 */
}}
.field-wrapper :deep(.n-input) {
flex: 1;
}
</style>
'''
field_file.write_text(field_content, encoding="utf-8")