index.vue 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. <template>
  2. <div class="app-container">
  3. <div class="filter-container">
  4. <el-button type="primary" @click="submitDesignOrder">
  5. <i-ep-search />
  6. 提交
  7. </el-button>
  8. </div>
  9. <div class="table-con">
  10. <el-tabs v-model="activeName" @tab-click="handleChangeProduct">
  11. <el-tab-pane label="条幅" name="banner">
  12. <el-form ref="formRef" :model="formData" label-width="120px">
  13. <el-row>
  14. <el-col :span="12">
  15. <el-form-item prop="backgroundColor" label="材料">
  16. <el-select
  17. v-model="formData.backgroundColor"
  18. filterable
  19. placeholder="请选择"
  20. @change="refreshPreview"
  21. >
  22. <el-option
  23. v-for="item in bannerBgColorOptions"
  24. :key="item.label"
  25. :label="item.label"
  26. :value="item.color"
  27. >
  28. </el-option>
  29. </el-select>
  30. </el-form-item>
  31. </el-col>
  32. </el-row>
  33. <el-row>
  34. <el-col :span="12">
  35. <el-form-item prop="backgroundSize" label="尺寸">
  36. <el-input-number
  37. :precision="2"
  38. :controls="false"
  39. v-model="formData.backgroundWidth"
  40. @change="refreshPreview"
  41. />
  42. <span style="margin-left: 20px; margin-right: 20px">*</span>
  43. <el-input-number
  44. :precision="2"
  45. :controls="false"
  46. v-model="formData.backgroundHeight"
  47. @change="refreshPreview"
  48. />
  49. </el-form-item>
  50. </el-col>
  51. </el-row>
  52. <el-row>
  53. <el-col :span="12">
  54. <el-form-item prop="fontColor" label="印色">
  55. <el-select
  56. v-model="bannerFontObject.color"
  57. filterable
  58. placeholder="请选择"
  59. @change="refreshPreview"
  60. >
  61. <el-option
  62. v-for="item in bannerFontColorOptions"
  63. :key="item.label"
  64. :label="item.label"
  65. :value="item.color"
  66. >
  67. </el-option>
  68. </el-select>
  69. </el-form-item>
  70. </el-col>
  71. </el-row>
  72. <el-row>
  73. <el-col :span="12">
  74. <el-form-item prop="fontFamily" label="字体">
  75. <el-select
  76. v-model="bannerFontObject.fontFamily"
  77. filterable
  78. placeholder="请选择"
  79. @change="refreshPreview"
  80. >
  81. <el-option
  82. v-for="item in bannerFontFamilyOptions"
  83. :key="item.label"
  84. :label="item.label"
  85. :value="item.fontFamily"
  86. >
  87. </el-option>
  88. </el-select>
  89. </el-form-item>
  90. </el-col>
  91. </el-row>
  92. <el-row>
  93. <el-col :span="12">
  94. <el-form-item prop="fontContent" label="文字内容">
  95. <el-input
  96. v-model="bannerFontObject.text"
  97. @change="refreshPreview"
  98. />
  99. </el-form-item>
  100. </el-col>
  101. </el-row>
  102. </el-form>
  103. </el-tab-pane>
  104. <el-tab-pane label="锦旗" name="flag">锦旗</el-tab-pane>
  105. </el-tabs>
  106. <iframe
  107. id="iframe"
  108. ref="iframe"
  109. :src="iframeSrc"
  110. style="width: 1200px; height: 600px"
  111. ></iframe>
  112. </div>
  113. </div>
  114. </template>
  115. <script setup lang="ts">
  116. import { TabsPaneContext } from "element-plus";
  117. import { getDesignFonts } from "@/api/design";
  118. import { getUserInfoApi } from "@/api/user";
  119. import { getToken } from "@/utils/js-cookie";
  120. const products = ref([
  121. {
  122. label: "条幅",
  123. name: "banner",
  124. templateId: 2,
  125. },
  126. {
  127. label: "锦旗",
  128. name: "flag",
  129. templateId: 3,
  130. },
  131. ]);
  132. const bannerBgColorOptions = [
  133. { label: "红底条幅", color: "rgba(255,0,0,1)" },
  134. { label: "黄底条幅", color: "rgba(255,255,0,1)" },
  135. { label: "蓝底条幅", color: "rgba(0,0,255,1)" },
  136. { label: "绿底条幅", color: "rgba(0,255,0,1)" },
  137. ];
  138. const bannerFontColorOptions = [
  139. { label: "红色", color: "rgba(255,0,0,1)" },
  140. { label: "黄色", color: "rgba(255,255,0,1)" },
  141. { label: "白色", color: "rgba(255,255,255,1)" },
  142. ];
  143. const bannerFontFamilyOptions = ref([]);
  144. const designModuleUrl = "http://192.168.1.44:9191/?runMode=0";
  145. const outerSessionId = getToken("Access-Token"); //这个地方需要传入的是当前会话的唯一标识
  146. const iframeSrc = ref("");
  147. const iframe = ref();
  148. const formData = ref({
  149. backgroundWidth: 2000.0,
  150. backgroundHeight: 400.0,
  151. backgroundColor: "rgba(255,0,0,1)",
  152. objects: "",
  153. });
  154. const bannerFontObject = ref({
  155. id: "5p3ngaG9MM", //对应模板中的元素id
  156. color: "rgba(255,255,0,1)",
  157. text: "",
  158. fontFamily: "",
  159. });
  160. let currentProduct = {};
  161. const activeName = ref("banner");
  162. onMounted(() => {
  163. currentProduct = products.value[0];
  164. iframeSrc.value =
  165. designModuleUrl +
  166. "&template=" +
  167. currentProduct.templateId +
  168. "&sessionId=" +
  169. outerSessionId;
  170. //后台获取上传的字体
  171. const param = {
  172. voidFlag: 0,
  173. };
  174. getDesignFonts(param).then((res) => {
  175. if (res.httpCode == 200) {
  176. res.data.forEach((x) => {
  177. bannerFontFamilyOptions.value.push({
  178. label: x.fontName,
  179. fontFamily: x.fontFamily,
  180. });
  181. });
  182. }
  183. });
  184. });
  185. const handleChangeProduct = (tab: TabsPaneContext, event: Event) => {
  186. console.log(tab);
  187. currentProduct = products.value.find((x) => x.name == tab.props.name);
  188. iframeSrc.value = designModuleUrl + "?template=" + currentProduct.templateId;
  189. };
  190. const buildTemplateParams = () => {
  191. formData.value.objects = JSON.stringify([bannerFontObject.value]);
  192. return {
  193. msgType: "loadTemplate",
  194. data: formData.value,
  195. };
  196. };
  197. const refreshPreview = () => {
  198. const msg = buildTemplateParams();
  199. iframe.value.contentWindow.postMessage(JSON.stringify(msg), "*");
  200. };
  201. const submitDesignOrder = () => {
  202. const msg = {
  203. msgType: "submitOrder",
  204. data: outerSessionId,
  205. };
  206. iframe.value.contentWindow.postMessage(JSON.stringify(msg), "*");
  207. };
  208. const testIframe = () => {
  209. iframe.value.contentWindow.postMessage("Hello from parent page!", "*");
  210. };
  211. </script>
  212. <style scoped lang="scss">
  213. #iframe {
  214. pointer-events: none;
  215. }
  216. </style>