masoneffect 2.0.5 → 2.0.7

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.
Files changed (308) hide show
  1. package/README.md +170 -2
  2. package/dist/core/index.d.ts +3 -0
  3. package/dist/core/index.d.ts.map +1 -1
  4. package/dist/core/scrollFadeIn/index.d.ts +57 -0
  5. package/dist/core/scrollFadeIn/index.d.ts.map +1 -0
  6. package/dist/core/textToParticle/index.d.ts.map +1 -1
  7. package/dist/count/core/index.d.ts +3 -0
  8. package/dist/count/core/index.d.ts.map +1 -1
  9. package/dist/count/core/scrollFadeIn/index.d.ts +57 -0
  10. package/dist/count/core/scrollFadeIn/index.d.ts.map +1 -0
  11. package/dist/count/core/textToParticle/index.d.ts.map +1 -1
  12. package/dist/count/index.d.ts +3 -0
  13. package/dist/count/index.d.ts.map +1 -1
  14. package/dist/count/react/MasonEffect.d.ts.map +1 -1
  15. package/dist/count/react/index.d.ts +3 -0
  16. package/dist/count/react/index.d.ts.map +1 -1
  17. package/dist/count/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  18. package/dist/count/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  19. package/dist/count/react/scrollFadeIn/index.d.ts +5 -0
  20. package/dist/count/react/scrollFadeIn/index.d.ts.map +1 -0
  21. package/dist/count/react/textToParticle/TextToParticle.d.ts.map +1 -1
  22. package/dist/count/svelte/index.d.ts +1 -0
  23. package/dist/count/svelte/index.d.ts.map +1 -1
  24. package/dist/count/svelte/scrollFadeIn/index.d.ts +2 -0
  25. package/dist/count/svelte/scrollFadeIn/index.d.ts.map +1 -0
  26. package/dist/count/vue/index.d.ts +1 -0
  27. package/dist/count/vue/index.d.ts.map +1 -1
  28. package/dist/count/vue/scrollFadeIn/index.d.ts +2 -0
  29. package/dist/count/vue/scrollFadeIn/index.d.ts.map +1 -0
  30. package/dist/index.cjs +1 -1
  31. package/dist/index.d.ts +3 -0
  32. package/dist/index.d.ts.map +1 -1
  33. package/dist/index.mjs +1 -1
  34. package/dist/index.umd.min.js +1 -1
  35. package/dist/react/MasonEffect.d.ts.map +1 -1
  36. package/dist/react/core/index.d.ts +3 -0
  37. package/dist/react/core/scrollFadeIn/index.d.ts +56 -0
  38. package/dist/react/count/core/index.d.ts +3 -0
  39. package/dist/react/count/core/index.d.ts.map +1 -1
  40. package/dist/react/count/core/scrollFadeIn/index.d.ts +57 -0
  41. package/dist/react/count/core/scrollFadeIn/index.d.ts.map +1 -0
  42. package/dist/react/count/core/textToParticle/index.d.ts.map +1 -1
  43. package/dist/react/count/index.d.ts +3 -0
  44. package/dist/react/count/index.d.ts.map +1 -1
  45. package/dist/react/count/react/MasonEffect.d.ts.map +1 -1
  46. package/dist/react/count/react/index.d.ts +3 -0
  47. package/dist/react/count/react/index.d.ts.map +1 -1
  48. package/dist/react/count/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  49. package/dist/react/count/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  50. package/dist/react/count/react/scrollFadeIn/index.d.ts +5 -0
  51. package/dist/react/count/react/scrollFadeIn/index.d.ts.map +1 -0
  52. package/dist/react/count/react/textToParticle/TextToParticle.d.ts.map +1 -1
  53. package/dist/react/count/svelte/index.d.ts +1 -0
  54. package/dist/react/count/svelte/index.d.ts.map +1 -1
  55. package/dist/react/count/svelte/scrollFadeIn/index.d.ts +2 -0
  56. package/dist/react/count/svelte/scrollFadeIn/index.d.ts.map +1 -0
  57. package/dist/react/count/vue/index.d.ts +1 -0
  58. package/dist/react/count/vue/index.d.ts.map +1 -1
  59. package/dist/react/count/vue/scrollFadeIn/index.d.ts +2 -0
  60. package/dist/react/count/vue/scrollFadeIn/index.d.ts.map +1 -0
  61. package/dist/react/index.cjs +6 -0
  62. package/dist/react/index.d.ts.map +1 -1
  63. package/dist/react/index.mjs +1 -0
  64. package/dist/react/react/index.d.ts +3 -0
  65. package/dist/react/react/scrollFadeIn/ScrollFadeIn.d.ts +18 -0
  66. package/dist/react/react/scrollFadeIn/index.d.ts +4 -0
  67. package/dist/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  68. package/dist/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  69. package/dist/react/scrollFadeIn/core/count/index.d.ts +53 -0
  70. package/dist/react/scrollFadeIn/core/count/index.d.ts.map +1 -0
  71. package/dist/react/scrollFadeIn/core/index.d.ts +23 -0
  72. package/dist/react/scrollFadeIn/core/index.d.ts.map +1 -0
  73. package/dist/react/scrollFadeIn/core/scrollFadeIn/index.d.ts +57 -0
  74. package/dist/react/scrollFadeIn/core/scrollFadeIn/index.d.ts.map +1 -0
  75. package/dist/react/scrollFadeIn/core/textToParticle/index.d.ts +103 -0
  76. package/dist/react/scrollFadeIn/core/textToParticle/index.d.ts.map +1 -0
  77. package/dist/react/scrollFadeIn/core/typing/index.d.ts +54 -0
  78. package/dist/react/scrollFadeIn/core/typing/index.d.ts.map +1 -0
  79. package/dist/react/scrollFadeIn/core/utils/visibilityManager.d.ts +35 -0
  80. package/dist/react/scrollFadeIn/core/utils/visibilityManager.d.ts.map +1 -0
  81. package/dist/react/scrollFadeIn/index.cjs +1 -0
  82. package/dist/react/scrollFadeIn/index.d.ts +21 -0
  83. package/dist/react/scrollFadeIn/index.d.ts.map +1 -0
  84. package/dist/react/scrollFadeIn/index.mjs +1 -0
  85. package/dist/react/scrollFadeIn/index.umd.d.ts +7 -0
  86. package/dist/react/scrollFadeIn/index.umd.d.ts.map +1 -0
  87. package/dist/react/scrollFadeIn/react/MasonEffect.d.ts +32 -0
  88. package/dist/react/scrollFadeIn/react/MasonEffect.d.ts.map +1 -0
  89. package/dist/react/scrollFadeIn/react/count/Count.d.ts +19 -0
  90. package/dist/react/scrollFadeIn/react/count/Count.d.ts.map +1 -0
  91. package/dist/react/scrollFadeIn/react/count/index.d.ts +5 -0
  92. package/dist/react/scrollFadeIn/react/count/index.d.ts.map +1 -0
  93. package/dist/react/scrollFadeIn/react/index.d.ts +17 -0
  94. package/dist/react/scrollFadeIn/react/index.d.ts.map +1 -0
  95. package/dist/react/scrollFadeIn/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  96. package/dist/react/scrollFadeIn/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  97. package/dist/react/scrollFadeIn/react/scrollFadeIn/index.d.ts +5 -0
  98. package/dist/react/scrollFadeIn/react/scrollFadeIn/index.d.ts.map +1 -0
  99. package/dist/react/scrollFadeIn/react/textToParticle/TextToParticle.d.ts +15 -0
  100. package/dist/react/scrollFadeIn/react/textToParticle/TextToParticle.d.ts.map +1 -0
  101. package/dist/react/scrollFadeIn/react/textToParticle/index.d.ts +4 -0
  102. package/dist/react/scrollFadeIn/react/textToParticle/index.d.ts.map +1 -0
  103. package/dist/react/scrollFadeIn/react/typing/Typing.d.ts +18 -0
  104. package/dist/react/scrollFadeIn/react/typing/Typing.d.ts.map +1 -0
  105. package/dist/react/scrollFadeIn/react/typing/index.d.ts +4 -0
  106. package/dist/react/scrollFadeIn/react/typing/index.d.ts.map +1 -0
  107. package/dist/react/scrollFadeIn/svelte/count/index.d.ts +2 -0
  108. package/dist/react/scrollFadeIn/svelte/count/index.d.ts.map +1 -0
  109. package/dist/react/scrollFadeIn/svelte/index.d.ts +10 -0
  110. package/dist/react/scrollFadeIn/svelte/index.d.ts.map +1 -0
  111. package/dist/react/scrollFadeIn/svelte/scrollFadeIn/index.d.ts +2 -0
  112. package/dist/react/scrollFadeIn/svelte/scrollFadeIn/index.d.ts.map +1 -0
  113. package/dist/react/scrollFadeIn/svelte/textToParticle/index.d.ts +2 -0
  114. package/dist/react/scrollFadeIn/svelte/textToParticle/index.d.ts.map +1 -0
  115. package/dist/react/scrollFadeIn/svelte/typing/index.d.ts +3 -0
  116. package/dist/react/scrollFadeIn/svelte/typing/index.d.ts.map +1 -0
  117. package/dist/react/scrollFadeIn/vue/count/index.d.ts +2 -0
  118. package/dist/react/scrollFadeIn/vue/count/index.d.ts.map +1 -0
  119. package/dist/react/scrollFadeIn/vue/index.d.ts +10 -0
  120. package/dist/react/scrollFadeIn/vue/index.d.ts.map +1 -0
  121. package/dist/react/scrollFadeIn/vue/scrollFadeIn/index.d.ts +2 -0
  122. package/dist/react/scrollFadeIn/vue/scrollFadeIn/index.d.ts.map +1 -0
  123. package/dist/react/scrollFadeIn/vue/textToParticle/index.d.ts +2 -0
  124. package/dist/react/scrollFadeIn/vue/textToParticle/index.d.ts.map +1 -0
  125. package/dist/react/scrollFadeIn/vue/typing/index.d.ts +4 -0
  126. package/dist/react/scrollFadeIn/vue/typing/index.d.ts.map +1 -0
  127. package/dist/react/svelte/index.d.ts +1 -0
  128. package/dist/react/svelte/scrollFadeIn/index.d.ts +1 -0
  129. package/dist/react/textToParticle/TextToParticle.d.ts.map +1 -1
  130. package/dist/react/textToParticle/core/index.d.ts +3 -0
  131. package/dist/react/textToParticle/core/index.d.ts.map +1 -1
  132. package/dist/react/textToParticle/core/scrollFadeIn/index.d.ts +57 -0
  133. package/dist/react/textToParticle/core/scrollFadeIn/index.d.ts.map +1 -0
  134. package/dist/react/textToParticle/core/textToParticle/index.d.ts.map +1 -1
  135. package/dist/react/textToParticle/index.cjs +1 -1
  136. package/dist/react/textToParticle/index.d.ts +3 -0
  137. package/dist/react/textToParticle/index.d.ts.map +1 -1
  138. package/dist/react/textToParticle/index.mjs +1 -1
  139. package/dist/react/textToParticle/react/MasonEffect.d.ts.map +1 -1
  140. package/dist/react/textToParticle/react/index.d.ts +3 -0
  141. package/dist/react/textToParticle/react/index.d.ts.map +1 -1
  142. package/dist/react/textToParticle/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  143. package/dist/react/textToParticle/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  144. package/dist/react/textToParticle/react/scrollFadeIn/index.d.ts +5 -0
  145. package/dist/react/textToParticle/react/scrollFadeIn/index.d.ts.map +1 -0
  146. package/dist/react/textToParticle/react/textToParticle/TextToParticle.d.ts.map +1 -1
  147. package/dist/react/textToParticle/svelte/index.d.ts +1 -0
  148. package/dist/react/textToParticle/svelte/index.d.ts.map +1 -1
  149. package/dist/react/textToParticle/svelte/scrollFadeIn/index.d.ts +2 -0
  150. package/dist/react/textToParticle/svelte/scrollFadeIn/index.d.ts.map +1 -0
  151. package/dist/react/textToParticle/vue/index.d.ts +1 -0
  152. package/dist/react/textToParticle/vue/index.d.ts.map +1 -1
  153. package/dist/react/textToParticle/vue/scrollFadeIn/index.d.ts +2 -0
  154. package/dist/react/textToParticle/vue/scrollFadeIn/index.d.ts.map +1 -0
  155. package/dist/react/typing/core/index.d.ts +3 -0
  156. package/dist/react/typing/core/index.d.ts.map +1 -1
  157. package/dist/react/typing/core/scrollFadeIn/index.d.ts +57 -0
  158. package/dist/react/typing/core/scrollFadeIn/index.d.ts.map +1 -0
  159. package/dist/react/typing/core/textToParticle/index.d.ts.map +1 -1
  160. package/dist/react/typing/index.d.ts +3 -0
  161. package/dist/react/typing/index.d.ts.map +1 -1
  162. package/dist/react/typing/react/MasonEffect.d.ts.map +1 -1
  163. package/dist/react/typing/react/index.d.ts +3 -0
  164. package/dist/react/typing/react/index.d.ts.map +1 -1
  165. package/dist/react/typing/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  166. package/dist/react/typing/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  167. package/dist/react/typing/react/scrollFadeIn/index.d.ts +5 -0
  168. package/dist/react/typing/react/scrollFadeIn/index.d.ts.map +1 -0
  169. package/dist/react/typing/react/textToParticle/TextToParticle.d.ts.map +1 -1
  170. package/dist/react/typing/svelte/index.d.ts +1 -0
  171. package/dist/react/typing/svelte/index.d.ts.map +1 -1
  172. package/dist/react/typing/svelte/scrollFadeIn/index.d.ts +2 -0
  173. package/dist/react/typing/svelte/scrollFadeIn/index.d.ts.map +1 -0
  174. package/dist/react/typing/vue/index.d.ts +1 -0
  175. package/dist/react/typing/vue/index.d.ts.map +1 -1
  176. package/dist/react/typing/vue/scrollFadeIn/index.d.ts +2 -0
  177. package/dist/react/typing/vue/scrollFadeIn/index.d.ts.map +1 -0
  178. package/dist/react/vue/index.d.ts +1 -0
  179. package/dist/react/vue/scrollFadeIn/index.d.ts +1 -0
  180. package/dist/scrollFadeIn/core/count/index.d.ts +53 -0
  181. package/dist/scrollFadeIn/core/count/index.d.ts.map +1 -0
  182. package/dist/scrollFadeIn/core/index.d.ts +23 -0
  183. package/dist/scrollFadeIn/core/index.d.ts.map +1 -0
  184. package/dist/scrollFadeIn/core/scrollFadeIn/index.d.ts +57 -0
  185. package/dist/scrollFadeIn/core/scrollFadeIn/index.d.ts.map +1 -0
  186. package/dist/scrollFadeIn/core/textToParticle/index.d.ts +103 -0
  187. package/dist/scrollFadeIn/core/textToParticle/index.d.ts.map +1 -0
  188. package/dist/scrollFadeIn/core/typing/index.d.ts +54 -0
  189. package/dist/scrollFadeIn/core/typing/index.d.ts.map +1 -0
  190. package/dist/scrollFadeIn/core/utils/visibilityManager.d.ts +35 -0
  191. package/dist/scrollFadeIn/core/utils/visibilityManager.d.ts.map +1 -0
  192. package/dist/scrollFadeIn/index.cjs +1 -0
  193. package/dist/scrollFadeIn/index.d.ts +21 -0
  194. package/dist/scrollFadeIn/index.d.ts.map +1 -0
  195. package/dist/scrollFadeIn/index.mjs +1 -0
  196. package/dist/scrollFadeIn/index.umd.d.ts +7 -0
  197. package/dist/scrollFadeIn/index.umd.d.ts.map +1 -0
  198. package/dist/scrollFadeIn/react/MasonEffect.d.ts +32 -0
  199. package/dist/scrollFadeIn/react/MasonEffect.d.ts.map +1 -0
  200. package/dist/scrollFadeIn/react/count/Count.d.ts +19 -0
  201. package/dist/scrollFadeIn/react/count/Count.d.ts.map +1 -0
  202. package/dist/scrollFadeIn/react/count/index.d.ts +5 -0
  203. package/dist/scrollFadeIn/react/count/index.d.ts.map +1 -0
  204. package/dist/scrollFadeIn/react/index.d.ts +17 -0
  205. package/dist/scrollFadeIn/react/index.d.ts.map +1 -0
  206. package/dist/scrollFadeIn/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  207. package/dist/scrollFadeIn/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  208. package/dist/scrollFadeIn/react/scrollFadeIn/index.d.ts +5 -0
  209. package/dist/scrollFadeIn/react/scrollFadeIn/index.d.ts.map +1 -0
  210. package/dist/scrollFadeIn/react/textToParticle/TextToParticle.d.ts +15 -0
  211. package/dist/scrollFadeIn/react/textToParticle/TextToParticle.d.ts.map +1 -0
  212. package/dist/scrollFadeIn/react/textToParticle/index.d.ts +4 -0
  213. package/dist/scrollFadeIn/react/textToParticle/index.d.ts.map +1 -0
  214. package/dist/scrollFadeIn/react/typing/Typing.d.ts +18 -0
  215. package/dist/scrollFadeIn/react/typing/Typing.d.ts.map +1 -0
  216. package/dist/scrollFadeIn/react/typing/index.d.ts +4 -0
  217. package/dist/scrollFadeIn/react/typing/index.d.ts.map +1 -0
  218. package/dist/scrollFadeIn/svelte/count/index.d.ts +2 -0
  219. package/dist/scrollFadeIn/svelte/count/index.d.ts.map +1 -0
  220. package/dist/scrollFadeIn/svelte/index.d.ts +10 -0
  221. package/dist/scrollFadeIn/svelte/index.d.ts.map +1 -0
  222. package/dist/scrollFadeIn/svelte/scrollFadeIn/index.d.ts +2 -0
  223. package/dist/scrollFadeIn/svelte/scrollFadeIn/index.d.ts.map +1 -0
  224. package/dist/scrollFadeIn/svelte/textToParticle/index.d.ts +2 -0
  225. package/dist/scrollFadeIn/svelte/textToParticle/index.d.ts.map +1 -0
  226. package/dist/scrollFadeIn/svelte/typing/index.d.ts +3 -0
  227. package/dist/scrollFadeIn/svelte/typing/index.d.ts.map +1 -0
  228. package/dist/scrollFadeIn/vue/count/index.d.ts +2 -0
  229. package/dist/scrollFadeIn/vue/count/index.d.ts.map +1 -0
  230. package/dist/scrollFadeIn/vue/index.d.ts +10 -0
  231. package/dist/scrollFadeIn/vue/index.d.ts.map +1 -0
  232. package/dist/scrollFadeIn/vue/scrollFadeIn/index.d.ts +2 -0
  233. package/dist/scrollFadeIn/vue/scrollFadeIn/index.d.ts.map +1 -0
  234. package/dist/scrollFadeIn/vue/textToParticle/index.d.ts +2 -0
  235. package/dist/scrollFadeIn/vue/textToParticle/index.d.ts.map +1 -0
  236. package/dist/scrollFadeIn/vue/typing/index.d.ts +4 -0
  237. package/dist/scrollFadeIn/vue/typing/index.d.ts.map +1 -0
  238. package/dist/svelte/count/index.d.ts +44 -1
  239. package/dist/svelte/index.cjs +1 -1
  240. package/dist/svelte/index.d.ts +44 -1
  241. package/dist/svelte/index.mjs +556 -12
  242. package/dist/svelte/scrollFadeIn/index.cjs +1 -0
  243. package/dist/svelte/scrollFadeIn/index.d.ts +272 -0
  244. package/dist/svelte/scrollFadeIn/index.mjs +911 -0
  245. package/dist/svelte/textToParticle/index.cjs +1 -1
  246. package/dist/svelte/textToParticle/index.d.ts +44 -1
  247. package/dist/svelte/textToParticle/index.mjs +3 -2
  248. package/dist/svelte/typing/index.d.ts +44 -1
  249. package/dist/textToParticle/core/index.d.ts +3 -0
  250. package/dist/textToParticle/core/index.d.ts.map +1 -1
  251. package/dist/textToParticle/core/scrollFadeIn/index.d.ts +57 -0
  252. package/dist/textToParticle/core/scrollFadeIn/index.d.ts.map +1 -0
  253. package/dist/textToParticle/core/textToParticle/index.d.ts.map +1 -1
  254. package/dist/textToParticle/index.cjs +1 -1
  255. package/dist/textToParticle/index.d.ts +3 -0
  256. package/dist/textToParticle/index.d.ts.map +1 -1
  257. package/dist/textToParticle/index.mjs +1 -1
  258. package/dist/textToParticle/react/MasonEffect.d.ts.map +1 -1
  259. package/dist/textToParticle/react/index.d.ts +3 -0
  260. package/dist/textToParticle/react/index.d.ts.map +1 -1
  261. package/dist/textToParticle/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  262. package/dist/textToParticle/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  263. package/dist/textToParticle/react/scrollFadeIn/index.d.ts +5 -0
  264. package/dist/textToParticle/react/scrollFadeIn/index.d.ts.map +1 -0
  265. package/dist/textToParticle/react/textToParticle/TextToParticle.d.ts.map +1 -1
  266. package/dist/textToParticle/svelte/index.d.ts +1 -0
  267. package/dist/textToParticle/svelte/index.d.ts.map +1 -1
  268. package/dist/textToParticle/svelte/scrollFadeIn/index.d.ts +2 -0
  269. package/dist/textToParticle/svelte/scrollFadeIn/index.d.ts.map +1 -0
  270. package/dist/textToParticle/vue/index.d.ts +1 -0
  271. package/dist/textToParticle/vue/index.d.ts.map +1 -1
  272. package/dist/textToParticle/vue/scrollFadeIn/index.d.ts +2 -0
  273. package/dist/textToParticle/vue/scrollFadeIn/index.d.ts.map +1 -0
  274. package/dist/typing/core/index.d.ts +3 -0
  275. package/dist/typing/core/index.d.ts.map +1 -1
  276. package/dist/typing/core/scrollFadeIn/index.d.ts +57 -0
  277. package/dist/typing/core/scrollFadeIn/index.d.ts.map +1 -0
  278. package/dist/typing/core/textToParticle/index.d.ts.map +1 -1
  279. package/dist/typing/index.d.ts +3 -0
  280. package/dist/typing/index.d.ts.map +1 -1
  281. package/dist/typing/react/MasonEffect.d.ts.map +1 -1
  282. package/dist/typing/react/index.d.ts +3 -0
  283. package/dist/typing/react/index.d.ts.map +1 -1
  284. package/dist/typing/react/scrollFadeIn/ScrollFadeIn.d.ts +19 -0
  285. package/dist/typing/react/scrollFadeIn/ScrollFadeIn.d.ts.map +1 -0
  286. package/dist/typing/react/scrollFadeIn/index.d.ts +5 -0
  287. package/dist/typing/react/scrollFadeIn/index.d.ts.map +1 -0
  288. package/dist/typing/react/textToParticle/TextToParticle.d.ts.map +1 -1
  289. package/dist/typing/svelte/index.d.ts +1 -0
  290. package/dist/typing/svelte/index.d.ts.map +1 -1
  291. package/dist/typing/svelte/scrollFadeIn/index.d.ts +2 -0
  292. package/dist/typing/svelte/scrollFadeIn/index.d.ts.map +1 -0
  293. package/dist/typing/vue/index.d.ts +1 -0
  294. package/dist/typing/vue/index.d.ts.map +1 -1
  295. package/dist/typing/vue/scrollFadeIn/index.d.ts +2 -0
  296. package/dist/typing/vue/scrollFadeIn/index.d.ts.map +1 -0
  297. package/dist/vue/count/index.d.ts +44 -1
  298. package/dist/vue/index.cjs +1 -1
  299. package/dist/vue/index.d.ts +44 -1
  300. package/dist/vue/index.mjs +357 -13
  301. package/dist/vue/scrollFadeIn/index.cjs +1 -0
  302. package/dist/vue/scrollFadeIn/index.d.ts +272 -0
  303. package/dist/vue/scrollFadeIn/index.mjs +447 -0
  304. package/dist/vue/textToParticle/index.cjs +1 -1
  305. package/dist/vue/textToParticle/index.d.ts +44 -1
  306. package/dist/vue/textToParticle/index.mjs +3 -2
  307. package/dist/vue/typing/index.d.ts +44 -1
  308. package/package.json +26 -2
@@ -0,0 +1,272 @@
1
+ export declare class Count {
2
+ container: HTMLElement;
3
+ config: Required<Omit<CountOptions, 'onUpdate' | 'onComplete'>> & {
4
+ onUpdate: CountOptions['onUpdate'];
5
+ onComplete: CountOptions['onComplete'];
6
+ };
7
+ currentValue: number;
8
+ startTime: number | null;
9
+ animationFrameId: number | null;
10
+ visibilityManager: VisibilityManager | null;
11
+ isRunning: boolean;
12
+ hasTriggered: boolean;
13
+ constructor(container: HTMLElement | string, options: CountOptions);
14
+ init(): void;
15
+ setupVisibilityManager(): void;
16
+ start(): void;
17
+ stop(): void;
18
+ reset(): void;
19
+ updateDisplay(value: number): void;
20
+ formatNumber(value: number): string;
21
+ updateConfig(newConfig: Partial<CountOptions>): void;
22
+ getValue(): number;
23
+ destroy(): void;
24
+ }
25
+
26
+ export declare interface CountOptions {
27
+ targetValue: number;
28
+ duration?: number;
29
+ startValue?: number;
30
+ enabled?: boolean;
31
+ easing?: (t: number) => number;
32
+ threshold?: number;
33
+ rootMargin?: string;
34
+ triggerOnce?: boolean;
35
+ onUpdate?: (value: number) => void;
36
+ onComplete?: () => void;
37
+ }
38
+
39
+ declare const easingFunctions: {
40
+ linear: (t: number) => number;
41
+ easeInQuad: (t: number) => number;
42
+ easeOutQuad: (t: number) => number;
43
+ easeInOutQuad: (t: number) => number;
44
+ easeOutCubic: (t: number) => number;
45
+ };
46
+ export { easingFunctions }
47
+ export { easingFunctions as scrollFadeInEasingFunctions }
48
+
49
+ export declare interface Particle {
50
+ x: number;
51
+ y: number;
52
+ vx: number;
53
+ vy: number;
54
+ tx: number;
55
+ ty: number;
56
+ initialX?: number;
57
+ initialY?: number;
58
+ j: number;
59
+ }
60
+
61
+ export declare class ScrollFadeIn {
62
+ container: HTMLElement;
63
+ config: Required<Omit<ScrollFadeInOptions, 'onStart' | 'onComplete' | 'easing'>> & {
64
+ easing: (t: number) => number;
65
+ onStart: ScrollFadeInOptions['onStart'];
66
+ onComplete: ScrollFadeInOptions['onComplete'];
67
+ };
68
+ visibilityManager: VisibilityManager | null;
69
+ animationFrameId: number | null;
70
+ startTime: number | null;
71
+ isRunning: boolean;
72
+ hasTriggered: boolean;
73
+ initialTransform: string;
74
+ targetDistance: number;
75
+ constructor(container: HTMLElement | string, options?: ScrollFadeInOptions);
76
+ init(): void;
77
+ parseDistance(distance: string): number;
78
+ setInitialPosition(): void;
79
+ setupVisibilityManager(): void;
80
+ start(): void;
81
+ animate(): void;
82
+ complete(): void;
83
+ reset(): void;
84
+ stop(): void;
85
+ updateConfig(newConfig: Partial<ScrollFadeInOptions>): void;
86
+ destroy(): void;
87
+ }
88
+
89
+ export declare interface ScrollFadeInOptions {
90
+ direction?: 'top' | 'right' | 'bottom' | 'left';
91
+ distance?: string;
92
+ duration?: number;
93
+ easing?: (t: number) => number;
94
+ threshold?: number;
95
+ rootMargin?: string;
96
+ triggerOnce?: boolean;
97
+ enabled?: boolean;
98
+ onStart?: () => void;
99
+ onComplete?: () => void;
100
+ }
101
+
102
+ declare class TextToParticle {
103
+ container: HTMLElement;
104
+ config: Required<Omit<TextToParticleOptions, 'onReady' | 'onUpdate' | 'debounceDelay'>> & {
105
+ onReady: TextToParticleOptions['onReady'];
106
+ onUpdate: TextToParticleOptions['onUpdate'];
107
+ };
108
+ canvas: HTMLCanvasElement;
109
+ ctx: CanvasRenderingContext2D;
110
+ offCanvas: HTMLCanvasElement;
111
+ offCtx: CanvasRenderingContext2D;
112
+ W: number;
113
+ H: number;
114
+ DPR: number;
115
+ particles: Particle[];
116
+ mouse: {
117
+ x: number;
118
+ y: number;
119
+ down: boolean;
120
+ };
121
+ animationId: number | null;
122
+ isRunning: boolean;
123
+ visibilityManager: VisibilityManager | null;
124
+ debounceDelay: number;
125
+ _debouncedMorph: (textOrOptions?: string | Partial<TextToParticleOptions> | null) => void;
126
+ _debouncedUpdateConfig: (newConfig: Partial<TextToParticleOptions>) => void;
127
+ constructor(container: HTMLElement | string, options?: TextToParticleOptions);
128
+ init(): void;
129
+ setupVisibilityManager(): void;
130
+ resize(): void;
131
+ /**
132
+ * 텍스트가 영역 안에 들어가는지 확인하는 헬퍼 함수 (줄바꿈 지원)
133
+ * @param fontSize 확인할 폰트 크기
134
+ * @param text 텍스트 (\n으로 줄바꿈 구분)
135
+ * @param maxWidth 최대 너비
136
+ * @param maxHeight 최대 높이
137
+ * @returns { width: number, height: number, fits: boolean }
138
+ */
139
+ private measureTextFit;
140
+ /**
141
+ * 이진 검색을 사용하여 적절한 폰트 크기를 찾는 최적화된 함수
142
+ * 반복 횟수를 O(log n)으로 줄여 성능 개선 (최대 15회 반복, 기존 최대 100회에서 대폭 감소)
143
+ */
144
+ private findOptimalFontSize;
145
+ buildTargets(): void;
146
+ makeParticle(): Particle;
147
+ initParticles(): void;
148
+ scatter(): void;
149
+ morph(textOrOptions?: string | Partial<TextToParticleOptions> | null): void;
150
+ _morphInternal(textOrOptions?: string | Partial<TextToParticleOptions> | null): void;
151
+ update(): void;
152
+ animate(): void;
153
+ start(): void;
154
+ stop(): void;
155
+ setupEventListeners(): void;
156
+ removeEventListeners(): void;
157
+ handleResize(): void;
158
+ handleMouseMove(e: MouseEvent): void;
159
+ handleMouseLeave(): void;
160
+ handleMouseDown(): void;
161
+ handleMouseUp(): void;
162
+ updateConfig(newConfig: Partial<TextToParticleOptions>): void;
163
+ _updateConfigInternal(newConfig: Partial<TextToParticleOptions>): void;
164
+ destroy(): void;
165
+ }
166
+ export { TextToParticle as MasonEffect }
167
+ export { TextToParticle }
168
+ export default TextToParticle;
169
+
170
+ declare interface TextToParticleOptions {
171
+ text?: string;
172
+ densityStep?: number;
173
+ maxParticles?: number;
174
+ pointSize?: number;
175
+ ease?: number;
176
+ repelRadius?: number;
177
+ repelStrength?: number;
178
+ particleColor?: string;
179
+ fontFamily?: string;
180
+ fontSize?: number | null;
181
+ width?: number | null;
182
+ height?: number | null;
183
+ devicePixelRatio?: number | null;
184
+ debounceDelay?: number;
185
+ onReady?: (instance: TextToParticle) => void;
186
+ onUpdate?: (instance: TextToParticle) => void;
187
+ }
188
+ export { TextToParticleOptions as MasonEffectOptions }
189
+ export { TextToParticleOptions }
190
+
191
+ export declare class Typing {
192
+ container: HTMLElement;
193
+ config: Required<Omit<TypingOptions, 'onUpdate' | 'onComplete'>> & {
194
+ onUpdate: TypingOptions['onUpdate'];
195
+ onComplete: TypingOptions['onComplete'];
196
+ };
197
+ textUnits: string[];
198
+ charUnitRanges: Array<{
199
+ start: number;
200
+ end: number;
201
+ isHangul: boolean;
202
+ }>;
203
+ currentIndex: number;
204
+ displayedText: string;
205
+ timeoutId: ReturnType<typeof setTimeout> | null;
206
+ visibilityManager: VisibilityManager | null;
207
+ isRunning: boolean;
208
+ hasTriggered: boolean;
209
+ originalText: string;
210
+ constructor(container: HTMLElement | string, options: TypingOptions);
211
+ init(): void;
212
+ setupVisibilityManager(): void;
213
+ private buildTextFromUnits;
214
+ start(): void;
215
+ typeNext(): void;
216
+ stop(): void;
217
+ reset(): void;
218
+ updateDisplay(text: string): void;
219
+ setText(newText: string): void;
220
+ destroy(): void;
221
+ }
222
+
223
+ export declare interface TypingOptions {
224
+ text: string;
225
+ speed?: number;
226
+ delay?: number;
227
+ enabled?: boolean;
228
+ threshold?: number;
229
+ rootMargin?: string;
230
+ triggerOnce?: boolean;
231
+ showCursor?: boolean;
232
+ cursorChar?: string;
233
+ onUpdate?: (text: string) => void;
234
+ onComplete?: () => void;
235
+ }
236
+
237
+ declare class VisibilityManager {
238
+ private container;
239
+ private options;
240
+ private intersectionObserver;
241
+ private visibilityChangeHandler;
242
+ private isVisible;
243
+ private isPageVisible;
244
+ constructor(container: HTMLElement, options?: VisibilityManagerOptions);
245
+ private setupIntersectionObserver;
246
+ private setupPageVisibility;
247
+ /**
248
+ * 현재 요소가 화면에 보이는지 확인
249
+ */
250
+ getIsVisible(): boolean;
251
+ /**
252
+ * 옵션 업데이트
253
+ */
254
+ updateOptions(newOptions: Partial<VisibilityManagerOptions>): void;
255
+ /**
256
+ * 리소스 정리
257
+ */
258
+ destroy(): void;
259
+ }
260
+
261
+ /**
262
+ * VisibilityManager - IntersectionObserver와 Page Visibility API를 통합 관리
263
+ * 모든 효과에서 공통으로 사용하는 가시성 관리 유틸리티
264
+ */
265
+ declare interface VisibilityManagerOptions {
266
+ threshold?: number;
267
+ rootMargin?: string;
268
+ onVisible?: () => void;
269
+ onHidden?: () => void;
270
+ }
271
+
272
+ export { }
@@ -0,0 +1,447 @@
1
+ import { defineComponent, ref, watch, onMounted, onBeforeUnmount, createElementBlock, openBlock, normalizeStyle, normalizeClass, renderSlot } from "vue";
2
+ class VisibilityManager {
3
+ constructor(container, options = {}) {
4
+ this.container = container;
5
+ this.options = {
6
+ threshold: options.threshold ?? 0.1,
7
+ rootMargin: options.rootMargin ?? "0px",
8
+ onVisible: options.onVisible,
9
+ onHidden: options.onHidden
10
+ };
11
+ this.intersectionObserver = null;
12
+ this.visibilityChangeHandler = null;
13
+ this.isVisible = false;
14
+ this.isPageVisible = typeof document !== "undefined" ? !document.hidden : true;
15
+ this.setupIntersectionObserver();
16
+ this.setupPageVisibility();
17
+ }
18
+ setupIntersectionObserver() {
19
+ if (typeof window === "undefined" || typeof window.IntersectionObserver === "undefined") {
20
+ this.isVisible = true;
21
+ if (this.isPageVisible && this.options.onVisible) {
22
+ this.options.onVisible();
23
+ }
24
+ return;
25
+ }
26
+ this.intersectionObserver = new IntersectionObserver(
27
+ (entries) => {
28
+ for (const entry of entries) {
29
+ if (entry.target !== this.container) continue;
30
+ if (entry.isIntersecting) {
31
+ this.isVisible = true;
32
+ if (this.isPageVisible && this.options.onVisible) {
33
+ this.options.onVisible();
34
+ }
35
+ } else {
36
+ this.isVisible = false;
37
+ if (this.options.onHidden) {
38
+ this.options.onHidden();
39
+ }
40
+ }
41
+ }
42
+ },
43
+ {
44
+ threshold: this.options.threshold,
45
+ rootMargin: this.options.rootMargin
46
+ }
47
+ );
48
+ this.intersectionObserver.observe(this.container);
49
+ }
50
+ setupPageVisibility() {
51
+ if (typeof document === "undefined") return;
52
+ this.visibilityChangeHandler = () => {
53
+ const wasVisible = this.isPageVisible;
54
+ this.isPageVisible = !document.hidden;
55
+ if (document.hidden) {
56
+ if (this.options.onHidden) {
57
+ this.options.onHidden();
58
+ }
59
+ } else if (wasVisible !== this.isPageVisible) {
60
+ if (this.isVisible && this.options.onVisible) {
61
+ this.options.onVisible();
62
+ }
63
+ }
64
+ };
65
+ document.addEventListener("visibilitychange", this.visibilityChangeHandler);
66
+ if (document.hidden && this.isVisible) {
67
+ if (this.options.onHidden) {
68
+ this.options.onHidden();
69
+ }
70
+ }
71
+ }
72
+ /**
73
+ * 현재 요소가 화면에 보이는지 확인
74
+ */
75
+ getIsVisible() {
76
+ return this.isVisible && this.isPageVisible;
77
+ }
78
+ /**
79
+ * 옵션 업데이트
80
+ */
81
+ updateOptions(newOptions) {
82
+ this.options = { ...this.options, ...newOptions };
83
+ if (this.intersectionObserver) {
84
+ this.intersectionObserver.disconnect();
85
+ this.intersectionObserver = null;
86
+ }
87
+ this.setupIntersectionObserver();
88
+ }
89
+ /**
90
+ * 리소스 정리
91
+ */
92
+ destroy() {
93
+ if (this.intersectionObserver) {
94
+ this.intersectionObserver.disconnect();
95
+ this.intersectionObserver = null;
96
+ }
97
+ if (this.visibilityChangeHandler && typeof document !== "undefined") {
98
+ document.removeEventListener("visibilitychange", this.visibilityChangeHandler);
99
+ this.visibilityChangeHandler = null;
100
+ }
101
+ }
102
+ }
103
+ const easingFunctions = {
104
+ easeOutCubic: (t) => --t * t * t + 1
105
+ };
106
+ class ScrollFadeIn {
107
+ // 계산된 거리 (px)
108
+ constructor(container, options = {}) {
109
+ this.container = typeof container === "string" ? document.querySelector(container) : container;
110
+ if (!this.container) {
111
+ throw new Error("Container element not found");
112
+ }
113
+ this.config = {
114
+ direction: options.direction ?? "bottom",
115
+ distance: options.distance ?? "50px",
116
+ duration: options.duration ?? 800,
117
+ easing: options.easing ?? easingFunctions.easeOutCubic,
118
+ threshold: options.threshold ?? 0.1,
119
+ rootMargin: options.rootMargin ?? "0px",
120
+ triggerOnce: options.triggerOnce ?? false,
121
+ enabled: options.enabled ?? true,
122
+ onStart: options.onStart || null,
123
+ onComplete: options.onComplete || null
124
+ };
125
+ this.visibilityManager = null;
126
+ this.animationFrameId = null;
127
+ this.startTime = null;
128
+ this.isRunning = false;
129
+ this.hasTriggered = false;
130
+ this.initialTransform = "";
131
+ this.targetDistance = 0;
132
+ this.init();
133
+ }
134
+ init() {
135
+ const computedStyle = window.getComputedStyle(this.container);
136
+ this.initialTransform = computedStyle.transform !== "none" ? computedStyle.transform : this.container.style.transform || "";
137
+ this.targetDistance = this.parseDistance(this.config.distance);
138
+ this.setInitialPosition();
139
+ this.setupVisibilityManager();
140
+ }
141
+ parseDistance(distance) {
142
+ const match = distance.match(/^(-?\d+\.?\d*)(px|rem|em|%|vh|vw)$/);
143
+ if (!match) {
144
+ const num = parseFloat(distance) || 50;
145
+ return num;
146
+ }
147
+ const value = parseFloat(match[1]);
148
+ const unit = match[2];
149
+ switch (unit) {
150
+ case "px":
151
+ return value;
152
+ case "rem":
153
+ case "em":
154
+ const fontSize = parseFloat(getComputedStyle(document.documentElement).fontSize) || 16;
155
+ return value * fontSize;
156
+ case "%":
157
+ const rect = this.container.getBoundingClientRect();
158
+ const dimension = this.config.direction === "top" || this.config.direction === "bottom" ? rect.height : rect.width;
159
+ return value / 100 * dimension;
160
+ case "vh":
161
+ return value / 100 * window.innerHeight;
162
+ case "vw":
163
+ return value / 100 * window.innerWidth;
164
+ default:
165
+ return value;
166
+ }
167
+ }
168
+ setInitialPosition() {
169
+ const direction = this.config.direction;
170
+ let translateX = 0;
171
+ let translateY = 0;
172
+ switch (direction) {
173
+ case "top":
174
+ translateY = -this.targetDistance;
175
+ break;
176
+ case "right":
177
+ translateX = this.targetDistance;
178
+ break;
179
+ case "bottom":
180
+ translateY = this.targetDistance;
181
+ break;
182
+ case "left":
183
+ translateX = -this.targetDistance;
184
+ break;
185
+ }
186
+ const existingTransform = this.initialTransform || "";
187
+ const translate = `translate(${translateX}px, ${translateY}px)`;
188
+ if (existingTransform && existingTransform !== "none") {
189
+ this.container.style.transform = `${translate} ${existingTransform}`;
190
+ } else {
191
+ this.container.style.transform = translate;
192
+ }
193
+ this.container.style.opacity = "0";
194
+ this.container.style.transition = "none";
195
+ }
196
+ setupVisibilityManager() {
197
+ this.visibilityManager = new VisibilityManager(this.container, {
198
+ threshold: this.config.threshold,
199
+ rootMargin: this.config.rootMargin,
200
+ onVisible: () => {
201
+ if (!this.hasTriggered && this.config.enabled) {
202
+ this.hasTriggered = true;
203
+ this.start();
204
+ }
205
+ },
206
+ onHidden: () => {
207
+ if (!this.config.triggerOnce && this.isRunning) {
208
+ this.reset();
209
+ }
210
+ }
211
+ });
212
+ }
213
+ start() {
214
+ if (this.isRunning) return;
215
+ this.isRunning = true;
216
+ this.startTime = performance.now();
217
+ if (this.config.onStart) {
218
+ this.config.onStart();
219
+ }
220
+ this.container.style.transition = "none";
221
+ this.animate();
222
+ }
223
+ animate() {
224
+ if (!this.isRunning) return;
225
+ const currentTime = performance.now();
226
+ const elapsed = currentTime - (this.startTime || 0);
227
+ const progress = Math.min(elapsed / this.config.duration, 1);
228
+ const easedProgress = this.config.easing(progress);
229
+ const direction = this.config.direction;
230
+ let translateX = 0;
231
+ let translateY = 0;
232
+ switch (direction) {
233
+ case "top":
234
+ translateY = -this.targetDistance * (1 - easedProgress);
235
+ break;
236
+ case "right":
237
+ translateX = this.targetDistance * (1 - easedProgress);
238
+ break;
239
+ case "bottom":
240
+ translateY = this.targetDistance * (1 - easedProgress);
241
+ break;
242
+ case "left":
243
+ translateX = -this.targetDistance * (1 - easedProgress);
244
+ break;
245
+ }
246
+ const existingTransform = this.initialTransform || "";
247
+ const translate = `translate(${translateX}px, ${translateY}px)`;
248
+ if (existingTransform && existingTransform !== "none") {
249
+ this.container.style.transform = `${translate} ${existingTransform}`;
250
+ } else {
251
+ this.container.style.transform = translate;
252
+ }
253
+ this.container.style.opacity = String(easedProgress);
254
+ if (progress < 1) {
255
+ this.animationFrameId = requestAnimationFrame(() => this.animate());
256
+ } else {
257
+ this.complete();
258
+ }
259
+ }
260
+ complete() {
261
+ this.isRunning = false;
262
+ if (this.initialTransform && this.initialTransform !== "none") {
263
+ this.container.style.transform = this.initialTransform;
264
+ } else {
265
+ this.container.style.transform = "";
266
+ }
267
+ this.container.style.opacity = "1";
268
+ if (this.animationFrameId) {
269
+ cancelAnimationFrame(this.animationFrameId);
270
+ this.animationFrameId = null;
271
+ }
272
+ if (this.config.onComplete) {
273
+ this.config.onComplete();
274
+ }
275
+ }
276
+ reset() {
277
+ this.stop();
278
+ this.hasTriggered = false;
279
+ this.setInitialPosition();
280
+ }
281
+ stop() {
282
+ this.isRunning = false;
283
+ if (this.animationFrameId) {
284
+ cancelAnimationFrame(this.animationFrameId);
285
+ this.animationFrameId = null;
286
+ }
287
+ }
288
+ // 설정 업데이트
289
+ updateConfig(newConfig) {
290
+ const wasRunning = this.isRunning;
291
+ this.stop();
292
+ this.config = {
293
+ ...this.config,
294
+ ...newConfig,
295
+ easing: newConfig.easing ?? this.config.easing,
296
+ onStart: newConfig.onStart ?? this.config.onStart,
297
+ onComplete: newConfig.onComplete ?? this.config.onComplete
298
+ };
299
+ if (newConfig.distance) {
300
+ this.targetDistance = this.parseDistance(this.config.distance);
301
+ }
302
+ this.setInitialPosition();
303
+ if (newConfig.threshold !== void 0 || newConfig.rootMargin !== void 0) {
304
+ if (this.visibilityManager) {
305
+ this.visibilityManager.destroy();
306
+ this.visibilityManager = null;
307
+ }
308
+ this.setupVisibilityManager();
309
+ }
310
+ if (wasRunning && this.config.enabled) {
311
+ this.start();
312
+ }
313
+ }
314
+ // 파괴 및 정리
315
+ destroy() {
316
+ this.stop();
317
+ if (this.visibilityManager) {
318
+ this.visibilityManager.destroy();
319
+ this.visibilityManager = null;
320
+ }
321
+ this.container.style.transform = this.initialTransform || "";
322
+ this.container.style.opacity = "";
323
+ this.container.style.transition = "";
324
+ }
325
+ }
326
+ const _sfc_main = /* @__PURE__ */ defineComponent({
327
+ __name: "ScrollFadeIn",
328
+ props: {
329
+ className: { default: "" },
330
+ style: { default: () => ({}) },
331
+ direction: { default: "bottom" },
332
+ distance: { default: "50px" },
333
+ duration: { default: 800 },
334
+ easing: { type: Function, default: () => (t) => t },
335
+ threshold: { default: 0.1 },
336
+ rootMargin: { default: "0px" },
337
+ triggerOnce: { type: Boolean, default: false },
338
+ enabled: { type: Boolean, default: true },
339
+ onStart: { type: Function, default: null },
340
+ onComplete: { type: Function, default: null }
341
+ },
342
+ emits: ["start", "complete"],
343
+ setup(__props, { expose: __expose, emit: __emit }) {
344
+ const props = __props;
345
+ const emit = __emit;
346
+ const container = ref(null);
347
+ let instance = null;
348
+ const init = () => {
349
+ if (!container.value) return;
350
+ const options = {
351
+ direction: props.direction,
352
+ distance: props.distance,
353
+ duration: props.duration,
354
+ easing: props.easing,
355
+ threshold: props.threshold,
356
+ rootMargin: props.rootMargin,
357
+ triggerOnce: props.triggerOnce,
358
+ enabled: props.enabled,
359
+ onStart: () => {
360
+ if (props.onStart) props.onStart();
361
+ emit("start");
362
+ },
363
+ onComplete: () => {
364
+ if (props.onComplete) props.onComplete();
365
+ emit("complete");
366
+ }
367
+ };
368
+ instance = new ScrollFadeIn(container.value, options);
369
+ };
370
+ watch(
371
+ () => [
372
+ props.direction,
373
+ props.distance,
374
+ props.duration,
375
+ props.easing,
376
+ props.threshold,
377
+ props.rootMargin,
378
+ props.triggerOnce,
379
+ props.enabled
380
+ ],
381
+ () => {
382
+ if (instance) {
383
+ instance.updateConfig({
384
+ direction: props.direction,
385
+ distance: props.distance,
386
+ duration: props.duration,
387
+ easing: props.easing,
388
+ threshold: props.threshold,
389
+ rootMargin: props.rootMargin,
390
+ triggerOnce: props.triggerOnce,
391
+ enabled: props.enabled,
392
+ onStart: () => {
393
+ if (props.onStart) props.onStart();
394
+ emit("start");
395
+ },
396
+ onComplete: () => {
397
+ if (props.onComplete) props.onComplete();
398
+ emit("complete");
399
+ }
400
+ });
401
+ }
402
+ }
403
+ );
404
+ onMounted(() => {
405
+ init();
406
+ });
407
+ onBeforeUnmount(() => {
408
+ if (instance) {
409
+ instance.destroy();
410
+ instance = null;
411
+ }
412
+ });
413
+ __expose({
414
+ start: () => {
415
+ if (instance) instance.start();
416
+ },
417
+ stop: () => {
418
+ if (instance) instance.stop();
419
+ },
420
+ reset: () => {
421
+ if (instance) instance.reset();
422
+ },
423
+ updateConfig: (config) => {
424
+ if (instance) instance.updateConfig(config);
425
+ },
426
+ destroy: () => {
427
+ if (instance) {
428
+ instance.destroy();
429
+ instance = null;
430
+ }
431
+ }
432
+ });
433
+ return (_ctx, _cache) => {
434
+ return openBlock(), createElementBlock("div", {
435
+ ref_key: "container",
436
+ ref: container,
437
+ class: normalizeClass(__props.className),
438
+ style: normalizeStyle(__props.style)
439
+ }, [
440
+ renderSlot(_ctx.$slots, "default")
441
+ ], 6);
442
+ };
443
+ }
444
+ });
445
+ export {
446
+ _sfc_main as default
447
+ };