panel.vue 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. <template>
  2. <div class="com-panel" :class="{ 'no-title': !hasTitle, line: showLine }">
  3. <div v-if="hasTitle" class="panel-header">
  4. <div class="panel-title">
  5. <i v-if="hasIcon" class="panel-icon" :class="icon"></i>
  6. {{ title }}
  7. </div>
  8. <div class="panel-tools">{{ subTitle }}</div>
  9. </div>
  10. <div class="panel-body">
  11. <slot></slot>
  12. </div>
  13. </div>
  14. </template>
  15. <script>
  16. export default {
  17. name: "com-panel",
  18. componentName: "com-panel",
  19. props: {
  20. // 标题
  21. title: String,
  22. // 图标
  23. icon: String,
  24. // 副标题
  25. subTitle: String,
  26. showLine: {
  27. type: Boolean,
  28. default: true,
  29. },
  30. },
  31. computed: {
  32. // 是否存在标题
  33. // 标题为空时 不显示标题框
  34. hasTitle() {
  35. if (this.title) return true;
  36. return false;
  37. },
  38. // 是否存在图标
  39. hasIcon() {
  40. if (this.icon) return true;
  41. return false;
  42. },
  43. },
  44. };
  45. </script>
  46. <style lang="less">
  47. .com-panel {
  48. &.line {
  49. border-left: 0.185vh solid rgba(255, 255, 255, 50%);
  50. }
  51. &.line:before {
  52. content: " ";
  53. width: 0.37vh;
  54. height: 0.37vh;
  55. float: left;
  56. background: #fff;
  57. margin: 0.185vh 0.556vh 0vh 0.185vh;
  58. }
  59. &.no-title {
  60. border-left: 0vh;
  61. }
  62. &.no-title::before {
  63. display: none;
  64. }
  65. .panel-header {
  66. display: flex;
  67. font-size: 12px;
  68. padding-left: 1.185vh;
  69. background: rgba(255, 255, 255, 10%);
  70. line-height: 27px;
  71. margin-bottom: 0.7407vh;
  72. .panel-title {
  73. color: fade(#fff, 75);
  74. flex: 1 1 auto;
  75. .panel-icon {
  76. margin-right: 0.741vh;
  77. }
  78. }
  79. .panel-tools {
  80. flex: 0 0 auto;
  81. color: #ffffff4d;
  82. padding: 0 0.741vh;
  83. font-size: 12px;
  84. letter-spacing: 0.093vh;
  85. }
  86. }
  87. &.line .panel-body {
  88. padding-left: 1.185vh;
  89. }
  90. &.no-title .panel-body {
  91. padding-left: 0vh;
  92. }
  93. }
  94. </style>