Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 | 7x 7x 7x 7x 7x 7x 7x 7x 7x 7x 7x 7x | <template> <div :class="$style.root" :appear="appear" :fill="fill"> <slot></slot> </div> </template> <script> import { MParent } from '../m-parent.vue'; export default { name: 'u-collapse', childName: 'u-collapse-item', mixins: [MParent], props: { accordion: { type: Boolean, default: false }, expandTrigger: { type: String, default: 'click' }, appear: String, disabled: { type: Boolean, default: false }, fill: { type: String, default: 'head' }, showExtraEmptySlot: { type: Boolean, default: false }, }, data() { return { // @inherit: itemVMs: [], }; }, methods: { onItemExpand(itemVM) { this.$emit('expand', { itemVM }, this); }, onItemCollapse(itemVM) { this.$emit('collapse', { itemVM }, this); }, expand(itemVM) { itemVM.expand(); }, collapse(itemVM) { itemVM.collapse(); }, expandAll() { this.itemVMs.forEach((itemVM) => itemVM.expand()); }, collapseAll() { this.itemVMs.forEach((itemVM) => itemVM.collapse()); }, }, }; </script> <style module> .root { border: var(--collapse-border-width) solid var(--collapse-border-color); border-radius: var(--collapse-border-radius); } .root[appear="simple"] { border: none; border-top: var(--collapse-border-width) solid var(--collapse-border-color); border-bottom: var(--collapse-border-width) solid var(--collapse-border-color); } .root[fill="head"] .item_head, .root[fill="content"] .item_content { background: var(--collapse-item-fill-background); } .root[appear="simple"] .item_head { background: transparent; /* border-top: var(--collapse-border-width) solid var(--collapse-border-color); */ } .root[appear="simple"] .item_body { border-top: none; } .root[size="small"] .item_head { padding: var(--collapse-item-head-padding-small); } .root[size="small"] .item_expander { width: var(--collapse-item-expander-size-small); height: var(--collapse-item-expander-size-small); line-height: var(--collapse-item-expander-size-small); } .root[size="mini"] .item_head { padding: var(--collapse-item-head-padding-mini); } .root[size="mini"] .item_expander { width: var(--collapse-item-expander-size-mini); height: var(--collapse-item-expander-size-mini); line-height: var(--collapse-item-expander-size-mini); } .root[size="mini"] .item_content { padding: var(--collapse-item-content-padding-mini); } .root[display="full"] { width: 100%; height: 100%; overflow: auto; } .root[display="filled"] { width: 100%; height: 100%; display: flex; flex-direction: column; } .root[display="filled"] .item { flex: none; display: flex; flex-direction: column; overflow: hidden; } .root[display="filled"] .item[expanded] { flex: auto; } .root[display="filled"] .item_head { flex: none; } .root[display="filled"] .item_body { flex: auto; overflow: auto; } </style> |