InfoCard.vue 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <template>
  2. <el-card class="box-card-component">
  3. <div style="position:relative;">
  4. <mallki class-name="mallki-text" text="用户基本信息"/>
  5. <el-form style="padding-top:35px;margin-top: 10px"
  6. status-icon ref="ruleForm" label-width="120px" class="demo-ruleForm">
  7. <el-form-item label="用户头像:">
  8. <el-avatar :size="70" :src="info.photoUrl"></el-avatar>
  9. </el-form-item>
  10. <el-form-item label="用户姓名:">
  11. {{info.name}}
  12. </el-form-item>
  13. <el-form-item label="所在城市:">
  14. {{info.province}} {{info.city}}
  15. </el-form-item>
  16. <el-form-item label="所在单位:">
  17. {{info.unit}}
  18. </el-form-item>
  19. <el-form-item label="注册时间:">
  20. {{info.createTime}}
  21. </el-form-item>
  22. </el-form>
  23. </div>
  24. </el-card>
  25. </template>
  26. <script>
  27. import { mapGetters } from 'vuex'
  28. import Mallki from '@/components/TextHoverEffect/Mallki'
  29. export default {
  30. components: { Mallki },
  31. props:['info'],
  32. filters: {
  33. statusFilter (status) {
  34. const statusMap = {
  35. success: 'success',
  36. pending: 'danger'
  37. }
  38. return statusMap[status]
  39. }
  40. },
  41. data() {
  42. return {
  43. statisticsData: {
  44. article_count: 1024,
  45. pageviews_count: 1024
  46. }
  47. }
  48. },
  49. computed: {
  50. ...mapGetters([
  51. 'name',
  52. 'avatar',
  53. 'roles'
  54. ])
  55. }
  56. }
  57. </script>
  58. <style lang="scss" >
  59. .box-card-component{
  60. .el-card__header {
  61. padding: 0px!important;
  62. }
  63. }
  64. </style>
  65. <style lang="scss" scoped>
  66. .box-card-component {
  67. .box-card-header {
  68. position: relative;
  69. height: 220px;
  70. img {
  71. width: 100%;
  72. height: 100%;
  73. transition: all 0.2s linear;
  74. &:hover {
  75. transform: scale(1.1, 1.1);
  76. filter: contrast(130%);
  77. }
  78. }
  79. }
  80. .mallki-text {
  81. position: absolute;
  82. top: 0px;
  83. left: 0px;
  84. font-size: 20px;
  85. font-weight: bold;
  86. }
  87. .panThumb {
  88. z-index: 100;
  89. height: 70px!important;
  90. width: 70px!important;
  91. position: absolute!important;
  92. top: -45px;
  93. left: 0px;
  94. border: 5px solid #ffffff;
  95. background-color: #fff;
  96. margin: auto;
  97. box-shadow: none!important;
  98. ::v-deep .pan-info {
  99. box-shadow: none!important;
  100. }
  101. }
  102. .progress-item {
  103. margin-bottom: 10px;
  104. font-size: 14px;
  105. }
  106. @media only screen and (max-width: 1510px){
  107. .mallki-text{
  108. display: none;
  109. }
  110. }
  111. }
  112. </style>