Skip to content

Commit

Permalink
feat: add responsive component
Browse files Browse the repository at this point in the history
  • Loading branch information
pataar committed Mar 6, 2022
1 parent 0da0504 commit e5b4f28
Show file tree
Hide file tree
Showing 5 changed files with 153 additions and 0 deletions.
53 changes: 53 additions & 0 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

3 changes: 3 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -40,9 +40,11 @@
"echarts": "^5.2.2",
"echarts-gl": "^2.0.8",
"js-sha256": "^0.9.0",
"lodash.throttle": "^4.1.1",
"overlayscrollbars": "^1.13.1",
"overlayscrollbars-vue": "^0.2.2",
"regenerator-runtime": "^0.13.9",
"resize-observer-polyfill": "^1.5.1",
"semver": "^7.3.5",
"uuid": "^8.3.2",
"vue": "^2.6.14",
Expand All @@ -61,6 +63,7 @@
"devDependencies": {
"@intlify/vite-plugin-vue-i18n": "^2.5.0",
"@mdi/js": "^6.5.95",
"@types/lodash.throttle": "^4.1.6",
"@types/semver": "^7.3.8",
"@types/uuid": "^8.3.1",
"@typescript-eslint/eslint-plugin": "^5.11.0",
Expand Down
60 changes: 60 additions & 0 deletions src/components/mixins/responsive.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,60 @@
import Component from 'vue-class-component'
import BaseMixin from './base'
import { Prop } from 'vue-property-decorator'
import throttle from 'lodash.throttle'

export type ResponsiveElement = {
width: number
height: number
is: {
[key: string]: boolean
}
}

@Component
export default class ResponsiveMixin extends BaseMixin {
@Prop() protected declare breakpoints: {
[key: string]: (el: ResponsiveElement) => boolean
}

observer?: ResizeObserver

el: ResponsiveElement = {
width: 0,
height: 0,
is: {},
}

mounted() {
if (this.breakpoints) {
this.$nextTick(() => {
this.observer = new ResizeObserver(throttle(this.onResize, 50))
if (this.$el instanceof Element) {
this.observer.observe(this.$el)
}
})
}
}

beforeDestroy() {
if (this.$el instanceof Element) {
this.observer?.unobserve(this.$el)
}
}

private onResize(entries: ResizeObserverEntry[]) {
const cr = entries[0].contentRect
const conds = this.breakpoints
for (const breakpoint in conds) {
this.$set(
this.el.is,
breakpoint,
conds[breakpoint]({
...this.el,
width: cr.width,
height: cr.height,
})
)
}
}
}
11 changes: 11 additions & 0 deletions src/components/panels/GcodefilesPanel.vue
Original file line number Diff line number Diff line change
Expand Up @@ -436,6 +436,15 @@
</v-list-item>
</v-list>
</v-menu>

<responsive
:breakpoints="{
small: (el) => el.width <= 200,
}">
<template #default="{ el }">
<div :class="{ small: el.is.small }">Small thing</div>
</template>
</responsive>
<v-dialog v-model="dialogCreateDirectory.show" :max-width="400">
<panel
:title="$t('Files.NewDirectory')"
Expand Down Expand Up @@ -561,6 +570,7 @@ import {
mdiPencil,
mdiDelete,
mdiCloseThick,
mdiClose,
} from '@mdi/js'
interface draggingFile {
Expand Down Expand Up @@ -609,6 +619,7 @@ export default class GcodefilesPanel extends Mixins(BaseMixin) {
mdiPlay = mdiPlay
mdiPlaylistPlus = mdiPlaylistPlus
mdiFire = mdiFire
mdiClose = mdiClose
mdiVideo3d = mdiVideo3d
mdiCloudDownload = mdiCloudDownload
mdiRenameBox = mdiRenameBox
Expand Down
26 changes: 26 additions & 0 deletions src/components/ui/Responsive.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
<template>
<div>
<div v-if="!noHide && !init" style="visibility: hidden">
<slot :el="el"></slot>
</div>

<slot :el="el"></slot>
</div>
</template>

<script lang="ts">
import Component from 'vue-class-component'
import { Mixins, Prop } from 'vue-property-decorator'
import ResponsiveMixin from '@/components/mixins/responsive'
@Component
export default class Responsive extends Mixins(ResponsiveMixin) {
@Prop({ default: false }) protected declare noHide: boolean
init = false
mounted() {
this.init = true
}
}
</script>

0 comments on commit e5b4f28

Please sign in to comment.