Skip to content

Commit

Permalink
wip
Browse files Browse the repository at this point in the history
  • Loading branch information
allanmcarvalho committed Oct 17, 2023
1 parent cf334a8 commit d0f1ea3
Show file tree
Hide file tree
Showing 4 changed files with 104 additions and 3 deletions.
5 changes: 3 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@
"filepond-plugin-file-validate-type": "^1.2.8",
"filepond-plugin-image-preview": "^4.6.11",
"filepond-plugin-image-validate-size": "^1.2.7",
"tailwindcss": "^3.2.1"
"tailwindcss": "^3.2.1",
"vanilla-lazyload": "^17.8.5"
}
}
}
2 changes: 1 addition & 1 deletion resources/js/Components/Form/SelectableInput/Options.vue
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,6 @@ export default defineComponent({

<style scoped lang="scss">
.lvw-select-options {
@apply absolute z-10 mt-1 max-h-60 w-full overflow-auto rounded-md bg-white py-1 text-base shadow ring-1 ring-black ring-opacity-5 focus:outline-none sm:text-sm;
@apply absolute z-30 mt-1 max-h-60 w-full overflow-auto rounded-md bg-white py-1 text-base shadow ring-1 ring-black ring-opacity-5 focus:outline-none sm:text-sm;
}
</style>
99 changes: 99 additions & 0 deletions resources/js/Components/Image.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,99 @@
<template>
<div :style="[{'aspect-ratio': dimensions ? `${dimensionsX}/${dimensionsY}` : null}]">
<img
v-bind="$attrs"
ref="img"
:alt="alt"
class="w-full"
:data-src="src"
:src="loadingSrc ?? ''"/>
</div>
</template>

<script lang="ts">
import {defineComponent, PropType} from "vue";
import LazyLoad, {ILazyLoadInstance} from "vanilla-lazyload";
export default defineComponent({
inheritAttrs: false,
name: "Image",
props: {
alt: String,
dimensions: Array as PropType<[x: number, y: number]>,
errorSrc: String,
loadingSrc: String,
src: {
type: String,
required: true,
},
},
emits: ['enter', 'exit', 'applied', 'loading', 'loaded', 'error', 'finish', 'cancel'],
data() {
return {
lazyLoad: null,
dimensionsX: null,
dimensionsY: null,
}
},
computed: {
options() {
return {
callback_enter: (el: HTMLElement, entry: IntersectionObserverEntry, instance: ILazyLoadInstance) => this.$emit('enter', el, entry, instance),
callback_exit: (el: HTMLElement, entry: IntersectionObserverEntry, instance: ILazyLoadInstance) => this.$emit('exit', el, entry, instance),
callback_applied: (el: HTMLElement, instance: ILazyLoadInstance) => this.$emit('applied', el, instance),
callback_loading: (el: HTMLElement, instance: ILazyLoadInstance) => this.$emit('loading', el, instance),
callback_loaded: this.onLoaded,
callback_error: this.onError,
callback_finish: (instance: ILazyLoadInstance) => this.$emit('finish', instance),
callback_cancel: (el: HTMLElement, entry: IntersectionObserverEntry, instance: ILazyLoadInstance) => this.$emit('cancel', el, entry, instance),
class_applied: 'lvw-ll-applied',
class_entered: 'lvw-ll-entered',
class_error: 'lvw-ll-error',
class_exited: 'lvw-ll-exited',
class_loaded: 'lvw-ll-loaded',
class_loading: 'lvw-ll-loading',
}
}
},
mounted() {
this.create();
},
methods: {
create() {
this.dimensionsX = this.dimensions[0];
this.dimensionsY = this.dimensions[1];
this.lazyLoad = new LazyLoad(this.options, [this.$refs.img]);
},
destroy() {
if (this.lazyLoad) {
this.lazyLoad.destroy();
}
LazyLoad.resetStatus(this.$refs.img);
},
onError(el: HTMLElement, instance: ILazyLoadInstance) {
this.$emit('error', el, instance);
el.setAttribute("src", this.errorSrc);
},
onLoaded(el: HTMLImageElement, instance: ILazyLoadInstance) {
this.$emit('loaded', el, instance);
setTimeout(() => {
this.$nextTick(() => {
this.dimensionsX = el.width;
this.dimensionsY = el.height;
});
}, 300);
},
},
watch: {
src() {
this.destroy();
this.create();
}
}
});
</script>

<style scoped>
</style>
1 change: 1 addition & 0 deletions resources/js/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import plugin from "./plugin";
export {default as Datetime} from "./Components/Datetime.vue";
export {default as FilePondInput} from "./Components/Form/FilePondInput.vue";
export {default as FillableInput} from "./Components/Form/FillableInput.vue";
export {default as Image} from "./Components/Image.vue";
export {default as InputGroup} from "./Components/Form/InputGroup.vue";
export {default as InputHelp} from "./Components/Form/InputFeedback.vue";
export {default as InputLabel} from "./Components/Form/InputLabel.vue";
Expand Down

0 comments on commit d0f1ea3

Please sign in to comment.