zhengyiming
12 小时以前 97f29024ce18babeb4b635c5d73f907ac493976e
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
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
<!--
 * @Author: 秦少卫
 * @Date: 2024-05-11 13:23:48
 * @LastEditors: 秦少卫
 * @LastEditTime: 2024-05-30 18:49:59
 * @Description: 文件名称
-->
 
<template>
  <div style="display: inline-block" v-if="route?.query?.id">
    <Input
      v-model="fileName"
      placeholder="请输入文件名称"
      style="width: 190px"
      size="small"
      @on-change="changeFileName"
      :loading="loading"
    />
    <Button type="text" @click="saveTempl" :loading="loading">
      <Icon type="ios-cloud-done" :color="loading ? '#ff9900' : '#19be6b'" />
    </Button>
    <Divider type="vertical" />
  </div>
</template>
 
<script name="ImportJson" setup>
import { debounce } from 'lodash-es';
import { Message } from 'view-ui-plus';
import useMaterial from '@/hooks/useMaterial';
import { useRoute, useRouter } from 'vue-router';
import useSelect from '@/hooks/select';
import { getTmplList } from '@/api/user';
 
// const APIHOST = import.meta.env.APP_APIHOST;
import qs from 'qs';
const router = useRouter();
const { getTemplInfo, updataTemplInfo } = useMaterial();
 
const { canvasEditor } = useSelect();
 
const fileName = ref('');
const route = useRoute();
const loading = ref(false);
 
watch(
  () => route.query,
  (query) => {
    if (query?.id) {
      getTemplInfo(query?.id).then((res) => {
        fileName.value = res?.data?.attributes?.name;
      });
    } else {
      fileName.value = false;
    }
  }
);
 
onMounted(async () => {
  if (route?.query?.id) {
    getTemplInfo(route?.query?.id)
      .then((res) => {
        fileName.value = res?.data?.attributes?.name;
        canvasEditor.loadJSON(JSON.stringify(res?.data?.attributes?.json));
      })
      .catch(() => {
        window.location.href = '/';
      });
  } else if (route?.query?.projectid) {
    const infoid = await queryTemplIdByProId(route?.query?.projectid);
    if (infoid) {
      getTemplInfo(infoid).then((res) => {
        router.replace(route.fullPath + '&id=' + infoid);
        fileName.value = res?.data?.attributes?.name;
        canvasEditor.loadJSON(JSON.stringify(res?.data?.attributes?.json));
      });
    }
  }
});
 
const queryTemplIdByProId = (projectid) => {
  const query = {
    populate: {
      img: '*',
    },
    filters: {
      externalId: {
        $eq: String(projectid),
      },
    },
    pagination: {
      page: 1,
      pageSize: 50,
    },
  };
 
  return getTmplList(qs.stringify(query))
    .then((res) => {
      if (res.data.data.length) {
        return res.data.data[0].id;
      }
    })
    .catch((err) => {
      return err;
    });
};
 
const saveTempl = () => {
  if (fileName.value === '') {
    Message.warning('文件名称不能为空');
    fileName.value = '默认文件名称';
    return;
  }
  loading.value = true;
  updataTemplInfo(route.query.id, fileName.value)
    .then()
    .finally(() => {
      loading.value = false;
    });
};
 
// canvasEditor
const changeFileName = debounce(() => {
  if (route.query.id) {
    saveTempl();
  }
}, 3000);
// 自动保存优化
canvasEditor.canvas.on('object:modified', changeFileName);
</script>
<style scoped lang="less">
h3 {
  margin-bottom: 10px;
}
.divider {
  margin-top: 0;
}
</style>