mirror of
https://github.com/apache/skywalking-booster-ui.git
synced 2025-10-14 20:01:28 +00:00
feat: update layout
This commit is contained in:
@@ -20,73 +20,27 @@ limitations under the License. -->
|
||||
</div>
|
||||
<div class="flex-h ds-main">
|
||||
<div class="ds-layout">
|
||||
<VueDragResize
|
||||
:isActive="item.static"
|
||||
:w="item.w"
|
||||
:h="item.h"
|
||||
:x="item.x"
|
||||
:y="item.y"
|
||||
@resizing="resize"
|
||||
@dragging="resize"
|
||||
v-for="item in layout"
|
||||
:key="item.i"
|
||||
>
|
||||
<h3>Hello World {{ item.i }}</h3>
|
||||
</VueDragResize>
|
||||
<GridLayout />
|
||||
</div>
|
||||
<div class="ds-config">Configurations</div>
|
||||
</div>
|
||||
</template>
|
||||
<script lang="ts">
|
||||
<script lang="ts" setup>
|
||||
import { toRefs, defineComponent, reactive, ref } from "vue";
|
||||
import { ElButton } from "element-plus";
|
||||
import VueDragResize from "vue-drag-resize";
|
||||
|
||||
export interface GridItemData {
|
||||
x: number;
|
||||
y: number;
|
||||
w: number;
|
||||
h: number;
|
||||
i: number;
|
||||
static: boolean;
|
||||
}
|
||||
|
||||
export default defineComponent({
|
||||
name: "dashboardEdit",
|
||||
components: {
|
||||
ElButton,
|
||||
VueDragResize,
|
||||
},
|
||||
setup() {
|
||||
const layout = ref<GridItemData[]>([
|
||||
{ x: 300, y: 100, w: 200, h: 200, i: 0, static: true },
|
||||
{ x: 500, y: 100, w: 200, h: 200, i: 1, static: true },
|
||||
{ x: 700, y: 100, w: 200, h: 200, i: 2, static: true },
|
||||
{ x: 900, y: 100, w: 200, h: 200, i: 3, static: true },
|
||||
]);
|
||||
|
||||
function resize(newRect: {
|
||||
width: number;
|
||||
height: number;
|
||||
top: number;
|
||||
left: number;
|
||||
}) {
|
||||
console.log(newRect);
|
||||
}
|
||||
return { resize, layout };
|
||||
},
|
||||
});
|
||||
import GridLayout from "./widget/GridLayout.vue";
|
||||
</script>
|
||||
<style lang="scss" scoped>
|
||||
.dashboard-tool {
|
||||
text-align: right;
|
||||
padding: 5px 10px;
|
||||
background: rgb(240, 242, 245);
|
||||
// border-bottom: 1px solid rgb(240, 242, 245);
|
||||
border-bottom: 1px solid #ccc;
|
||||
}
|
||||
|
||||
.ds-main {
|
||||
background: rgb(240, 242, 245);
|
||||
background: #f7f9fa;
|
||||
// background: #eee;
|
||||
}
|
||||
|
||||
.ds-layout {
|
||||
@@ -113,63 +67,4 @@ export default defineComponent({
|
||||
margin: 5px;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.vue-grid-layout {
|
||||
background: #eee;
|
||||
}
|
||||
|
||||
.vue-grid-item:not(.vue-grid-placeholder) {
|
||||
background: #ccc;
|
||||
border: 1px solid black;
|
||||
}
|
||||
|
||||
.vue-grid-item .resizing {
|
||||
opacity: 0.9;
|
||||
}
|
||||
|
||||
.vue-grid-item .static {
|
||||
background: #cce;
|
||||
}
|
||||
|
||||
.vue-grid-item .text {
|
||||
font-size: 24px;
|
||||
text-align: center;
|
||||
position: absolute;
|
||||
top: 0;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
margin: auto;
|
||||
height: 100%;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.vue-grid-item .no-drag {
|
||||
height: 100%;
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.vue-grid-item .minMax {
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
.vue-grid-item .add {
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.vue-draggable-handle {
|
||||
position: absolute;
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
top: 0;
|
||||
left: 0;
|
||||
background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='10'><circle cx='5' cy='5' r='5' fill='#999999'/></svg>")
|
||||
no-repeat;
|
||||
background-position: bottom right;
|
||||
padding: 0 8px 8px 0;
|
||||
background-repeat: no-repeat;
|
||||
background-origin: content-box;
|
||||
box-sizing: border-box;
|
||||
cursor: pointer;
|
||||
}
|
||||
</style>
|
||||
|
Reference in New Issue
Block a user