CrEditProperty.ce.vue 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728
  1. <template>
  2. <div class="jt-wall-dialog">
  3. <el-dialog :modal="false" :destroy-on-close="false" v-model="dialogVisible" :title="title" :style="{ left: '10rem', background: 'rgb(0 44 126 / 68%)', height: 'calc(100% - 175rem)', width: '180rem', top: '125rem' }" @close="closeDialog" @open="openDialog" :show-close="false">
  4. <template #header>
  5. <div slot="title" class="header-title">
  6. <span style="line-height:24rem;font-size:16rem;color:#fff;font-family: 'Alimama_ShuHeiTi_Bold'">{{ title }}</span>
  7. </div>
  8. </template>
  9. <template #default>
  10. <div class="odin-dialog__content">
  11. <div class="jt-wall-row" v-show="isShowHeight">
  12. <div class="col-left">高度</div>
  13. <div class="col-main">
  14. <el-input v-model="wallHeight" placeholder="输入高度值" clearable />
  15. </div>
  16. </div>
  17. <div class="jt-wall-row" v-show="isShowArcHeight">
  18. <div class="col-left">弯曲度</div>
  19. <div class="col-main">
  20. <el-input v-model="arcHeight" placeholder="输入弯曲度0~9000" clearable />
  21. </div>
  22. </div>
  23. <div class="jt-wall-row" v-show="isShowLineWidth">
  24. <div class="col-left">线宽</div>
  25. <div class="col-main">
  26. <el-input v-model="lineWidth" placeholder="输入宽度值" clearable />
  27. </div>
  28. </div>
  29. <div class="jt-wall-row" v-show="isShowGlowpower">
  30. <div class="col-left">发光强度</div>
  31. <div class="col-main">
  32. <el-input v-model="glowPower" placeholder="输入发光强度0~1" clearable />
  33. </div>
  34. </div>
  35. <div class="jt-wall-row" v-show="isShowColor">
  36. <div class="col-left">颜色</div>
  37. <div class="col-main">
  38. <el-config-provider :locale="locale">
  39. <el-color-picker v-model="color" show-alpha :predefine="predefineColors" label="12" />
  40. </el-config-provider>
  41. </div>
  42. </div>
  43. <div class="jt-wall-row" v-show="isShowDirection">
  44. <div class="col-left">流动方向</div>
  45. <div class="col-main">
  46. <el-radio-group v-model="radioDirection">
  47. <el-radio-button v-for="(item, index) in directions" :label="item.key" v-model="item.value" @change="directionChange" />
  48. </el-radio-group>
  49. </div>
  50. </div>
  51. <div class="jt-wall-row" v-show="isShowOrder">
  52. <div class="col-left">流动顺序</div>
  53. <div class="col-main">
  54. <el-radio-group v-model="radioOrder">
  55. <el-radio-button v-for="(item, index) in orders" :label="item.key" v-model="item.value" />
  56. </el-radio-group>
  57. </div>
  58. </div>
  59. <div class="jt-wall-row" v-show="isShowSpeed">
  60. <div class="col-left">流动时间</div>
  61. <div class="col-main">
  62. <div class="col-main">
  63. <el-input v-model="speed" placeholder="输入流动时间0~10" clearable />
  64. </div>
  65. </div>
  66. </div>
  67. <div class="jt-wall-row" v-show="isShowCount">
  68. <div class="col-left">重复数量</div>
  69. <div class="col-main">
  70. <el-input v-model="yCount" placeholder="输入1~100" clearable />
  71. </div>
  72. </div>
  73. <div class="jt-wall-row" v-show="isShowText" style="height: 60rem;">
  74. <div class="col-left">文字内容</div>
  75. <div class="col-main">
  76. <el-input v-model="txtContent" placeholder="输入显示的文字内容" clearable type="textarea" :rows="2" />
  77. </div>
  78. </div>
  79. <div class="jt-wall-row" v-show="isShowOutlineWidth">
  80. <div class="col-left">描边宽度</div>
  81. <div class="col-main">
  82. <el-input v-model="outlineWidth" placeholder="输入宽度值" clearable />
  83. </div>
  84. </div>
  85. <div class="jt-wall-row" v-show="isShowOutlineColor">
  86. <div class="col-left">描边颜色</div>
  87. <div class="col-main">
  88. <el-config-provider :locale="locale">
  89. <el-color-picker v-model="outlineColor" show-alpha :predefine="predefineColors" label="12" />
  90. </el-config-provider>
  91. </div>
  92. </div>
  93. <div class="jt-wall-row" v-show="isShowVideoUrl" style="height: 100rem;">
  94. <div class="col-left">视频地址</div>
  95. <div class="col-main">
  96. <el-input v-model="txtVideoUrl" placeholder="输入播放视频的地址" clearable type="textarea" :rows="4" />
  97. </div>
  98. </div>
  99. <div class="jt-wall-row" v-show="isShowAxis">
  100. <div class="col-left">X轴平移</div>
  101. <div class="col-main">
  102. <el-input-number v-model="axisX" :precision="2" :step="0.1" :max="10"></el-input-number>
  103. </div>
  104. </div>
  105. <div class="jt-wall-row" v-show="isShowAxis">
  106. <div class="col-left">Y轴平移</div>
  107. <div class="col-main">
  108. <el-input-number v-model="axisY" :precision="2" :step="0.1" :max="10"></el-input-number>
  109. </div>
  110. </div>
  111. <div class="jt-wall-row" v-show="isShowAxis">
  112. <div class="col-left">Z轴平移</div>
  113. <div class="col-main">
  114. <el-input-number v-model="axisZ" :precision="2" :step="0.1" :max="10"></el-input-number>
  115. </div>
  116. </div>
  117. <div class="el-body-foot">
  118. <el-button-group>
  119. <el-button type="primary" :icon="Edit" @click="submit()">修改</el-button>
  120. <el-button type="primary" style="background-color: rgb(222, 146, 47);" :icon="Delete" @click="remove()">删除</el-button>
  121. <el-button type="primary" style="background-color: rgb(126, 128, 135);" :icon="Close" @click="close()">关闭</el-button>
  122. </el-button-group>
  123. </div>
  124. </div>
  125. </template>
  126. </el-dialog>
  127. </div>
  128. </template>
  129. <script setup>
  130. /* 引入ref和reactive 其中ref用于简单类型 reactive用于复杂类型 */
  131. import {
  132. computed,
  133. ref,
  134. reactive,
  135. toRefs,
  136. watch,
  137. getCurrentInstance
  138. } from 'vue';
  139. import {
  140. ElDialog,
  141. ElInput,
  142. ElButtonGroup,
  143. ElConfigProvider,
  144. ElColorPicker,
  145. ElRadioButton,
  146. ElButton,
  147. ElRadioGroup,
  148. ElInputNumber
  149. } from 'element-plus';
  150. import zhCn from 'element-plus/dist/locale/zh-cn.mjs';
  151. import en from 'element-plus/dist/locale/en.mjs';
  152. import {
  153. ArrowLeft,
  154. ArrowRight,
  155. Delete,
  156. Edit,
  157. Share,
  158. Close
  159. } from '@element-plus/icons-vue';
  160. import {
  161. param,
  162. type
  163. } from 'jquery';
  164. import {
  165. DrawTools
  166. } from './DrawTools.js';
  167. const language = ref('zh-cn');
  168. const locale = computed(() => (language.value === 'zh-cn' ? zhCn : en));
  169. const {
  170. proxy
  171. } = getCurrentInstance();
  172. const props = defineProps({
  173. params: {
  174. id: {
  175. type: String,
  176. default: () => undefined
  177. },
  178. height: {
  179. type: Number,
  180. default: () => 13
  181. },
  182. bottomHeight: {
  183. type: Number,
  184. default: () => 0
  185. },
  186. color: {
  187. type: String,
  188. default: () => '255,255,0,0.9'
  189. },
  190. direction: {
  191. type: String,
  192. default: () => 'horizontal'
  193. },
  194. order: {
  195. type: String,
  196. default: () => '+'
  197. },
  198. count: {
  199. type: Number,
  200. default: () => 2
  201. },
  202. text: {
  203. type: String,
  204. default: () => ''
  205. },
  206. lineWidth: {
  207. type: Number,
  208. default: () => 2
  209. },
  210. glowPower: {
  211. type: Number,
  212. default: () => 0.25
  213. },
  214. outlineWidth: {
  215. type: Number,
  216. default: () => 0
  217. },
  218. outlineColor: {
  219. type: String,
  220. default: () => '255,255,0,0.9'
  221. },
  222. speed: {
  223. type: Number,
  224. default: () => 1.5
  225. },
  226. videoUrl: {
  227. type: String,
  228. default: () => ''
  229. },
  230. arcHeight: {
  231. type: Number,
  232. default: () => 1000
  233. },
  234. axisX: {
  235. type: Number,
  236. default: () => 0
  237. },
  238. axisY: {
  239. type: Number,
  240. default: () => 0
  241. },
  242. axisZ: {
  243. type: Number,
  244. default: () => 0
  245. }
  246. },
  247. showDialog: {
  248. type: Boolean,
  249. default: () => false
  250. }
  251. });
  252. const emit = defineEmits(['submit', 'update:showDialog', 'update:params', 'remove']);
  253. /* 默认颜色 */
  254. const predefineColors = ref([
  255. '#ff4500',
  256. '#ff8c00',
  257. '#ffd700',
  258. '#90ee90',
  259. '#00ced1',
  260. '#1e90ff',
  261. '#c71585',
  262. 'rgba(255, 69, 0, 0.68)',
  263. 'rgb(255, 120, 0)',
  264. 'hsv(51, 100, 98)',
  265. 'hsva(120, 40, 94, 0.5)',
  266. 'hsl(181, 100%, 37%)',
  267. 'hsla(209, 100%, 56%, 0.73)',
  268. '#c7158577'
  269. ]);
  270. /* 初始赋值 */
  271. const isShowColor = ref(false);
  272. const isShowText = ref(false);
  273. const isShowHeight = ref(false);
  274. const isShowDirection = ref(false);
  275. const isShowOrder = ref(false);
  276. const isShowCount = ref(false);
  277. const isLineWidth = ref(false);
  278. const isShowLineWidth = ref(false);
  279. const isShowGlowpower = ref(false);
  280. const isShowOutlineWidth = ref(false);
  281. const isShowOutlineColor = ref(false);
  282. const isShowSpeed = ref(false);
  283. const isShowVideoUrl = ref(false);
  284. const isShowArcHeight = ref(false);
  285. const isShowAxis = ref(false);
  286. const color = ref(props.params.color);
  287. const title = ref('属性编辑');
  288. const dialogVisible = ref(props.showDialog);
  289. const directions = reactive([{
  290. key: '左右',
  291. value: 'horizontal'
  292. }, {
  293. key: '上下',
  294. value: 'vertical'
  295. }]);
  296. const orders = reactive([]);
  297. const radioDirection = ref('');
  298. const radioOrder = ref('');
  299. const wallHeight = ref(0);
  300. const yCount = ref(0);
  301. const txtContent = ref('');
  302. const lineWidth = ref(0);
  303. const glowPower = ref(0.25);
  304. const outlineWidth = ref(0);
  305. const outlineColor = ref(props.params.outlineColor);
  306. const speed = ref(1.5);
  307. const txtVideoUrl = ref('');
  308. const arcHeight = ref(1000);
  309. const axisX = ref(0);
  310. const axisY = ref(0);
  311. const axisZ = ref(0);
  312. /* 根据传递的属性更新 */
  313. updateParams(props.params);
  314. /**
  315. * 根据参数更新内容
  316. * @param {JSON} params 参数
  317. */
  318. function updateParams(params) {
  319. /* 保存到本地 */
  320. proxy._params = params;
  321. _setShowControls(false);
  322. /* 根据参数的显示不同的内容 */
  323. if (params.id === DrawTools.DrawType.TextWall) {
  324. title.value = '广告牌编辑';
  325. isShowColor.value = true;
  326. isShowText.value = true;
  327. isShowHeight.value = true;
  328. } else if (params.id === DrawTools.DrawType.DynamicWall) {
  329. title.value = '动态围栏编辑';
  330. isShowColor.value = true;
  331. isShowDirection.value = true;
  332. isShowOrder.value = true;
  333. isShowCount.value = true;
  334. isShowHeight.value = true;
  335. isShowSpeed.value = true;
  336. } else if (params.id === DrawTools.DrawType.NormalWall) {
  337. title.value = '普通围栏编辑';
  338. isShowColor.value = true;
  339. isShowHeight.value = true;
  340. } else if (params.id === DrawTools.DrawType.Circle) {
  341. title.value = '贴地圆编辑';
  342. isShowColor.value = true;
  343. isShowOutlineColor.value = true;
  344. isShowOutlineWidth.value = true;
  345. } else if (params.id === DrawTools.DrawType.DynamicCircle) {
  346. title.value = '扩散圆编辑';
  347. isShowColor.value = true;
  348. isShowCount.value = true;
  349. isShowSpeed.value = true;
  350. } else if (params.id === DrawTools.DrawType.House) {
  351. title.value = '房屋编辑';
  352. isShowColor.value = true;
  353. isShowHeight.value = true;
  354. } else if (params.id === DrawTools.DrawType.VideoWall) {
  355. title.value = '视频墙编辑';
  356. isShowHeight.value = true;
  357. isShowVideoUrl.value = true;
  358. isShowAxis.value = true;
  359. } else if (params.id === DrawTools.DrawType.Polyline) {
  360. title.value = '贴地线编辑';
  361. isShowColor.value = true;
  362. isShowLineWidth.value = true;
  363. } else if (params.id === DrawTools.DrawType.ArrowPolyline) {
  364. title.value = '箭头线编辑';
  365. isShowColor.value = true;
  366. isShowLineWidth.value = true;
  367. } else if (params.id === DrawTools.DrawType.DynamicPolyline) {
  368. title.value = '动态线编辑';
  369. isShowColor.value = true;
  370. isShowOrder.value = true;
  371. isShowCount.value = true;
  372. isShowLineWidth.value = true;
  373. isShowSpeed.value = true;
  374. } else if (params.id === DrawTools.DrawType.GrowPolyline) {
  375. title.value = '发光线编辑';
  376. isShowColor.value = true;
  377. isShowLineWidth.value = true;
  378. isShowGlowpower.value = true;
  379. } else if (params.id === DrawTools.DrawType.OutlinePolyline) {
  380. title.value = '描边线编辑';
  381. isShowColor.value = true;
  382. isShowLineWidth.value = true;
  383. isShowOutlineColor.value = true;
  384. isShowOutlineWidth.value = true;
  385. } else if (params.id === DrawTools.DrawType.Polygon) {
  386. title.value = '贴地面编辑';
  387. isShowColor.value = true;
  388. isShowOutlineColor.value = true;
  389. isShowOutlineWidth.value = true;
  390. } else if (params.id === DrawTools.DrawType.Rectangle) {
  391. title.value = '矩形编辑';
  392. isShowColor.value = true;
  393. isShowOutlineColor.value = true;
  394. isShowOutlineWidth.value = true;
  395. } else if (params.id === DrawTools.DrawType.SpatialLine) {
  396. title.value = '空间线编辑';
  397. isShowColor.value = true;
  398. isShowLineWidth.value = true;
  399. } else if (params.id === DrawTools.DrawType.OdLine) {
  400. title.value = 'OD线编辑';
  401. isShowSpeed.value = true;
  402. isShowColor.value = true;
  403. isShowLineWidth.value = true;
  404. isShowOrder.value = true;
  405. isShowArcHeight.value = true;
  406. } else {
  407. _setShowControls(false);
  408. }
  409. color.value = params.color;
  410. /* 判断方向及顺序 */
  411. if (params.direction === 'horizontal') {
  412. radioDirection.value = directions[0].key;
  413. Object.assign(orders, [{
  414. key: '自左至右',
  415. value: '-'
  416. }, {
  417. key: '自右至左',
  418. value: '+'
  419. }]);
  420. if (params.order === '-') {
  421. radioOrder.value = orders[0].key;
  422. } else {
  423. radioOrder.value = orders[1].key;
  424. }
  425. } else {
  426. radioDirection.value = directions[1].key;
  427. Object.assign(orders, [{
  428. key: '自上至下',
  429. value: '+'
  430. }, {
  431. key: '自下至上',
  432. value: '-'
  433. }]);
  434. if (params.order === '+') {
  435. radioOrder.value = orders[0].key;
  436. } else {
  437. radioOrder.value = orders[1].key;
  438. }
  439. }
  440. /* 单独更改 */
  441. if (params.id === DrawTools.DrawType.OdLine) {
  442. Object.assign(orders, [{
  443. key: '汇聚',
  444. value: '+'
  445. }, {
  446. key: '扩散',
  447. value: '-'
  448. }]);
  449. if (params.order === '+') {
  450. radioOrder.value = orders[0].key;
  451. } else {
  452. radioOrder.value = orders[1].key;
  453. }
  454. }
  455. wallHeight.value = parseFloat(params.height).toFixed(2);
  456. yCount.value = params.count;
  457. txtContent.value = params.text;
  458. lineWidth.value = params.lineWidth;
  459. glowPower.value = params.power;
  460. outlineColor.value = params.outlineColor;
  461. outlineWidth.value = params.outlineWidth;
  462. speed.value = (parseFloat(params.duration) / 1000).toFixed(2);
  463. txtVideoUrl.value = params.videoUrl;
  464. arcHeight.value = params.odlineHeight;
  465. axisX.value = params.axisX;
  466. axisY.value = params.axisY;
  467. axisZ.value = params.axisZ;
  468. // console.log('===设置参数显示>>>', params.lineWidth);
  469. }
  470. /**
  471. * 显示控件设置
  472. * @param {Boolean} isShow 是否显示
  473. */
  474. function _setShowControls(isShow) {
  475. isShowColor.value = isShow;
  476. isShowText.value = isShow;
  477. isShowDirection.value = isShow;
  478. isShowOrder.value = isShow;
  479. isShowCount.value = isShow;
  480. isShowHeight.value = isShow;
  481. isShowLineWidth.value = isShow;
  482. isShowGlowpower.value = isShow;
  483. isShowOutlineColor.value = isShow;
  484. isShowOutlineWidth.value = isShow;
  485. isShowSpeed.value = isShow;
  486. isShowVideoUrl.value = isShow;
  487. isShowArcHeight.value = isShow;
  488. isShowAxis.value = isShow;
  489. }
  490. /**
  491. * 对外部公开的函数
  492. */
  493. defineExpose({
  494. // updateParams
  495. });
  496. /**
  497. * 提交更改
  498. */
  499. function submit() {
  500. let outParam = proxy._params;
  501. outParam.height = wallHeight.value;
  502. outParam.color = color.value;
  503. outParam.direction = directions.filter(item => {
  504. return item.key === radioDirection.value;
  505. })[0].value;
  506. outParam.order = orders.filter(item => {
  507. return item.key === radioOrder.value;
  508. })[0].value;
  509. outParam.count = yCount.value;
  510. outParam.text = txtContent.value;
  511. outParam.lineWidth = lineWidth.value;
  512. outParam.power = glowPower.value;
  513. outParam.outlineColor = outlineColor.value;
  514. outParam.outlineWidth = outlineWidth.value;
  515. outParam.duration = speed.value * 1000;
  516. outParam.videoUrl = txtVideoUrl.value;
  517. outParam.odlineHeight = arcHeight.value;
  518. outParam.bottomHeight = props.params.bottomHeight;
  519. outParam.axisX = axisX.value;
  520. outParam.axisY = axisY.value;
  521. outParam.axisZ = axisZ.value;
  522. emit('submit', outParam);
  523. axisX.value = axisY.value = axisZ.value = 0;
  524. // dialogVisible.value = false;
  525. }
  526. /**
  527. * 关闭
  528. */
  529. function close() {
  530. dialogVisible.value = false;
  531. }
  532. /**
  533. * 提交删除
  534. */
  535. function remove() {
  536. emit('remove', {});
  537. dialogVisible.value = false;
  538. }
  539. /**
  540. * 材质方向选择事件
  541. * @param {Object} e
  542. */
  543. function directionChange(e) {
  544. if (e.target.value === directions[0].key) {
  545. Object.assign(orders, [{
  546. key: '自左至右',
  547. value: '-'
  548. }, {
  549. key: '自右至左',
  550. value: '+'
  551. }]);
  552. radioOrder.value = orders[0].key;
  553. } else if (e.target.value === directions[1].key) {
  554. Object.assign(orders, [{
  555. key: '自上至下',
  556. value: '-'
  557. }, {
  558. key: '自下至上',
  559. value: '+'
  560. }]);
  561. radioOrder.value = orders[0].key;
  562. }
  563. }
  564. /**
  565. * 窗口关闭,修改双向绑定值
  566. */
  567. function closeDialog() {
  568. emit('update:showDialog', false);
  569. }
  570. /**
  571. * 窗口打开
  572. */
  573. function openDialog() {
  574. updateParams(props.params);
  575. }
  576. </script>
  577. <style lang="scss">
  578. /* 引入element-plus的内部样式 必须在此处引入 否则无效 */
  579. /* 为了保证引入的样式文件起作用 必须保证文件名称以.ce.vue结束 */
  580. @import 'element-plus/theme-chalk/index.css';
  581. //组件内部样式
  582. .el-button{
  583. height: 32rem !important;
  584. padding: 8rem 15rem !important;
  585. font-size: 14rem !important;
  586. }
  587. .el-input__wrapper{
  588. padding: 1rem 11rem !important;
  589. }
  590. .el-input{
  591. height: 32rem !important;
  592. font-size: 14rem !important;
  593. }
  594. .jt-wall-row .col-left{
  595. font-size: 14rem !important;
  596. }
  597. .el-color-picker__trigger{
  598. height: 32rem !important;
  599. padding: 4rem !important;
  600. }
  601. .el-radio-button__inner{
  602. padding: 8rem 15rem !important;
  603. font-size: 14rem;
  604. }
  605. .el-textarea__inner{
  606. padding: 5rem 11rem !important;
  607. font-size: 14rem;
  608. }
  609. .el-input__inner{
  610. height: 32rem !important;
  611. font-size: 14rem !important;
  612. }
  613. /* 墙对话框内容行样式 */
  614. .jt-wall-row {
  615. display: flex;
  616. flex-direction: row;
  617. height: 40rem;
  618. align-items: center;
  619. /* 行左侧标题样式 */
  620. .col-left {
  621. display: flex;
  622. align-items: center;
  623. justify-content: right;
  624. width: 60rem;
  625. font-family: 'Alimama_ShuHeiTi_Bold';
  626. font-weight: bold;
  627. margin-right: 8rem;
  628. }
  629. /* 主要内容样式 */
  630. .col-main {
  631. flex: 1;
  632. display: flex;
  633. flex-direction: row;
  634. .el-input--suffix {
  635. background-color: rgba(255, 255, 255, 0);
  636. }
  637. .el-input--suffix * {
  638. background-color: rgba(255, 255, 255, 0);
  639. color: rgba(255, 255, 255, 1);
  640. }
  641. /* 数字组件按钮背景色 */
  642. .el-input-number__decrease,
  643. .el-input-number__increase {
  644. background-color: rgb(52, 137, 255);
  645. color: rgb(255, 255, 255);
  646. }
  647. }
  648. }
  649. /* 墙对话框整体样式 */
  650. .jt-wall-dialog {
  651. pointer-events: none; // ***覆盖层元素增加可穿透点击事件***
  652. .el-dialog {
  653. pointer-events: auto; // ***弹窗层元素不可穿透点击事件(不影响弹窗层元素的点击事件)***
  654. position: absolute !important; //将通知框的position改成absolute,可以在某个div进行显示
  655. background: rgb(5 45 155 / 70%);
  656. min-width: 280rem;
  657. overflow: hidden;
  658. margin-top: 0rem;
  659. /* 对话框标题头样式 */
  660. .el-dialog__header {
  661. background: url() no-repeat;
  662. background-size: 100%;
  663. margin-right: 0rem;
  664. padding: 6rem;
  665. text-align: center;
  666. }
  667. /* 对话框关闭按钮的样式 */
  668. .el-dialog__headerbtn {
  669. height: 34rem;
  670. }
  671. /* 对话框主体的样式 */
  672. .el-dialog__body {
  673. padding: 10rem;
  674. color: #fff;
  675. }
  676. /* 颜色选择器的宽度 */
  677. .el-color-picker__trigger {
  678. width: 120rem;
  679. }
  680. /* 底部按钮容器样式 */
  681. .el-body-foot {
  682. position: absolute;
  683. bottom: 8rem;
  684. right: 8rem;
  685. width: calc(100% - 16rem);
  686. }
  687. /* 底部容器内分组容器样式 */
  688. .el-body-foot .el-button-group {
  689. display: flex;
  690. }
  691. /* 底部容器内按钮样式 */
  692. .el-body-foot .el-button-group .el-button {
  693. border: solid 0rem rgb(255, 0, 0);
  694. flex: 1;
  695. }
  696. }
  697. }
  698. </style>