@konbraphat51/affectiveslidervue 0.0.5 → 0.0.6
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/README.md +1 -14
- package/dist/affective-slider-vue.es.js +68 -59
- package/dist/affective-slider-vue.umd.js +3 -1
- package/package.json +3 -1
- package/src/index.ts +15 -0
package/README.md
CHANGED
|
@@ -33,20 +33,7 @@ The AS has been empirically validated and presented in the following open access
|
|
|
33
33
|
pnpm add affectiveslidervue
|
|
34
34
|
```
|
|
35
35
|
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
```javascript
|
|
39
|
-
// In your main.js or main.ts
|
|
40
|
-
import '@konbraphat51/affectiveslidervue/dist/style.css'
|
|
41
|
-
```
|
|
42
|
-
|
|
43
|
-
Or if using in a single component:
|
|
44
|
-
|
|
45
|
-
```vue
|
|
46
|
-
<style>
|
|
47
|
-
@import '@konbraphat51/affectiveslidervue/dist/style.css';
|
|
48
|
-
</style>
|
|
49
|
-
```
|
|
36
|
+
The CSS is automatically injected when you import the component, so no additional setup is needed!
|
|
50
37
|
|
|
51
38
|
## Usage
|
|
52
39
|
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import { ref as
|
|
2
|
-
const F = "", N = "", y = "", J = "", U = "", P = { class: "affective-slider" }, H = { class: "as-icon-wrapper as-icon-left" }, b = ["src", "alt"], G = {
|
|
1
|
+
import { ref as c, computed as x, onMounted as W, watch as h, createElementBlock as o, openBlock as l, Fragment as K, renderList as y, normalizeClass as R, createElementVNode as t, createCommentVNode as w, toDisplayString as C, unref as q } from "vue";
|
|
2
|
+
const k = "", D = "", I = "", S = "", F = "", N = { class: "affective-slider" }, J = { class: "as-icon-wrapper as-icon-left" }, U = ["src", "alt"], P = {
|
|
3
3
|
key: 0,
|
|
4
4
|
class: "as-icon-label"
|
|
5
|
-
},
|
|
5
|
+
}, H = ["name", "id", "value", "onInput", "onMousedown", "onTouchstart"], G = { class: "as-icon-wrapper as-icon-right" }, T = ["src", "alt"], Y = {
|
|
6
6
|
key: 0,
|
|
7
7
|
class: "as-icon-label"
|
|
8
|
-
},
|
|
8
|
+
}, z = { class: "as-intensity-cue" }, X = ["src"], M = {
|
|
9
9
|
__name: "AffectiveSlider",
|
|
10
10
|
props: {
|
|
11
11
|
// Initial value for pleasure slider (0-1)
|
|
12
12
|
pleasureValue: {
|
|
13
13
|
type: Number,
|
|
14
14
|
default: 0.5,
|
|
15
|
-
validator: (
|
|
15
|
+
validator: (r) => r >= 0 && r <= 1
|
|
16
16
|
},
|
|
17
17
|
// Initial value for arousal slider (0-1)
|
|
18
18
|
arousalValue: {
|
|
19
19
|
type: Number,
|
|
20
20
|
default: 0.5,
|
|
21
|
-
validator: (
|
|
21
|
+
validator: (r) => r >= 0 && r <= 1
|
|
22
22
|
},
|
|
23
23
|
// Randomize the order of sliders
|
|
24
24
|
randomizeOrder: {
|
|
@@ -47,77 +47,86 @@ const F = "
|
|
|
47
47
|
}
|
|
48
48
|
},
|
|
49
49
|
emits: ["update:pleasureValue", "update:arousalValue", "change", "interacted"],
|
|
50
|
-
setup(
|
|
51
|
-
const
|
|
50
|
+
setup(r, { emit: s }) {
|
|
51
|
+
const A = r, d = s, n = c(A.pleasureValue), i = c(A.arousalValue), g = c([]), u = c({
|
|
52
52
|
pleasure: !1,
|
|
53
53
|
arousal: !1
|
|
54
|
-
}),
|
|
55
|
-
type:
|
|
56
|
-
value:
|
|
57
|
-
leftImage:
|
|
58
|
-
rightImage:
|
|
59
|
-
leftLabel:
|
|
60
|
-
rightLabel:
|
|
61
|
-
}))),
|
|
62
|
-
const
|
|
63
|
-
|
|
64
|
-
},
|
|
65
|
-
|
|
66
|
-
},
|
|
67
|
-
const
|
|
68
|
-
|
|
54
|
+
}), b = (e) => e === "pleasure" ? k : D, B = (e) => e === "pleasure" ? I : S, V = (e) => e === "pleasure" ? A.pleasureLeftLabel : A.arousalLeftLabel, Q = (e) => e === "pleasure" ? A.pleasureRightLabel : A.arousalRightLabel, v = x(() => g.value.map((e) => ({
|
|
55
|
+
type: e,
|
|
56
|
+
value: e === "pleasure" ? n.value : i.value,
|
|
57
|
+
leftImage: b(e),
|
|
58
|
+
rightImage: B(e),
|
|
59
|
+
leftLabel: V(e),
|
|
60
|
+
rightLabel: Q(e)
|
|
61
|
+
}))), E = (e, m) => {
|
|
62
|
+
const a = parseFloat(m.target.value);
|
|
63
|
+
e === "pleasure" ? n.value = a : i.value = a, d(`update:${e}Value`, a), d("change", { pleasure: n.value, arousal: i.value });
|
|
64
|
+
}, f = (e) => {
|
|
65
|
+
u.value[e] || (u.value[e] = !0, d("interacted", { type: e, pleasure: n.value, arousal: i.value }));
|
|
66
|
+
}, L = () => {
|
|
67
|
+
const e = ["arousal", "pleasure"];
|
|
68
|
+
A.randomizeOrder ? g.value = Math.random() > 0.5 ? [...e] : [...e].reverse() : g.value = ["pleasure", "arousal"];
|
|
69
69
|
};
|
|
70
|
-
return
|
|
71
|
-
|
|
72
|
-
}),
|
|
73
|
-
|
|
74
|
-
}),
|
|
75
|
-
|
|
76
|
-
}), (
|
|
77
|
-
(
|
|
78
|
-
key:
|
|
79
|
-
class:
|
|
70
|
+
return W(() => {
|
|
71
|
+
L();
|
|
72
|
+
}), h(() => A.pleasureValue, (e) => {
|
|
73
|
+
n.value = e;
|
|
74
|
+
}), h(() => A.arousalValue, (e) => {
|
|
75
|
+
i.value = e;
|
|
76
|
+
}), (e, m) => (l(), o("div", N, [
|
|
77
|
+
(l(!0), o(K, null, y(v.value, (a) => (l(), o("div", {
|
|
78
|
+
key: a.type,
|
|
79
|
+
class: R(["as-container", a.type])
|
|
80
80
|
}, [
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
src:
|
|
84
|
-
alt: `${
|
|
81
|
+
t("div", J, [
|
|
82
|
+
t("img", {
|
|
83
|
+
src: a.leftImage,
|
|
84
|
+
alt: `${a.type} left`,
|
|
85
85
|
class: "as-icon"
|
|
86
|
-
}, null, 8,
|
|
87
|
-
|
|
86
|
+
}, null, 8, U),
|
|
87
|
+
a.leftLabel ? (l(), o("div", P, C(a.leftLabel), 1)) : w("", !0)
|
|
88
88
|
]),
|
|
89
|
-
|
|
89
|
+
t("input", {
|
|
90
90
|
type: "range",
|
|
91
|
-
name: `AS-${
|
|
92
|
-
id: `AS-${
|
|
93
|
-
value:
|
|
91
|
+
name: `AS-${a.type}`,
|
|
92
|
+
id: `AS-${a.type}`,
|
|
93
|
+
value: a.value,
|
|
94
94
|
min: "0",
|
|
95
95
|
max: "1",
|
|
96
96
|
step: "0.01",
|
|
97
|
-
onInput: (
|
|
98
|
-
onMousedown: (
|
|
99
|
-
onTouchstart: (
|
|
97
|
+
onInput: (p) => E(a.type, p),
|
|
98
|
+
onMousedown: (p) => f(a.type),
|
|
99
|
+
onTouchstart: (p) => f(a.type),
|
|
100
100
|
class: "as-slider"
|
|
101
|
-
}, null, 40,
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
src:
|
|
105
|
-
alt: `${
|
|
101
|
+
}, null, 40, H),
|
|
102
|
+
t("div", G, [
|
|
103
|
+
t("img", {
|
|
104
|
+
src: a.rightImage,
|
|
105
|
+
alt: `${a.type} right`,
|
|
106
106
|
class: "as-icon"
|
|
107
|
-
}, null, 8,
|
|
108
|
-
|
|
107
|
+
}, null, 8, T),
|
|
108
|
+
a.rightLabel ? (l(), o("div", Y, C(a.rightLabel), 1)) : w("", !0)
|
|
109
109
|
]),
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
src:
|
|
110
|
+
t("div", z, [
|
|
111
|
+
t("img", {
|
|
112
|
+
src: q(F),
|
|
113
113
|
alt: "intensity cue"
|
|
114
|
-
}, null, 8,
|
|
114
|
+
}, null, 8, X)
|
|
115
115
|
])
|
|
116
116
|
], 2))), 128))
|
|
117
117
|
]));
|
|
118
118
|
}
|
|
119
119
|
};
|
|
120
|
+
if (typeof document < "u") {
|
|
121
|
+
const r = "affectiveslidervue-styles";
|
|
122
|
+
if (!document.getElementById(r)) {
|
|
123
|
+
const s = document.createElement("style");
|
|
124
|
+
s.id = r, s.textContent = `
|
|
125
|
+
.affective-slider{width:100%;max-width:800px;margin:0 auto;padding:20px}.as-container{margin:3em 0;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative}.as-icon{width:60px;height:60px;object-fit:contain}.as-icon-wrapper{position:absolute;top:0;display:flex;flex-direction:column;align-items:center;gap:4px}.as-icon-left{left:0}.as-icon-right{right:0}.as-icon-label{font-size:12px;color:#333;text-align:center;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}.as-slider{-webkit-appearance:none;width:calc(100% - 140px);height:20px;background:#ddd;border-radius:10px;outline:none;margin:0 70px;cursor:pointer}.as-slider:focus{background:#ccc}.as-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer;transition:all .2s ease}.as-slider::-webkit-slider-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-webkit-slider-thumb:active{background:#505050;border:2px solid #fff}.as-slider::-moz-range-thumb{width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer;transition:all .2s ease}.as-slider::-moz-range-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-moz-range-thumb:active{background:#505050;border:2px solid #fff}.as-slider::-moz-range-track{width:100%;height:20px;background:#ddd;border-radius:10px;border:none}.as-slider:focus::-moz-range-track{background:#ccc}.as-slider::-ms-track{width:100%;height:20px;background:transparent;border-color:transparent;border-width:16px 0;color:transparent}.as-slider::-ms-fill-lower{background:#ddd;border-radius:10px}.as-slider::-ms-fill-upper{background:#ddd;border-radius:10px}.as-slider::-ms-thumb{width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer}.as-slider::-ms-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-ms-thumb:active{background:#505050;border:2px solid #fff}.as-slider:focus::-ms-fill-lower{background:#ccc}.as-slider:focus::-ms-fill-upper{background:#ccc}.as-intensity-cue{width:calc(100% - 140px);margin:10px 70px 0}.as-intensity-cue img{width:100%;height:auto}@media(max-width:768px){.as-icon{width:40px;height:40px}.as-slider{width:calc(100% - 100px);margin:0 50px}.as-intensity-cue{width:calc(100% - 100px);margin:10px 50px 0}.as-icon-label{font-size:10px;max-width:60px}}
|
|
126
|
+
`, document.head.appendChild(s);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
120
129
|
export {
|
|
121
|
-
|
|
122
|
-
|
|
130
|
+
M as AffectiveSlider,
|
|
131
|
+
M as default
|
|
123
132
|
};
|
|
@@ -1 +1,3 @@
|
|
|
1
|
-
(function(l,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(l=typeof globalThis<"u"?globalThis:l||self,e(l.AffectiveSliderVue={},l.Vue))})(this,(function(l,e){"use strict";const B="",V="",d="",m="",f="",E={class:"affective-slider"},Q={class:"as-icon-wrapper as-icon-left"},w=["src","alt"],L={key:0,class:"as-icon-label"},W=["name","id","value","onInput","onMousedown","onTouchstart"],K={class:"as-icon-wrapper as-icon-right"},R=["src","alt"],q={key:0,class:"as-icon-label"},h={class:"as-intensity-cue"},N=["src"],g={__name:"AffectiveSlider",props:{pleasureValue:{type:Number,default:.5,validator:r=>r>=0&&r<=1},arousalValue:{type:Number,default:.5,validator:r=>r>=0&&r<=1},randomizeOrder:{type:Boolean,default:!0},pleasureLeftLabel:{type:String,default:""},pleasureRightLabel:{type:String,default:""},arousalLeftLabel:{type:String,default:""},arousalRightLabel:{type:String,default:""}},emits:["update:pleasureValue","update:arousalValue","change","interacted"],setup(r,{emit:S}){const t=r,o=S,n=e.ref(t.pleasureValue),s=e.ref(t.arousalValue),c=e.ref([]),p=e.ref({pleasure:!1,arousal:!1}),D=A=>A==="pleasure"?B:V,y=A=>A==="pleasure"?d:m,I=A=>A==="pleasure"?t.pleasureLeftLabel:t.arousalLeftLabel,F=A=>A==="pleasure"?t.pleasureRightLabel:t.arousalRightLabel,J=e.computed(()=>c.value.map(A=>({type:A,value:A==="pleasure"?n.value:s.value,leftImage:D(A),rightImage:y(A),leftLabel:I(A),rightLabel:F(A)}))),U=(A,C)=>{const a=parseFloat(C.target.value);A==="pleasure"?n.value=a:s.value=a,o(`update:${A}Value`,a),o("change",{pleasure:n.value,arousal:s.value})},u=A=>{p.value[A]||(p.value[A]=!0,o("interacted",{type:A,pleasure:n.value,arousal:s.value}))},P=()=>{const A=["arousal","pleasure"];t.randomizeOrder?c.value=Math.random()>.5?[...A]:[...A].reverse():c.value=["pleasure","arousal"]};return e.onMounted(()=>{P()}),e.watch(()=>t.pleasureValue,A=>{n.value=A}),e.watch(()=>t.arousalValue,A=>{s.value=A}),(A,C)=>(e.openBlock(),e.createElementBlock("div",E,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(J.value,a=>(e.openBlock(),e.createElementBlock("div",{key:a.type,class:e.normalizeClass(["as-container",a.type])},[e.createElementVNode("div",Q,[e.createElementVNode("img",{src:a.leftImage,alt:`${a.type} left`,class:"as-icon"},null,8,w),a.leftLabel?(e.openBlock(),e.createElementBlock("div",L,e.toDisplayString(a.leftLabel),1)):e.createCommentVNode("",!0)]),e.createElementVNode("input",{type:"range",name:`AS-${a.type}`,id:`AS-${a.type}`,value:a.value,min:"0",max:"1",step:"0.01",onInput:i=>U(a.type,i),onMousedown:i=>u(a.type),onTouchstart:i=>u(a.type),class:"as-slider"},null,40,W),e.createElementVNode("div",K,[e.createElementVNode("img",{src:a.rightImage,alt:`${a.type} right`,class:"as-icon"},null,8,R),a.rightLabel?(e.openBlock(),e.createElementBlock("div",q,e.toDisplayString(a.rightLabel),1)):e.createCommentVNode("",!0)]),e.createElementVNode("div",h,[e.createElementVNode("img",{src:e.unref(f),alt:"intensity cue"},null,8,N)])],2))),128))]))}};l.AffectiveSlider=g,l.default=g,Object.defineProperties(l,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})}));
|
|
1
|
+
(function(s,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(s=typeof globalThis<"u"?globalThis:s||self,e(s.AffectiveSliderVue={},s.Vue))})(this,(function(s,e){"use strict";const m="",h="",w="",C="",b="",B={class:"affective-slider"},V={class:"as-icon-wrapper as-icon-left"},E=["src","alt"],Q={key:0,class:"as-icon-label"},L=["name","id","value","onInput","onMousedown","onTouchstart"],x={class:"as-icon-wrapper as-icon-right"},W=["src","alt"],y={key:0,class:"as-icon-label"},K={class:"as-intensity-cue"},k=["src"],p={__name:"AffectiveSlider",props:{pleasureValue:{type:Number,default:.5,validator:r=>r>=0&&r<=1},arousalValue:{type:Number,default:.5,validator:r=>r>=0&&r<=1},randomizeOrder:{type:Boolean,default:!0},pleasureLeftLabel:{type:String,default:""},pleasureRightLabel:{type:String,default:""},arousalLeftLabel:{type:String,default:""},arousalRightLabel:{type:String,default:""}},emits:["update:pleasureValue","update:arousalValue","change","interacted"],setup(r,{emit:n}){const A=r,l=n,o=e.ref(A.pleasureValue),i=e.ref(A.arousalValue),c=e.ref([]),g=e.ref({pleasure:!1,arousal:!1}),R=a=>a==="pleasure"?m:h,q=a=>a==="pleasure"?w:C,N=a=>a==="pleasure"?A.pleasureLeftLabel:A.arousalLeftLabel,S=a=>a==="pleasure"?A.pleasureRightLabel:A.arousalRightLabel,D=e.computed(()=>c.value.map(a=>({type:a,value:a==="pleasure"?o.value:i.value,leftImage:R(a),rightImage:q(a),leftLabel:N(a),rightLabel:S(a)}))),I=(a,f)=>{const t=parseFloat(f.target.value);a==="pleasure"?o.value=t:i.value=t,l(`update:${a}Value`,t),l("change",{pleasure:o.value,arousal:i.value})},u=a=>{g.value[a]||(g.value[a]=!0,l("interacted",{type:a,pleasure:o.value,arousal:i.value}))},F=()=>{const a=["arousal","pleasure"];A.randomizeOrder?c.value=Math.random()>.5?[...a]:[...a].reverse():c.value=["pleasure","arousal"]};return e.onMounted(()=>{F()}),e.watch(()=>A.pleasureValue,a=>{o.value=a}),e.watch(()=>A.arousalValue,a=>{i.value=a}),(a,f)=>(e.openBlock(),e.createElementBlock("div",B,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(D.value,t=>(e.openBlock(),e.createElementBlock("div",{key:t.type,class:e.normalizeClass(["as-container",t.type])},[e.createElementVNode("div",V,[e.createElementVNode("img",{src:t.leftImage,alt:`${t.type} left`,class:"as-icon"},null,8,E),t.leftLabel?(e.openBlock(),e.createElementBlock("div",Q,e.toDisplayString(t.leftLabel),1)):e.createCommentVNode("",!0)]),e.createElementVNode("input",{type:"range",name:`AS-${t.type}`,id:`AS-${t.type}`,value:t.value,min:"0",max:"1",step:"0.01",onInput:d=>I(t.type,d),onMousedown:d=>u(t.type),onTouchstart:d=>u(t.type),class:"as-slider"},null,40,L),e.createElementVNode("div",x,[e.createElementVNode("img",{src:t.rightImage,alt:`${t.type} right`,class:"as-icon"},null,8,W),t.rightLabel?(e.openBlock(),e.createElementBlock("div",y,e.toDisplayString(t.rightLabel),1)):e.createCommentVNode("",!0)]),e.createElementVNode("div",K,[e.createElementVNode("img",{src:e.unref(b),alt:"intensity cue"},null,8,k)])],2))),128))]))}};if(typeof document<"u"){const r="affectiveslidervue-styles";if(!document.getElementById(r)){const n=document.createElement("style");n.id=r,n.textContent=`
|
|
2
|
+
.affective-slider{width:100%;max-width:800px;margin:0 auto;padding:20px}.as-container{margin:3em 0;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative}.as-icon{width:60px;height:60px;object-fit:contain}.as-icon-wrapper{position:absolute;top:0;display:flex;flex-direction:column;align-items:center;gap:4px}.as-icon-left{left:0}.as-icon-right{right:0}.as-icon-label{font-size:12px;color:#333;text-align:center;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}.as-slider{-webkit-appearance:none;width:calc(100% - 140px);height:20px;background:#ddd;border-radius:10px;outline:none;margin:0 70px;cursor:pointer}.as-slider:focus{background:#ccc}.as-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer;transition:all .2s ease}.as-slider::-webkit-slider-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-webkit-slider-thumb:active{background:#505050;border:2px solid #fff}.as-slider::-moz-range-thumb{width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer;transition:all .2s ease}.as-slider::-moz-range-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-moz-range-thumb:active{background:#505050;border:2px solid #fff}.as-slider::-moz-range-track{width:100%;height:20px;background:#ddd;border-radius:10px;border:none}.as-slider:focus::-moz-range-track{background:#ccc}.as-slider::-ms-track{width:100%;height:20px;background:transparent;border-color:transparent;border-width:16px 0;color:transparent}.as-slider::-ms-fill-lower{background:#ddd;border-radius:10px}.as-slider::-ms-fill-upper{background:#ddd;border-radius:10px}.as-slider::-ms-thumb{width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer}.as-slider::-ms-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-ms-thumb:active{background:#505050;border:2px solid #fff}.as-slider:focus::-ms-fill-lower{background:#ccc}.as-slider:focus::-ms-fill-upper{background:#ccc}.as-intensity-cue{width:calc(100% - 140px);margin:10px 70px 0}.as-intensity-cue img{width:100%;height:auto}@media(max-width:768px){.as-icon{width:40px;height:40px}.as-slider{width:calc(100% - 100px);margin:0 50px}.as-intensity-cue{width:calc(100% - 100px);margin:10px 50px 0}.as-icon-label{font-size:10px;max-width:60px}}
|
|
3
|
+
`,document.head.appendChild(n)}}s.AffectiveSlider=p,s.default=p,Object.defineProperties(s,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})}));
|
package/package.json
CHANGED
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@konbraphat51/affectiveslidervue",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.6",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "./dist/affective-slider-vue.umd.js",
|
|
6
6
|
"module": "./dist/affective-slider-vue.es.js",
|
|
7
7
|
"exports": {
|
|
8
8
|
".": {
|
|
9
|
+
"types": "./dist/index.d.ts",
|
|
9
10
|
"import": "./dist/affective-slider-vue.es.js",
|
|
10
11
|
"require": "./dist/affective-slider-vue.umd.js"
|
|
11
12
|
},
|
|
12
13
|
"./dist/style.css": "./dist/affectiveslidervue.css",
|
|
14
|
+
"./style.css": "./dist/affectiveslidervue.css",
|
|
13
15
|
"./dist/images/*": "./dist/images/*"
|
|
14
16
|
},
|
|
15
17
|
"files": [
|
package/src/index.ts
CHANGED
|
@@ -1,4 +1,19 @@
|
|
|
1
1
|
import AffectiveSlider from './components/AffectiveSlider.vue'
|
|
2
2
|
|
|
3
|
+
// Auto-inject CSS styles when the component is imported
|
|
4
|
+
if (typeof document !== 'undefined') {
|
|
5
|
+
const styleId = 'affectiveslidervue-styles'
|
|
6
|
+
|
|
7
|
+
// Check if styles are already injected
|
|
8
|
+
if (!document.getElementById(styleId)) {
|
|
9
|
+
const style = document.createElement('style')
|
|
10
|
+
style.id = styleId
|
|
11
|
+
style.textContent = `
|
|
12
|
+
.affective-slider{width:100%;max-width:800px;margin:0 auto;padding:20px}.as-container{margin:3em 0;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative}.as-icon{width:60px;height:60px;object-fit:contain}.as-icon-wrapper{position:absolute;top:0;display:flex;flex-direction:column;align-items:center;gap:4px}.as-icon-left{left:0}.as-icon-right{right:0}.as-icon-label{font-size:12px;color:#333;text-align:center;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}.as-slider{-webkit-appearance:none;width:calc(100% - 140px);height:20px;background:#ddd;border-radius:10px;outline:none;margin:0 70px;cursor:pointer}.as-slider:focus{background:#ccc}.as-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer;transition:all .2s ease}.as-slider::-webkit-slider-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-webkit-slider-thumb:active{background:#505050;border:2px solid #fff}.as-slider::-moz-range-thumb{width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer;transition:all .2s ease}.as-slider::-moz-range-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-moz-range-thumb:active{background:#505050;border:2px solid #fff}.as-slider::-moz-range-track{width:100%;height:20px;background:#ddd;border-radius:10px;border:none}.as-slider:focus::-moz-range-track{background:#ccc}.as-slider::-ms-track{width:100%;height:20px;background:transparent;border-color:transparent;border-width:16px 0;color:transparent}.as-slider::-ms-fill-lower{background:#ddd;border-radius:10px}.as-slider::-ms-fill-upper{background:#ddd;border-radius:10px}.as-slider::-ms-thumb{width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer}.as-slider::-ms-thumb:hover{background:#505050;border:2px solid #fff;box-shadow:0 0 12px #212121}.as-slider::-ms-thumb:active{background:#505050;border:2px solid #fff}.as-slider:focus::-ms-fill-lower{background:#ccc}.as-slider:focus::-ms-fill-upper{background:#ccc}.as-intensity-cue{width:calc(100% - 140px);margin:10px 70px 0}.as-intensity-cue img{width:100%;height:auto}@media(max-width:768px){.as-icon{width:40px;height:40px}.as-slider{width:calc(100% - 100px);margin:0 50px}.as-intensity-cue{width:calc(100% - 100px);margin:10px 50px 0}.as-icon-label{font-size:10px;max-width:60px}}
|
|
13
|
+
`
|
|
14
|
+
document.head.appendChild(style)
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
|
|
3
18
|
export { AffectiveSlider }
|
|
4
19
|
export default AffectiveSlider
|