| ¶Ô±ÈÐÂÎļþ |
| | |
| | | <template> |
| | | <TableLayout> |
| | | <template v-slot:table-wrap> |
| | | <el-tabs v-model="activeName"> |
| | | <el-tab-pane label="室å
ç¨è½¦" name="first"></el-tab-pane> |
| | | <el-tab-pane label="室å¤ç¨è½¦" name="second"></el-tab-pane> |
| | | </el-tabs> |
| | | <div class="config"> |
| | | <div class="config_list"> |
| | | <div class="config_list_head"> |
| | | <span>æµç¨é
ç½®</span> |
| | | <el-button type="primary">åå¸</el-button> |
| | | </div> |
| | | <div class="config_content"> |
| | | <div class="item active"> |
| | | <div class="head">å起人</div> |
| | | <div class="content">å
é¨åå·¥</div> |
| | | </div> |
| | | <div class="arrows"> |
| | | <div class="line"></div> |
| | | <img src="@/assets/images/peizhi_ar@2x.png" alt="" /> |
| | | </div> |
| | | <div |
| | | class="item yellow" |
| | | :class="{ active: activeSel === 'one' }" |
| | | @click="flowClick('one')" |
| | | > |
| | | <div class="head">审æ¹äºº</div> |
| | | <div class="content"> |
| | | <div>ææ-综åç§</div> |
| | | <i class="el-icon-arrow-right"></i> |
| | | </div> |
| | | </div> |
| | | <div class="arrows"> |
| | | <div class="line"></div> |
| | | <img src="@/assets/images/peizhi_ar@2x.png" alt="" /> |
| | | </div> |
| | | <div |
| | | class="item yellow" |
| | | :class="{ active: activeSel === 'one' }" |
| | | @click="flowClick('one')" |
| | | > |
| | | <div class="head">审æ¹äºº</div> |
| | | <div class="content"> |
| | | <div>æç³-综åç§</div> |
| | | <i class="el-icon-arrow-right"></i> |
| | | </div> |
| | | </div> |
| | | <div class="arrows"> |
| | | <div class="line"></div> |
| | | <img src="@/assets/images/peizhi_ar@2x.png" alt="" /> |
| | | </div> |
| | | <div |
| | | class="item blue" |
| | | :class="{ active: activeSel === 'two' }" |
| | | @click="flowClick('two')" |
| | | > |
| | | <div class="head">æé人</div> |
| | | <div class="content"> |
| | | <div>ææ´¾é©¾é©¶å</div> |
| | | <i class="el-icon-arrow-right"></i> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="config_data"> |
| | | <div class="config_data_item"> |
| | | <div class="config_data_item_label">éæ©è¯¥èç¹ç审æ¹äºº</div> |
| | | <el-radio-group v-model="radio"> |
| | | <el-radio :label="1">æå®äººå</el-radio> |
| | | <el-radio :label="2">é¨é¨ä¸»ç®¡</el-radio> |
| | | </el-radio-group> |
| | | <div class="config_data_item_reviewed" v-if="radio === 1"> |
| | | <div class="config_data_item_reviewed_label"> |
| | | <span>æå®å®¡æ ¸äºº</span> |
| | | <span>ä¸è¶
è¿20人</span> |
| | | </div> |
| | | <div class="config_data_item_reviewed_content"> |
| | | <div class="config_data_item_reviewed_content_item"> |
| | | <span>æ åå¥</span> |
| | | <i class="el-icon-close"></i> |
| | | </div> |
| | | <span class="add" @click="selStaff">+æ·»å </span> |
| | | </div> |
| | | </div> |
| | | <div class="config_data_item_reviewed" v-if="radio === 2"> |
| | | <div class="config_data_item_reviewed_label"> |
| | | <span>é¨é¨ä¸»ç®¡</span> |
| | | </div> |
| | | <div class="config_data_item_reviewed_r"> |
| | | <span>被访人ç</span> |
| | | <el-select |
| | | v-model="value" |
| | | placeholder="è¯·éæ©" |
| | | style="margin: 0 20px 0 10px" |
| | | > |
| | | <el-option |
| | | v-for="item in options" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | > |
| | | </el-option> |
| | | </el-select> |
| | | <el-checkbox v-model="checked" |
| | | >æ¾ä¸å°ä¸»ç®¡æ¶ï¼ç±ä¸çº§ä¸»ç®¡ä»£å®¡æ ¸</el-checkbox |
| | | > |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="config_data_item" v-if="radio !== 0"> |
| | | <div class="config_data_item_label"> |
| | | å®¡æ¹æ¹å¼ |
| | | <span>审æ¹äººä¸ºå¤ä¸ªæ¶ï¼éç¨çå®¡æ¹æ¹å¼</span> |
| | | </div> |
| | | <el-radio-group |
| | | v-model="radio1" |
| | | style="display: flex; flex-direction: column" |
| | | > |
| | | <el-radio :label="0" style="margin-bottom: 20px" |
| | | >æç¾ï¼å
¶ä¸ä¸å审æ¹äººåæææç»å³å¯ï¼</el-radio |
| | | > |
| | | <el-radio :label="1">ä¼ç¾ï¼ææå®¡æ¹äººé½åææå¯éè¿ï¼</el-radio> |
| | | </el-radio-group> |
| | | </div> |
| | | <div class="df_ac"> |
| | | <span class="mr10"><strong>å
许修æ¹ç³è¯·é¡¹</strong></span> |
| | | <el-switch v-model="param.aa" active-value="1" inactive-value="0"> |
| | | </el-switch> |
| | | </div> |
| | | <div class="df_ac mt10"> |
| | | <span class="mr20">éæ©ä¿®æ¹é¡¹</span> |
| | | <el-select |
| | | v-model="param.list" |
| | | collapse-tags |
| | | multiple |
| | | placeholder="è¯·éæ©,å¤é" |
| | | > |
| | | <el-option |
| | | v-for="item in options" |
| | | :key="item.value" |
| | | :label="item.label" |
| | | :value="item.value" |
| | | > |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | <div class="config_data_submit" v-if="radio !== 0"> |
| | | <el-button style="background: #435ebe" type="primary" |
| | | >ä¿åé
置项</el-button |
| | | > |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </template> |
| | | <!-- --> |
| | | <el-dialog title="éæ©åå·¥" :visible.sync="isShowTransfer" width="800px"> |
| | | <tree-transfer |
| | | v-model="param.menuIds" |
| | | :title="['æªé', 'å·²é']" |
| | | :from_data="fromData" |
| | | :to_data="selData" |
| | | :defaultProps="{ label: 'label' }" |
| | | mode="transfer" |
| | | height="500px" |
| | | filter |
| | | openAll |
| | | ref="treeTransfer" |
| | | > |
| | | </tree-transfer> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="isShowTransfer = false">å æ¶</el-button> |
| | | <el-button type="primary" @click="isShowTransfer = false" |
| | | >ç¡® å®</el-button |
| | | > |
| | | </span> |
| | | </el-dialog> |
| | | </TableLayout> |
| | | </template> |
| | | |
| | | <script> |
| | | import TableLayout from '@/layouts/TableLayout' |
| | | import treeTransfer from 'el-tree-transfer' |
| | | export default { |
| | | name: 'config', |
| | | components: { |
| | | TableLayout, |
| | | treeTransfer |
| | | }, |
| | | data() { |
| | | return { |
| | | |
| | | value: '', |
| | | radio: 0, |
| | | radio1: 0, |
| | | checked: '', |
| | | checkList: [], |
| | | |
| | | param: {}, |
| | | activeSel: 'one', |
| | | activeName: 'first', |
| | | isShowTransfer: false, |
| | | fromData: [ |
| | | { |
| | | id: '1', |
| | | pid: 0, |
| | | label: 'ä¸çº§ 1', |
| | | children: [ |
| | | { |
| | | id: '1-1', |
| | | pid: '1', |
| | | label: 'äºçº§ 1-1', |
| | | disabled: true, |
| | | children: [] |
| | | }, |
| | | { |
| | | id: '1-2', |
| | | pid: '1', |
| | | label: 'äºçº§ 1-2', |
| | | children: [ |
| | | { |
| | | id: '1-2-1', |
| | | pid: '1-2', |
| | | children: [], |
| | | label: 'äºçº§ 1-2-1' |
| | | }, |
| | | { |
| | | id: '1-2-2', |
| | | pid: '1-2', |
| | | children: [], |
| | | label: 'äºçº§ 1-2-2' |
| | | } |
| | | ] |
| | | } |
| | | ] |
| | | } |
| | | ], |
| | | options: [{ |
| | | value: 'é项1', |
| | | label: 'é»éç³' |
| | | }, { |
| | | value: 'é项2', |
| | | label: 'åç®å¥¶' |
| | | }, { |
| | | value: 'é项3', |
| | | label: 'èµä»ç
' |
| | | }, { |
| | | value: 'é项4', |
| | | label: 'é¾é¡»é¢' |
| | | }, { |
| | | value: 'é项5', |
| | | label: 'å京ç¤é¸' |
| | | }], |
| | | selData: [] |
| | | } |
| | | }, |
| | | methods: { |
| | | flowClick(val) { |
| | | this.activeSel = val |
| | | }, |
| | | |
| | | selStaff() { |
| | | this.isShowTransfer = true |
| | | }, |
| | | seleItem(i) { |
| | | this.list.forEach((item, index) => { |
| | | item.active = index === i |
| | | }) |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | |
| | | <style lang="scss" scoped> |
| | | .config { |
| | | width: 100%; |
| | | padding-bottom: 20px; |
| | | box-sizing: border-box; |
| | | height: calc(100vh - 140px); |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | .config_list { |
| | | width: 543px; |
| | | height: 100%; |
| | | flex-shrink: 0; |
| | | border-radius: 2px; |
| | | padding: 20px; |
| | | box-sizing: border-box; |
| | | border: 1px solid #eeeeee; |
| | | background: #f7f7f7; |
| | | .config_list_head { |
| | | width: 100%; |
| | | height: 40px; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | span { |
| | | font-size: 18px; |
| | | font-weight: 500; |
| | | color: #222222; |
| | | } |
| | | } |
| | | .config_content { |
| | | width: 100%; |
| | | height: calc(100% - 40px); |
| | | padding-top: 45px; |
| | | box-sizing: border-box; |
| | | overflow-y: scroll; |
| | | display: flex; |
| | | align-items: center; |
| | | flex-direction: column; |
| | | &::-webkit-scrollbar { |
| | | width: 0; |
| | | } |
| | | .active { |
| | | border: 2px solid #4456ac !important; |
| | | } |
| | | .yellow { |
| | | background: #e89e42 !important; |
| | | } |
| | | .blue { |
| | | background: #5094f3 !important; |
| | | } |
| | | .arrows { |
| | | display: flex; |
| | | flex-direction: column; |
| | | align-items: center; |
| | | .line { |
| | | width: 1px; |
| | | height: 60px; |
| | | background-color: #ccc; |
| | | } |
| | | img { |
| | | width: 12px; |
| | | } |
| | | } |
| | | .item { |
| | | width: 200px; |
| | | cursor: pointer; |
| | | border: 2px solid #f7f7f7; |
| | | height: 80px; |
| | | background: #4456ac; |
| | | border-radius: 2px; |
| | | position: relative; |
| | | display: flex; |
| | | flex-direction: column; |
| | | .head { |
| | | height: 32px; |
| | | line-height: 32px; |
| | | padding: 2px 12px; |
| | | color: #fff; |
| | | } |
| | | .content { |
| | | flex: 1; |
| | | background-color: #fff; |
| | | display: flex; |
| | | align-items: center; |
| | | padding: 0 12px; |
| | | justify-content: space-between; |
| | | } |
| | | &:last-child { |
| | | margin: 0 !important; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | .config_data { |
| | | flex: 1; |
| | | height: 100%; |
| | | margin-left: 20px; |
| | | .config_data_submit { |
| | | margin-top: 50px; |
| | | } |
| | | .config_data_item { |
| | | width: 100%; |
| | | display: flex; |
| | | flex-direction: column; |
| | | margin-bottom: 30px; |
| | | &:last-child { |
| | | margin: 0 !important; |
| | | } |
| | | .config_data_item_label { |
| | | font-size: 16px; |
| | | font-weight: 500; |
| | | color: #222222; |
| | | margin-bottom: 20px; |
| | | span { |
| | | font-size: 12px; |
| | | font-weight: 400; |
| | | color: #999999; |
| | | margin-left: 10px; |
| | | } |
| | | } |
| | | .config_data_item_reviewed { |
| | | width: 100%; |
| | | margin-top: 20px; |
| | | .config_data_item_reviewed_r { |
| | | margin-top: 10px; |
| | | width: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | span { |
| | | flex-shrink: 0; |
| | | font-size: 14px; |
| | | font-weight: 400; |
| | | color: #666666; |
| | | } |
| | | } |
| | | .config_data_item_reviewed_label { |
| | | display: flex; |
| | | align-items: center; |
| | | span { |
| | | &:nth-child(1) { |
| | | font-size: 14px; |
| | | font-weight: 400; |
| | | color: #222222; |
| | | } |
| | | &:nth-child(2) { |
| | | font-size: 12px; |
| | | font-weight: 400; |
| | | color: #999999; |
| | | margin-left: 8px; |
| | | } |
| | | } |
| | | } |
| | | .config_data_item_reviewed_content { |
| | | width: 400px; |
| | | margin-top: 10px; |
| | | height: 110px; |
| | | padding: 12px; |
| | | box-sizing: border-box; |
| | | border-radius: 2px; |
| | | border: 1px solid #dfe2e8; |
| | | display: flex; |
| | | align-items: flex-start; |
| | | flex-wrap: wrap; |
| | | .add { |
| | | font-size: 12px; |
| | | font-weight: 400; |
| | | color: #435ebe; |
| | | cursor: pointer; |
| | | margin-top: 3px; |
| | | } |
| | | .config_data_item_reviewed_content_item { |
| | | padding: 3px 5px; |
| | | background: #f4f7fc; |
| | | border-radius: 2px; |
| | | box-sizing: border-box; |
| | | margin-right: 10px; |
| | | margin-bottom: 10px; |
| | | span { |
| | | font-size: 12px; |
| | | font-weight: 400; |
| | | color: #333333; |
| | | } |
| | | i { |
| | | color: #949ba2; |
| | | margin-left: 10px; |
| | | cursor: pointer; |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | </style> |