@konbraphat51/affectiveslidervue 0.0.4 → 0.0.5

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.
@@ -1,16 +1,11 @@
1
- import { ref as c, computed as R, onMounted as q, watch as Q, createElementBlock as o, openBlock as g, Fragment as h, renderList as D, normalizeClass as I, createElementVNode as r, createCommentVNode as w, toDisplayString as m, unref as S } from "vue";
2
- const y = "", F = "", N = "", J = "", U = "", P = (t, i) => {
3
- const a = t.__vccOpts || t;
4
- for (const [l, s] of i)
5
- a[l] = s;
6
- return a;
7
- }, H = { class: "affective-slider" }, b = { class: "as-icon-wrapper as-icon-left" }, G = ["src", "alt"], T = {
1
+ import { ref as g, computed as R, onMounted as q, watch as V, createElementBlock as n, openBlock as o, Fragment as h, renderList as D, normalizeClass as I, createElementVNode as s, createCommentVNode as Q, toDisplayString as w, unref as S } from "vue";
2
+ const F = "", N = "", y = "", J = "", U = "", P = { class: "affective-slider" }, H = { class: "as-icon-wrapper as-icon-left" }, b = ["src", "alt"], G = {
8
3
  key: 0,
9
4
  class: "as-icon-label"
10
- }, Y = ["name", "id", "value", "onInput", "onMousedown", "onTouchstart"], X = { class: "as-icon-wrapper as-icon-right" }, Z = ["src", "alt"], k = {
5
+ }, T = ["name", "id", "value", "onInput", "onMousedown", "onTouchstart"], Y = { class: "as-icon-wrapper as-icon-right" }, X = ["src", "alt"], Z = {
11
6
  key: 0,
12
7
  class: "as-icon-label"
13
- }, z = { class: "as-intensity-cue" }, M = ["src"], O = {
8
+ }, k = { class: "as-intensity-cue" }, z = ["src"], O = {
14
9
  __name: "AffectiveSlider",
15
10
  props: {
16
11
  // Initial value for pleasure slider (0-1)
@@ -52,46 +47,46 @@ const y = "
52
47
  }
53
48
  },
54
49
  emits: ["update:pleasureValue", "update:arousalValue", "change", "interacted"],
55
- setup(t, { emit: i }) {
56
- const a = t, l = i, s = c(a.pleasureValue), n = c(a.arousalValue), u = c([]), C = c({
50
+ setup(t, { emit: m }) {
51
+ const a = t, c = m, r = g(a.pleasureValue), l = g(a.arousalValue), i = g([]), p = g({
57
52
  pleasure: !1,
58
53
  arousal: !1
59
- }), d = (A) => A === "pleasure" ? y : F, E = (A) => A === "pleasure" ? N : J, L = (A) => A === "pleasure" ? a.pleasureLeftLabel : a.arousalLeftLabel, f = (A) => A === "pleasure" ? a.pleasureRightLabel : a.arousalRightLabel, v = R(() => u.value.map((A) => ({
54
+ }), E = (A) => A === "pleasure" ? F : N, L = (A) => A === "pleasure" ? y : J, d = (A) => A === "pleasure" ? a.pleasureLeftLabel : a.arousalLeftLabel, W = (A) => A === "pleasure" ? a.pleasureRightLabel : a.arousalRightLabel, f = R(() => i.value.map((A) => ({
60
55
  type: A,
61
- value: A === "pleasure" ? s.value : n.value,
62
- leftImage: d(A),
63
- rightImage: E(A),
64
- leftLabel: L(A),
65
- rightLabel: f(A)
66
- }))), W = (A, V) => {
67
- const e = parseFloat(V.target.value);
68
- A === "pleasure" ? s.value = e : n.value = e, l(`update:${A}Value`, e), l("change", { pleasure: s.value, arousal: n.value });
69
- }, B = (A) => {
70
- C.value[A] || (C.value[A] = !0, l("interacted", { type: A, pleasure: s.value, arousal: n.value }));
56
+ value: A === "pleasure" ? r.value : l.value,
57
+ leftImage: E(A),
58
+ rightImage: L(A),
59
+ leftLabel: d(A),
60
+ rightLabel: W(A)
61
+ }))), v = (A, B) => {
62
+ const e = parseFloat(B.target.value);
63
+ A === "pleasure" ? r.value = e : l.value = e, c(`update:${A}Value`, e), c("change", { pleasure: r.value, arousal: l.value });
64
+ }, C = (A) => {
65
+ p.value[A] || (p.value[A] = !0, c("interacted", { type: A, pleasure: r.value, arousal: l.value }));
71
66
  }, K = () => {
72
67
  const A = ["arousal", "pleasure"];
73
- a.randomizeOrder ? u.value = Math.random() > 0.5 ? [...A] : [...A].reverse() : u.value = ["pleasure", "arousal"];
68
+ a.randomizeOrder ? i.value = Math.random() > 0.5 ? [...A] : [...A].reverse() : i.value = ["pleasure", "arousal"];
74
69
  };
75
70
  return q(() => {
76
71
  K();
77
- }), Q(() => a.pleasureValue, (A) => {
78
- s.value = A;
79
- }), Q(() => a.arousalValue, (A) => {
80
- n.value = A;
81
- }), (A, V) => (g(), o("div", H, [
82
- (g(!0), o(h, null, D(v.value, (e) => (g(), o("div", {
72
+ }), V(() => a.pleasureValue, (A) => {
73
+ r.value = A;
74
+ }), V(() => a.arousalValue, (A) => {
75
+ l.value = A;
76
+ }), (A, B) => (o(), n("div", P, [
77
+ (o(!0), n(h, null, D(f.value, (e) => (o(), n("div", {
83
78
  key: e.type,
84
79
  class: I(["as-container", e.type])
85
80
  }, [
86
- r("div", b, [
87
- r("img", {
81
+ s("div", H, [
82
+ s("img", {
88
83
  src: e.leftImage,
89
84
  alt: `${e.type} left`,
90
85
  class: "as-icon"
91
- }, null, 8, G),
92
- e.leftLabel ? (g(), o("div", T, m(e.leftLabel), 1)) : w("", !0)
86
+ }, null, 8, b),
87
+ e.leftLabel ? (o(), n("div", G, w(e.leftLabel), 1)) : Q("", !0)
93
88
  ]),
94
- r("input", {
89
+ s("input", {
95
90
  type: "range",
96
91
  name: `AS-${e.type}`,
97
92
  id: `AS-${e.type}`,
@@ -99,30 +94,30 @@ const y = "
99
94
  min: "0",
100
95
  max: "1",
101
96
  step: "0.01",
102
- onInput: (p) => W(e.type, p),
103
- onMousedown: (p) => B(e.type),
104
- onTouchstart: (p) => B(e.type),
97
+ onInput: (u) => v(e.type, u),
98
+ onMousedown: (u) => C(e.type),
99
+ onTouchstart: (u) => C(e.type),
105
100
  class: "as-slider"
106
- }, null, 40, Y),
107
- r("div", X, [
108
- r("img", {
101
+ }, null, 40, T),
102
+ s("div", Y, [
103
+ s("img", {
109
104
  src: e.rightImage,
110
105
  alt: `${e.type} right`,
111
106
  class: "as-icon"
112
- }, null, 8, Z),
113
- e.rightLabel ? (g(), o("div", k, m(e.rightLabel), 1)) : w("", !0)
107
+ }, null, 8, X),
108
+ e.rightLabel ? (o(), n("div", Z, w(e.rightLabel), 1)) : Q("", !0)
114
109
  ]),
115
- r("div", z, [
116
- r("img", {
110
+ s("div", k, [
111
+ s("img", {
117
112
  src: S(U),
118
113
  alt: "intensity cue"
119
- }, null, 8, M)
114
+ }, null, 8, z)
120
115
  ])
121
116
  ], 2))), 128))
122
117
  ]));
123
118
  }
124
- }, j = /* @__PURE__ */ P(O, [["__scopeId", "data-v-7a449788"]]);
119
+ };
125
120
  export {
126
- j as AffectiveSlider,
127
- j as default
121
+ O as AffectiveSlider,
122
+ O as default
128
123
  };
@@ -1 +1 @@
1
- (function(r,e){typeof exports=="object"&&typeof module<"u"?e(exports,require("vue")):typeof define=="function"&&define.amd?define(["exports","vue"],e):(r=typeof globalThis<"u"?globalThis:r||self,e(r.AffectiveSliderVue={},r.Vue))})(this,(function(r,e){"use strict";const V="",d="",f="",m="",E="",Q=(l,c)=>{const t=l.__vccOpts||l;for(const[s,n]of c)t[s]=n;return t},w={class:"affective-slider"},L={class:"as-icon-wrapper as-icon-left"},W=["src","alt"],K={key:0,class:"as-icon-label"},R=["name","id","value","onInput","onMousedown","onTouchstart"],q={class:"as-icon-wrapper as-icon-right"},h=["src","alt"],N={key:0,class:"as-icon-label"},S={class:"as-intensity-cue"},D=["src"],p=Q({__name:"AffectiveSlider",props:{pleasureValue:{type:Number,default:.5,validator:l=>l>=0&&l<=1},arousalValue:{type:Number,default:.5,validator:l=>l>=0&&l<=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(l,{emit:c}){const t=l,s=c,n=e.ref(t.pleasureValue),o=e.ref(t.arousalValue),i=e.ref([]),u=e.ref({pleasure:!1,arousal:!1}),y=A=>A==="pleasure"?V:d,I=A=>A==="pleasure"?f:m,F=A=>A==="pleasure"?t.pleasureLeftLabel:t.arousalLeftLabel,J=A=>A==="pleasure"?t.pleasureRightLabel:t.arousalRightLabel,U=e.computed(()=>i.value.map(A=>({type:A,value:A==="pleasure"?n.value:o.value,leftImage:y(A),rightImage:I(A),leftLabel:F(A),rightLabel:J(A)}))),P=(A,B)=>{const a=parseFloat(B.target.value);A==="pleasure"?n.value=a:o.value=a,s(`update:${A}Value`,a),s("change",{pleasure:n.value,arousal:o.value})},C=A=>{u.value[A]||(u.value[A]=!0,s("interacted",{type:A,pleasure:n.value,arousal:o.value}))},b=()=>{const A=["arousal","pleasure"];t.randomizeOrder?i.value=Math.random()>.5?[...A]:[...A].reverse():i.value=["pleasure","arousal"]};return e.onMounted(()=>{b()}),e.watch(()=>t.pleasureValue,A=>{n.value=A}),e.watch(()=>t.arousalValue,A=>{o.value=A}),(A,B)=>(e.openBlock(),e.createElementBlock("div",w,[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(U.value,a=>(e.openBlock(),e.createElementBlock("div",{key:a.type,class:e.normalizeClass(["as-container",a.type])},[e.createElementVNode("div",L,[e.createElementVNode("img",{src:a.leftImage,alt:`${a.type} left`,class:"as-icon"},null,8,W),a.leftLabel?(e.openBlock(),e.createElementBlock("div",K,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:g=>P(a.type,g),onMousedown:g=>C(a.type),onTouchstart:g=>C(a.type),class:"as-slider"},null,40,R),e.createElementVNode("div",q,[e.createElementVNode("img",{src:a.rightImage,alt:`${a.type} right`,class:"as-icon"},null,8,h),a.rightLabel?(e.openBlock(),e.createElementBlock("div",N,e.toDisplayString(a.rightLabel),1)):e.createCommentVNode("",!0)]),e.createElementVNode("div",S,[e.createElementVNode("img",{src:e.unref(E),alt:"intensity cue"},null,8,D)])],2))),128))]))}},[["__scopeId","data-v-7a449788"]]);r.AffectiveSlider=p,r.default=p,Object.defineProperties(r,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})}));
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 +1 @@
1
- .affective-slider[data-v-7a449788]{width:100%;max-width:800px;margin:0 auto;padding:20px}.as-container[data-v-7a449788]{margin:3em 0;display:flex;align-items:center;justify-content:center;flex-direction:column;position:relative}.as-icon[data-v-7a449788]{width:60px;height:60px;object-fit:contain}.as-icon-wrapper[data-v-7a449788]{position:absolute;top:0;display:flex;flex-direction:column;align-items:center;gap:4px}.as-icon-left[data-v-7a449788]{left:0}.as-icon-right[data-v-7a449788]{right:0}.as-icon-label[data-v-7a449788]{font-size:12px;color:#333;text-align:center;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}.as-slider[data-v-7a449788]{-webkit-appearance:none;width:calc(100% - 140px);height:20px;background:#ddd;border-radius:10px;outline:none;margin:0 70px;cursor:pointer}.as-slider[data-v-7a449788]:focus{background:#ccc}.as-slider[data-v-7a449788]::-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[data-v-7a449788]::-webkit-slider-thumb:hover{background:#505050;border:2px solid white;box-shadow:0 0 12px #212121}.as-slider[data-v-7a449788]::-webkit-slider-thumb:active{background:#505050;border:2px solid white}.as-slider[data-v-7a449788]::-moz-range-thumb{width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer;transition:all .2s ease}.as-slider[data-v-7a449788]::-moz-range-thumb:hover{background:#505050;border:2px solid white;box-shadow:0 0 12px #212121}.as-slider[data-v-7a449788]::-moz-range-thumb:active{background:#505050;border:2px solid white}.as-slider[data-v-7a449788]::-moz-range-track{width:100%;height:20px;background:#ddd;border-radius:10px;border:none}.as-slider[data-v-7a449788]:focus::-moz-range-track{background:#ccc}.as-slider[data-v-7a449788]::-ms-track{width:100%;height:20px;background:transparent;border-color:transparent;border-width:16px 0;color:transparent}.as-slider[data-v-7a449788]::-ms-fill-lower{background:#ddd;border-radius:10px}.as-slider[data-v-7a449788]::-ms-fill-upper{background:#ddd;border-radius:10px}.as-slider[data-v-7a449788]::-ms-thumb{width:35px;height:35px;border-radius:50%;background:#fff;border:2px solid #505050;cursor:pointer}.as-slider[data-v-7a449788]::-ms-thumb:hover{background:#505050;border:2px solid white;box-shadow:0 0 12px #212121}.as-slider[data-v-7a449788]::-ms-thumb:active{background:#505050;border:2px solid white}.as-slider[data-v-7a449788]:focus::-ms-fill-lower{background:#ccc}.as-slider[data-v-7a449788]:focus::-ms-fill-upper{background:#ccc}.as-intensity-cue[data-v-7a449788]{width:calc(100% - 140px);margin:10px 70px 0}.as-intensity-cue img[data-v-7a449788]{width:100%;height:auto}@media(max-width:768px){.as-icon[data-v-7a449788]{width:40px;height:40px}.as-slider[data-v-7a449788]{width:calc(100% - 100px);margin:0 50px}.as-intensity-cue[data-v-7a449788]{width:calc(100% - 100px);margin:10px 50px 0}.as-icon-label[data-v-7a449788]{font-size:10px;max-width:60px}}
1
+ .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 white;box-shadow:0 0 12px #212121}.as-slider::-webkit-slider-thumb:active{background:#505050;border:2px solid white}.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 white;box-shadow:0 0 12px #212121}.as-slider::-moz-range-thumb:active{background:#505050;border:2px solid white}.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 white;box-shadow:0 0 12px #212121}.as-slider::-ms-thumb:active{background:#505050;border:2px solid white}.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}}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@konbraphat51/affectiveslidervue",
3
- "version": "0.0.4",
3
+ "version": "0.0.5",
4
4
  "type": "module",
5
5
  "main": "./dist/affective-slider-vue.umd.js",
6
6
  "module": "./dist/affective-slider-vue.es.js",
@@ -166,7 +166,7 @@ watch(() => props.arousalValue, (newVal) => {
166
166
  })
167
167
  </script>
168
168
 
169
- <style scoped>
169
+ <style>
170
170
  .affective-slider {
171
171
  width: 100%;
172
172
  max-width: 800px;