@skeletonizer/vue 1.1.0 → 1.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE CHANGED
@@ -1,6 +1,6 @@
1
1
  MIT License
2
2
 
3
- Copyright (c) 2023 Luka Varga
3
+ Copyright (c) 2024 Luka Varga
4
4
 
5
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
6
6
  of this software and associated documentation files (the "Software"), to deal
package/dist/index.css ADDED
@@ -0,0 +1 @@
1
+ [data-skeletonizer=wrapper-element]{--skeletonizer-text-background: rgba(0, 0, 0, .2);display:contents;filter:grayscale(100%);pointer-events:none}[data-skeletonizer=wrapper-element] *{pointer-events:none}[data-skeletonizer=wrapper-element] [data-skeletonizer=text]{animation:text-animation 2s infinite ease-in-out;background:var(--skeletonizer-primary-color);border-radius:50px;color:#0000!important}@keyframes text-animation{0%{background:var(--skeletonizer-primary-color)}50%{background:var(--skeletonizer-secondary-color)}to{background:var(--skeletonizer-primary-color)}}
@@ -0,0 +1,53 @@
1
+ import { defineComponent as m, reactive as l, watch as S, resolveDirective as u, openBlock as r, createElementBlock as s, Fragment as d, renderList as v, withDirectives as f, renderSlot as i } from "vue";
2
+ import { SkeletonAdapterComponent as h, SkeletonAbstractComponent as w, SkeletonDirective as z } from "@skeletonizer/utils";
3
+ const g = /* @__PURE__ */ m({
4
+ __name: "SkeletonizerSkeleton",
5
+ props: {
6
+ config: {},
7
+ showSkeleton: { type: Boolean },
8
+ scope: {},
9
+ colorSchema: {}
10
+ },
11
+ setup(n) {
12
+ const e = n, t = l(new h());
13
+ return S(
14
+ e.config,
15
+ (o) => {
16
+ t.config = o, t.setupModels();
17
+ },
18
+ { immediate: !0 }
19
+ ), (o, y) => {
20
+ const a = u("skeletonize");
21
+ return o.showSkeleton ? (r(!0), s(d, { key: 0 }, v(t.viewModels, (k, p) => f((r(), s("div", { key: p }, [
22
+ i(o.$slots, "default", {
23
+ scope: k.value
24
+ })
25
+ ])), [
26
+ [a, e.colorSchema]
27
+ ])), 128)) : i(o.$slots, "default", {
28
+ key: 1,
29
+ scope: e.scope
30
+ });
31
+ };
32
+ }
33
+ });
34
+ class c extends w {
35
+ constructor(e, t) {
36
+ super(), this.skeletonConfig = e, this.showSkeleton = t;
37
+ }
38
+ static generate(e, t) {
39
+ return l(new c(e, t));
40
+ }
41
+ }
42
+ const B = {
43
+ install: (n) => {
44
+ n.component("SkeletonizerSkeleton", g), n.directive("skeletonize", (e, t) => {
45
+ z.skeletonizeProjectedTemplate(e, t.value);
46
+ });
47
+ }
48
+ };
49
+ export {
50
+ c as SkeletonizerComponentComposable,
51
+ B as SkeletonizerPlugin,
52
+ g as SkeletonizerSkeleton
53
+ };
@@ -0,0 +1,2 @@
1
+ (function(t,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue"),require("@skeletonizer/utils")):typeof define=="function"&&define.amd?define(["exports","vue","@skeletonizer/utils"],e):(t=typeof globalThis<"u"?globalThis:t||self,e(t.SkeletonizerVue={},t.Vue,t.SkeletonizerUtils))})(this,function(t,e,l){"use strict";var a=document.createElement("style");a.textContent=`[data-skeletonizer=wrapper-element]{--skeletonizer-text-background: rgba(0, 0, 0, .2);display:contents;filter:grayscale(100%);pointer-events:none}[data-skeletonizer=wrapper-element] *{pointer-events:none}[data-skeletonizer=wrapper-element] [data-skeletonizer=text]{animation:text-animation 2s infinite ease-in-out;background:var(--skeletonizer-primary-color);border-radius:50px;color:#0000!important}@keyframes text-animation{0%{background:var(--skeletonizer-primary-color)}50%{background:var(--skeletonizer-secondary-color)}to{background:var(--skeletonizer-primary-color)}}
2
+ /*$vite$:1*/`,document.head.appendChild(a);const c=e.defineComponent({__name:"SkeletonizerSkeleton",props:{config:{},showSkeleton:{type:Boolean},scope:{},colorSchema:{}},setup(i){const n=i,o=e.reactive(new l.SkeletonAdapterComponent);return e.watch(n.config,r=>{o.config=r,o.setupModels()},{immediate:!0}),(r,u)=>{const d=e.resolveDirective("skeletonize");return r.showSkeleton?(e.openBlock(!0),e.createElementBlock(e.Fragment,{key:0},e.renderList(o.viewModels,(p,m)=>e.withDirectives((e.openBlock(),e.createElementBlock("div",{key:m},[e.renderSlot(r.$slots,"default",{scope:p.value})])),[[d,n.colorSchema]])),128)):e.renderSlot(r.$slots,"default",{key:1,scope:n.scope})}}});class s extends l.SkeletonAbstractComponent{constructor(n,o){super(),this.skeletonConfig=n,this.showSkeleton=o}static generate(n,o){return e.reactive(new s(n,o))}}const k={install:i=>{i.component("SkeletonizerSkeleton",c),i.directive("skeletonize",(n,o)=>{l.SkeletonDirective.skeletonizeProjectedTemplate(n,o.value)})}};t.SkeletonizerComponentComposable=s,t.SkeletonizerPlugin=k,t.SkeletonizerSkeleton=c,Object.defineProperty(t,Symbol.toStringTag,{value:"Module"})});
@@ -0,0 +1,34 @@
1
+ import { ISkeletonizerColorSchema, TSchemaConfig } from '@skeletonizer/utils';
2
+ import { UnwrapRef } from 'vue';
3
+ declare const _default: <TSkeletonScopeObject extends object>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
4
+ props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{} & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps, never>, never> & {
5
+ config: TSchemaConfig<TSkeletonScopeObject>;
6
+ showSkeleton: boolean;
7
+ scope: TSkeletonScopeObject;
8
+ colorSchema?: ISkeletonizerColorSchema;
9
+ }> & import('vue').PublicProps;
10
+ expose(exposed: import('vue').ShallowUnwrapRef<{}>): void;
11
+ attrs: any;
12
+ slots: Readonly<{
13
+ default?: (props: {
14
+ scope: TSkeletonScopeObject | UnwrapRef<TSkeletonScopeObject>;
15
+ }) => {
16
+ scope: TSkeletonScopeObject | UnwrapRef<TSkeletonScopeObject>;
17
+ };
18
+ }> & {
19
+ default?: (props: {
20
+ scope: TSkeletonScopeObject | UnwrapRef<TSkeletonScopeObject>;
21
+ }) => {
22
+ scope: TSkeletonScopeObject | UnwrapRef<TSkeletonScopeObject>;
23
+ };
24
+ };
25
+ emit: {};
26
+ }>) => import('vue').VNode<import('vue').RendererNode, import('vue').RendererElement, {
27
+ [key: string]: any;
28
+ }> & {
29
+ __ctx?: Awaited<typeof __VLS_setup>;
30
+ };
31
+ export default _default;
32
+ type __VLS_PrettifyLocal<T> = {
33
+ [K in keyof T]: T[K];
34
+ } & {};
@@ -0,0 +1,8 @@
1
+ import { SkeletonAbstractComponent, TSchemaConfig } from '@skeletonizer/utils';
2
+ import { UnwrapNestedRefs } from 'vue';
3
+ export declare class SkeletonizerComponentComposable<T extends object> extends SkeletonAbstractComponent<T> {
4
+ skeletonConfig: TSchemaConfig<T>;
5
+ showSkeleton: boolean;
6
+ private constructor();
7
+ static generate<T extends object>(skeletonConfig: TSchemaConfig<T>, showSkeleton: boolean): UnwrapNestedRefs<SkeletonizerComponentComposable<T>>;
8
+ }
@@ -0,0 +1,4 @@
1
+ import { default as SkeletonizerSkeleton } from './components/SkeletonizerSkeleton.vue';
2
+ import { SkeletonizerComponentComposable } from './composables/skeletonizer.component.composable';
3
+ import { default as SkeletonizerPlugin } from './main';
4
+ export { SkeletonizerSkeleton, SkeletonizerComponentComposable, SkeletonizerPlugin };
@@ -0,0 +1,5 @@
1
+ import { App } from 'vue';
2
+ declare const _default: {
3
+ install: (app: App) => void;
4
+ };
5
+ export default _default;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@skeletonizer/vue",
3
- "version": "1.1.0",
3
+ "version": "1.1.2",
4
4
  "description": "The way to skeletonize your Vue.js components",
5
5
  "author": "Luka Varga",
6
6
  "license": "MIT",
@@ -55,7 +55,7 @@
55
55
  "vue": "^3.3.4"
56
56
  },
57
57
  "devDependencies": {
58
- "@skeletonizer/utils": "^1.1.0",
58
+ "@skeletonizer/utils": "^1.1.2",
59
59
  "@tsconfig/node18": "^2.0.1",
60
60
  "@types/jsdom": "^21.1.7",
61
61
  "@types/node": "^20.17.5",
@@ -80,5 +80,5 @@
80
80
  "**/*.{scss,css}": "stylelint --fix",
81
81
  "**/*.{ts,js,.vue}": "eslint --fix"
82
82
  },
83
- "gitHead": "1cc1b5c8a71f0f2490f555edf700c238a64df3d1"
83
+ "gitHead": "5a9e8a309e8b9ac0649d1b84612389291920aff3"
84
84
  }