indexCopy.vue 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <template>
  2. <div class="container normal-panel ">
  3. <div class="tab flex-align-center">
  4. <p :class="activeName === '组织架构'?'tab-act':''" @click="tabChange('组织架构')">组织架构</p>
  5. <p :class="activeName === '营销组织'?'tab-act':''" @click="tabChange('营销组织')">营销组织</p>
  6. </div>
  7. <div style="padding:16px 0;">
  8. <dep ref="dep" :disabled="disabled" v-show="activeName === '组织架构'" :defaultData="defaultData" :scrollHeight="scrollHeight" :obiectName="obiectName" :obiectId="obiectId" @onParams="onParams"></dep>
  9. <mar ref="mar" v-show="activeName === '营销组织'" :defaultData="defaultData" :scrollHeight="scrollHeight" :obiectName="obiectName" :obiectId="obiectId" @onAgentParams="onAgentParams"></mar>
  10. </div>
  11. </div>
  12. </template>
  13. <script>
  14. import dep from './modules/dep_auth.vue'
  15. import mar from './modules/mar_auth.vue'
  16. export default {
  17. props:['defaultData','scrollHeight','appidname','dataid','obiectName','obiectId','disabled'],
  18. components:{
  19. dep,
  20. mar
  21. },
  22. data () {
  23. return {
  24. activeName:'组织架构',
  25. param:{
  26. "isonlymanager_dept":false,
  27. "isonlymanager_agent":false,
  28. "departmentid":[],
  29. "hrid":[],
  30. "sa_saleareaid":[],
  31. "sa_agentsid":[]
  32. }
  33. }
  34. },
  35. methods:{
  36. onParams (dep,men,isonlymanager) {
  37. console.log(dep,men,isonlymanager)
  38. this.param.isonlymanager_dept = isonlymanager
  39. this.param.hrid = men
  40. this.param.departmentid = dep
  41. this.param[this.appidname] = this.dataid
  42. this.$emit('onChecked',this.param)
  43. },
  44. onAgentParams (area,agent,isonlymanager) {
  45. console.log(area,agent,isonlymanager)
  46. this.param.isonlymanager_agent = isonlymanager
  47. this.param.sa_agentsid = agent
  48. this.param.sa_saleareaid = area
  49. this.$emit('onChecked',this.param)
  50. },
  51. tabChange (val) {
  52. this.activeName = val
  53. this.$emit('tabChange')
  54. },
  55. },
  56. watch:{
  57. defaultData (val) {
  58. this.param = Object.assign({},this.param,val)
  59. this.$emit('onChecked',this.param)
  60. }
  61. }
  62. }
  63. </script>
  64. <style>
  65. .panel .el-checkbox__input.is-checked+.el-checkbox__label{
  66. color:#777 !important;
  67. }
  68. </style>
  69. <style scoped>
  70. .panel{
  71. border:1px solid #CCCCCC;
  72. border-radius: 4px;
  73. }
  74. .tab p{
  75. flex:1;
  76. height: 39px;
  77. line-height: 39px;
  78. text-align: center;
  79. font-weight: 500;
  80. font-size: 14px;
  81. color:#999;
  82. border-bottom: 2px solid #eeeeee;
  83. cursor:pointer;
  84. }
  85. .tab-act{
  86. color:#3874F6 !important;
  87. border-bottom: 2px solid #3874F6 !important;
  88. }
  89. </style>