@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 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
- **Important:** You also need to import the CSS file in your application:
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 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 = {
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
- }, T = ["name", "id", "value", "onInput", "onMousedown", "onTouchstart"], Y = { class: "as-icon-wrapper as-icon-right" }, X = ["src", "alt"], Z = {
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
- }, k = { class: "as-intensity-cue" }, z = ["src"], O = {
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: (t) => t >= 0 && t <= 1
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: (t) => t >= 0 && t <= 1
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(t, { emit: m }) {
51
- const a = t, c = m, r = g(a.pleasureValue), l = g(a.arousalValue), i = g([]), p = g({
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
- }), 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) => ({
55
- type: A,
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 }));
66
- }, K = () => {
67
- const A = ["arousal", "pleasure"];
68
- a.randomizeOrder ? i.value = Math.random() > 0.5 ? [...A] : [...A].reverse() : i.value = ["pleasure", "arousal"];
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 q(() => {
71
- K();
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", {
78
- key: e.type,
79
- class: I(["as-container", e.type])
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
- s("div", H, [
82
- s("img", {
83
- src: e.leftImage,
84
- alt: `${e.type} left`,
81
+ t("div", J, [
82
+ t("img", {
83
+ src: a.leftImage,
84
+ alt: `${a.type} left`,
85
85
  class: "as-icon"
86
- }, null, 8, b),
87
- e.leftLabel ? (o(), n("div", G, w(e.leftLabel), 1)) : Q("", !0)
86
+ }, null, 8, U),
87
+ a.leftLabel ? (l(), o("div", P, C(a.leftLabel), 1)) : w("", !0)
88
88
  ]),
89
- s("input", {
89
+ t("input", {
90
90
  type: "range",
91
- name: `AS-${e.type}`,
92
- id: `AS-${e.type}`,
93
- value: e.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: (u) => v(e.type, u),
98
- onMousedown: (u) => C(e.type),
99
- onTouchstart: (u) => C(e.type),
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, T),
102
- s("div", Y, [
103
- s("img", {
104
- src: e.rightImage,
105
- alt: `${e.type} right`,
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, X),
108
- e.rightLabel ? (o(), n("div", Z, w(e.rightLabel), 1)) : Q("", !0)
107
+ }, null, 8, T),
108
+ a.rightLabel ? (l(), o("div", Y, C(a.rightLabel), 1)) : w("", !0)
109
109
  ]),
110
- s("div", k, [
111
- s("img", {
112
- src: S(U),
110
+ t("div", z, [
111
+ t("img", {
112
+ src: q(F),
113
113
  alt: "intensity cue"
114
- }, null, 8, z)
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
- O as AffectiveSlider,
122
- O as default
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.5",
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