masoneffect 2.0.2 → 2.0.4
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 +4 -4
- package/dist/core/index.d.ts +2 -0
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/typing/index.d.ts +53 -0
- package/dist/core/typing/index.d.ts.map +1 -0
- package/dist/count/core/index.d.ts +2 -0
- package/dist/count/core/index.d.ts.map +1 -1
- package/dist/count/core/typing/index.d.ts +53 -0
- package/dist/count/core/typing/index.d.ts.map +1 -0
- package/dist/count/index.d.ts +2 -0
- package/dist/count/index.d.ts.map +1 -1
- package/dist/count/react/index.d.ts +2 -0
- package/dist/count/react/index.d.ts.map +1 -1
- package/dist/count/react/typing/Typing.d.ts +18 -0
- package/dist/count/react/typing/Typing.d.ts.map +1 -0
- package/dist/count/react/typing/index.d.ts +4 -0
- package/dist/count/react/typing/index.d.ts.map +1 -0
- package/dist/count/svelte/index.d.ts +1 -0
- package/dist/count/svelte/index.d.ts.map +1 -1
- package/dist/count/svelte/typing/index.d.ts +3 -0
- package/dist/count/svelte/typing/index.d.ts.map +1 -0
- package/dist/count/vue/index.d.ts +1 -0
- package/dist/count/vue/index.d.ts.map +1 -1
- package/dist/count/vue/typing/index.d.ts +4 -0
- package/dist/count/vue/typing/index.d.ts.map +1 -0
- package/dist/index.cjs +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/react/core/index.d.ts +2 -0
- package/dist/react/core/typing/index.d.ts +52 -0
- package/dist/react/count/core/index.d.ts +2 -0
- package/dist/react/count/core/index.d.ts.map +1 -1
- package/dist/react/count/core/typing/index.d.ts +53 -0
- package/dist/react/count/core/typing/index.d.ts.map +1 -0
- package/dist/react/count/index.d.ts +2 -0
- package/dist/react/count/index.d.ts.map +1 -1
- package/dist/react/count/react/index.d.ts +2 -0
- package/dist/react/count/react/index.d.ts.map +1 -1
- package/dist/react/count/react/typing/Typing.d.ts +18 -0
- package/dist/react/count/react/typing/Typing.d.ts.map +1 -0
- package/dist/react/count/react/typing/index.d.ts +4 -0
- package/dist/react/count/react/typing/index.d.ts.map +1 -0
- package/dist/react/count/svelte/index.d.ts +1 -0
- package/dist/react/count/svelte/index.d.ts.map +1 -1
- package/dist/react/count/svelte/typing/index.d.ts +3 -0
- package/dist/react/count/svelte/typing/index.d.ts.map +1 -0
- package/dist/react/count/vue/index.d.ts +1 -0
- package/dist/react/count/vue/index.d.ts.map +1 -1
- package/dist/react/count/vue/typing/index.d.ts +4 -0
- package/dist/react/count/vue/typing/index.d.ts.map +1 -0
- package/dist/react/index.cjs +2 -0
- package/dist/react/index.d.ts.map +1 -1
- package/dist/react/index.mjs +1 -0
- package/dist/react/react/index.d.ts +2 -0
- package/dist/react/react/typing/Typing.d.ts +17 -0
- package/dist/react/react/typing/index.d.ts +3 -0
- package/dist/react/svelte/index.d.ts +1 -0
- package/dist/react/svelte/typing/index.d.ts +2 -0
- package/dist/react/textToParticle/core/index.d.ts +2 -0
- package/dist/react/textToParticle/core/index.d.ts.map +1 -1
- package/dist/react/textToParticle/core/typing/index.d.ts +53 -0
- package/dist/react/textToParticle/core/typing/index.d.ts.map +1 -0
- package/dist/react/textToParticle/index.d.ts +2 -0
- package/dist/react/textToParticle/index.d.ts.map +1 -1
- package/dist/react/textToParticle/react/index.d.ts +2 -0
- package/dist/react/textToParticle/react/index.d.ts.map +1 -1
- package/dist/react/textToParticle/react/typing/Typing.d.ts +18 -0
- package/dist/react/textToParticle/react/typing/Typing.d.ts.map +1 -0
- package/dist/react/textToParticle/react/typing/index.d.ts +4 -0
- package/dist/react/textToParticle/react/typing/index.d.ts.map +1 -0
- package/dist/react/textToParticle/svelte/index.d.ts +1 -0
- package/dist/react/textToParticle/svelte/index.d.ts.map +1 -1
- package/dist/react/textToParticle/svelte/typing/index.d.ts +3 -0
- package/dist/react/textToParticle/svelte/typing/index.d.ts.map +1 -0
- package/dist/react/textToParticle/vue/index.d.ts +1 -0
- package/dist/react/textToParticle/vue/index.d.ts.map +1 -1
- package/dist/react/textToParticle/vue/typing/index.d.ts +4 -0
- package/dist/react/textToParticle/vue/typing/index.d.ts.map +1 -0
- package/dist/react/typing/Typing.d.ts +18 -0
- package/dist/react/typing/Typing.d.ts.map +1 -0
- package/dist/react/typing/core/count/index.d.ts +52 -0
- package/dist/react/typing/core/count/index.d.ts.map +1 -0
- package/dist/react/typing/core/index.d.ts +20 -0
- package/dist/react/typing/core/index.d.ts.map +1 -0
- package/dist/react/typing/core/textToParticle/index.d.ts +103 -0
- package/dist/react/typing/core/textToParticle/index.d.ts.map +1 -0
- package/dist/react/typing/core/typing/index.d.ts +53 -0
- package/dist/react/typing/core/typing/index.d.ts.map +1 -0
- package/dist/react/typing/index.cjs +1 -0
- package/dist/react/typing/index.d.ts +18 -0
- package/dist/react/typing/index.d.ts.map +1 -0
- package/dist/react/typing/index.mjs +1 -0
- package/dist/react/typing/index.umd.d.ts +7 -0
- package/dist/react/typing/index.umd.d.ts.map +1 -0
- package/dist/react/typing/react/MasonEffect.d.ts +32 -0
- package/dist/react/typing/react/MasonEffect.d.ts.map +1 -0
- package/dist/react/typing/react/count/Count.d.ts +19 -0
- package/dist/react/typing/react/count/Count.d.ts.map +1 -0
- package/dist/react/typing/react/count/index.d.ts +5 -0
- package/dist/react/typing/react/count/index.d.ts.map +1 -0
- package/dist/react/typing/react/index.d.ts +14 -0
- package/dist/react/typing/react/index.d.ts.map +1 -0
- package/dist/react/typing/react/textToParticle/TextToParticle.d.ts +15 -0
- package/dist/react/typing/react/textToParticle/TextToParticle.d.ts.map +1 -0
- package/dist/react/typing/react/textToParticle/index.d.ts +4 -0
- package/dist/react/typing/react/textToParticle/index.d.ts.map +1 -0
- package/dist/react/typing/react/typing/Typing.d.ts +18 -0
- package/dist/react/typing/react/typing/Typing.d.ts.map +1 -0
- package/dist/react/typing/react/typing/index.d.ts +4 -0
- package/dist/react/typing/react/typing/index.d.ts.map +1 -0
- package/dist/react/typing/svelte/count/index.d.ts +2 -0
- package/dist/react/typing/svelte/count/index.d.ts.map +1 -0
- package/dist/react/typing/svelte/index.d.ts +9 -0
- package/dist/react/typing/svelte/index.d.ts.map +1 -0
- package/dist/react/typing/svelte/textToParticle/index.d.ts +2 -0
- package/dist/react/typing/svelte/textToParticle/index.d.ts.map +1 -0
- package/dist/react/typing/svelte/typing/index.d.ts +3 -0
- package/dist/react/typing/svelte/typing/index.d.ts.map +1 -0
- package/dist/react/typing/vue/count/index.d.ts +2 -0
- package/dist/react/typing/vue/count/index.d.ts.map +1 -0
- package/dist/react/typing/vue/index.d.ts +9 -0
- package/dist/react/typing/vue/index.d.ts.map +1 -0
- package/dist/react/typing/vue/textToParticle/index.d.ts +2 -0
- package/dist/react/typing/vue/textToParticle/index.d.ts.map +1 -0
- package/dist/react/typing/vue/typing/index.d.ts +4 -0
- package/dist/react/typing/vue/typing/index.d.ts.map +1 -0
- package/dist/react/vue/index.d.ts +1 -0
- package/dist/react/vue/typing/index.d.ts +3 -0
- package/dist/svelte/count/index.d.ts +53 -0
- package/dist/svelte/index.cjs +1 -1
- package/dist/svelte/index.d.ts +53 -0
- package/dist/svelte/index.mjs +419 -48
- package/dist/svelte/textToParticle/index.d.ts +53 -0
- package/dist/svelte/typing/index.cjs +1 -0
- package/dist/svelte/typing/index.d.ts +216 -0
- package/dist/svelte/typing/index.mjs +638 -0
- package/dist/textToParticle/core/index.d.ts +2 -0
- package/dist/textToParticle/core/index.d.ts.map +1 -1
- package/dist/textToParticle/core/typing/index.d.ts +53 -0
- package/dist/textToParticle/core/typing/index.d.ts.map +1 -0
- package/dist/textToParticle/index.d.ts +2 -0
- package/dist/textToParticle/index.d.ts.map +1 -1
- package/dist/textToParticle/react/index.d.ts +2 -0
- package/dist/textToParticle/react/index.d.ts.map +1 -1
- package/dist/textToParticle/react/typing/Typing.d.ts +18 -0
- package/dist/textToParticle/react/typing/Typing.d.ts.map +1 -0
- package/dist/textToParticle/react/typing/index.d.ts +4 -0
- package/dist/textToParticle/react/typing/index.d.ts.map +1 -0
- package/dist/textToParticle/svelte/index.d.ts +1 -0
- package/dist/textToParticle/svelte/index.d.ts.map +1 -1
- package/dist/textToParticle/svelte/typing/index.d.ts +3 -0
- package/dist/textToParticle/svelte/typing/index.d.ts.map +1 -0
- package/dist/textToParticle/vue/index.d.ts +1 -0
- package/dist/textToParticle/vue/index.d.ts.map +1 -1
- package/dist/textToParticle/vue/typing/index.d.ts +4 -0
- package/dist/textToParticle/vue/typing/index.d.ts.map +1 -0
- package/dist/typing/core/count/index.d.ts +52 -0
- package/dist/typing/core/count/index.d.ts.map +1 -0
- package/dist/typing/core/index.d.ts +20 -0
- package/dist/typing/core/index.d.ts.map +1 -0
- package/dist/typing/core/textToParticle/index.d.ts +103 -0
- package/dist/typing/core/textToParticle/index.d.ts.map +1 -0
- package/dist/typing/core/typing/index.d.ts +53 -0
- package/dist/typing/core/typing/index.d.ts.map +1 -0
- package/dist/typing/index.cjs +1 -0
- package/dist/typing/index.d.ts +18 -0
- package/dist/typing/index.d.ts.map +1 -0
- package/dist/typing/index.mjs +1 -0
- package/dist/typing/index.umd.d.ts +7 -0
- package/dist/typing/index.umd.d.ts.map +1 -0
- package/dist/typing/react/MasonEffect.d.ts +32 -0
- package/dist/typing/react/MasonEffect.d.ts.map +1 -0
- package/dist/typing/react/count/Count.d.ts +19 -0
- package/dist/typing/react/count/Count.d.ts.map +1 -0
- package/dist/typing/react/count/index.d.ts +5 -0
- package/dist/typing/react/count/index.d.ts.map +1 -0
- package/dist/typing/react/index.d.ts +14 -0
- package/dist/typing/react/index.d.ts.map +1 -0
- package/dist/typing/react/textToParticle/TextToParticle.d.ts +15 -0
- package/dist/typing/react/textToParticle/TextToParticle.d.ts.map +1 -0
- package/dist/typing/react/textToParticle/index.d.ts +4 -0
- package/dist/typing/react/textToParticle/index.d.ts.map +1 -0
- package/dist/typing/react/typing/Typing.d.ts +18 -0
- package/dist/typing/react/typing/Typing.d.ts.map +1 -0
- package/dist/typing/react/typing/index.d.ts +4 -0
- package/dist/typing/react/typing/index.d.ts.map +1 -0
- package/dist/typing/svelte/count/index.d.ts +2 -0
- package/dist/typing/svelte/count/index.d.ts.map +1 -0
- package/dist/typing/svelte/index.d.ts +9 -0
- package/dist/typing/svelte/index.d.ts.map +1 -0
- package/dist/typing/svelte/textToParticle/index.d.ts +2 -0
- package/dist/typing/svelte/textToParticle/index.d.ts.map +1 -0
- package/dist/typing/svelte/typing/index.d.ts +3 -0
- package/dist/typing/svelte/typing/index.d.ts.map +1 -0
- package/dist/typing/vue/count/index.d.ts +2 -0
- package/dist/typing/vue/count/index.d.ts.map +1 -0
- package/dist/typing/vue/index.d.ts +9 -0
- package/dist/typing/vue/index.d.ts.map +1 -0
- package/dist/typing/vue/textToParticle/index.d.ts +2 -0
- package/dist/typing/vue/textToParticle/index.d.ts.map +1 -0
- package/dist/typing/vue/typing/index.d.ts +4 -0
- package/dist/typing/vue/typing/index.d.ts.map +1 -0
- package/dist/vue/count/index.d.ts +53 -0
- package/dist/vue/index.cjs +1 -1
- package/dist/vue/index.d.ts +53 -0
- package/dist/vue/index.mjs +316 -7
- package/dist/vue/textToParticle/index.d.ts +53 -0
- package/dist/vue/typing/index.cjs +1 -0
- package/dist/vue/typing/index.d.ts +216 -0
- package/dist/vue/typing/index.mjs +312 -0
- package/package.json +25 -3
|
@@ -160,4 +160,57 @@ declare class TextToParticle {
|
|
|
160
160
|
export { TextToParticleOptions as MasonEffectOptions }
|
|
161
161
|
export { TextToParticleOptions }
|
|
162
162
|
|
|
163
|
+
export declare class Typing {
|
|
164
|
+
container: HTMLElement;
|
|
165
|
+
config: Required<Omit<TypingOptions, 'onUpdate' | 'onComplete'>> & {
|
|
166
|
+
onUpdate: TypingOptions['onUpdate'];
|
|
167
|
+
onComplete: TypingOptions['onComplete'];
|
|
168
|
+
};
|
|
169
|
+
textUnits: string[];
|
|
170
|
+
charUnitRanges: Array<{
|
|
171
|
+
start: number;
|
|
172
|
+
end: number;
|
|
173
|
+
isHangul: boolean;
|
|
174
|
+
}>;
|
|
175
|
+
currentIndex: number;
|
|
176
|
+
displayedText: string;
|
|
177
|
+
timeoutId: ReturnType<typeof setTimeout> | null;
|
|
178
|
+
intersectionObserver: IntersectionObserver | null;
|
|
179
|
+
isRunning: boolean;
|
|
180
|
+
hasTriggered: boolean;
|
|
181
|
+
originalText: string;
|
|
182
|
+
constructor(container: HTMLElement | string, options: TypingOptions);
|
|
183
|
+
init(): void;
|
|
184
|
+
setupIntersectionObserver(): void;
|
|
185
|
+
private buildTextFromUnits;
|
|
186
|
+
start(): void;
|
|
187
|
+
typeNext(): void;
|
|
188
|
+
stop(): void;
|
|
189
|
+
reset(): void;
|
|
190
|
+
updateDisplay(text: string): void;
|
|
191
|
+
setText(newText: string): void;
|
|
192
|
+
destroy(): void;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
/**
|
|
196
|
+
* Typing - 타이핑 애니메이션 효과
|
|
197
|
+
* 바닐라 JS 코어 클래스
|
|
198
|
+
*
|
|
199
|
+
* 사용법:
|
|
200
|
+
* import { Typing } from 'masoneffect/typing';
|
|
201
|
+
*/
|
|
202
|
+
export declare interface TypingOptions {
|
|
203
|
+
text: string;
|
|
204
|
+
speed?: number;
|
|
205
|
+
delay?: number;
|
|
206
|
+
enabled?: boolean;
|
|
207
|
+
threshold?: number;
|
|
208
|
+
rootMargin?: string;
|
|
209
|
+
triggerOnce?: boolean;
|
|
210
|
+
showCursor?: boolean;
|
|
211
|
+
cursorChar?: string;
|
|
212
|
+
onUpdate?: (text: string) => void;
|
|
213
|
+
onComplete?: () => void;
|
|
214
|
+
}
|
|
215
|
+
|
|
163
216
|
export { }
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";var t=Object.defineProperty,e=(e,n,s)=>((e,n,s)=>n in e?t(e,n,{enumerable:!0,configurable:!0,writable:!0,value:s}):e[n]=s)(e,"symbol"!=typeof n?n+"":n,s);const n=require("svelte");function s(){}function i(t){return t()}function r(){return Object.create(null)}function o(t){t.forEach(i)}function c(t){return"function"==typeof t}function u(t,e){return t!=t?e==e:t!==e||t&&"object"==typeof t||"function"==typeof t}function h(t,e,n){t.$$.on_destroy.push(function(t,...e){if(null==t){for(const t of e)t(void 0);return s}const n=t.subscribe(...e);return n.unsubscribe?()=>n.unsubscribe():n}(e,n))}function a(t){t.parentNode&&t.parentNode.removeChild(t)}function l(t,e,n){null==n?t.removeAttribute(e):t.getAttribute(e)!==n&&t.setAttribute(e,n)}let d;function f(t){d=t}const g=[],p=[];let x=[];const $=[],y=Promise.resolve();let b=!1;function m(t){x.push(t)}const v=new Set;let w=0;function T(){if(0!==w)return;const t=d;do{try{for(;w<g.length;){const t=g[w];w++,f(t),_(t.$$)}}catch(e){throw g.length=0,w=0,e}for(f(null),g.length=0,w=0;p.length;)p.pop()();for(let t=0;t<x.length;t+=1){const e=x[t];v.has(e)||(v.add(e),e())}x.length=0}while(g.length);for(;$.length;)$.pop()();b=!1,v.clear(),f(t)}function _(t){if(null!==t.fragment){t.update(),o(t.before_update);const e=t.dirty;t.dirty=[-1],t.fragment&&t.fragment.p(t.ctx,e),t.after_update.forEach(m)}}const C=new Set;function O(t,e){const n=t.$$;null!==n.fragment&&(!function(t){const e=[],n=[];x.forEach(s=>-1===t.indexOf(s)?e.push(s):n.push(s)),n.forEach(t=>t()),x=e}(n.after_update),o(n.on_destroy),n.fragment&&n.fragment.d(e),n.on_destroy=n.fragment=null,n.ctx=[])}function U(t,e){-1===t.$$.dirty[0]&&(g.push(t),b||(b=!0,y.then(T)),t.$$.dirty.fill(0)),t.$$.dirty[e/31|0]|=1<<e%31}function I(t,e,n,u,h,l,g=null,p=[-1]){const x=d;f(t);const $=t.$$={fragment:null,ctx:[],props:l,update:s,not_equal:h,bound:r(),on_mount:[],on_destroy:[],on_disconnect:[],before_update:[],after_update:[],context:new Map(e.context||(x?x.$$.context:[])),callbacks:r(),dirty:p,skip_bound:!1,root:e.target||x.$$.root};g&&g($.root);let y=!1;if($.ctx=n?n(t,e.props||{},(e,n,...s)=>{const i=s.length?s[0]:n;return $.ctx&&h($.ctx[e],$.ctx[e]=i)&&(!$.skip_bound&&$.bound[e]&&$.bound[e](i),y&&U(t,e)),n}):[],$.update(),y=!0,o($.before_update),$.fragment=!!u&&u($.ctx),e.target){if(e.hydrate){const t=(w=e.target,Array.from(w.childNodes));$.fragment&&$.fragment.l(t),t.forEach(a)}else $.fragment&&$.fragment.c();e.intro&&((b=t.$$.fragment)&&b.i&&(C.delete(b),b.i(v))),function(t,e,n){const{fragment:s,after_update:r}=t.$$;s&&s.m(e,n),m(()=>{const e=t.$$.on_mount.map(i).filter(c);t.$$.on_destroy?t.$$.on_destroy.push(...e):o(e),t.$$.on_mount=[]}),r.forEach(m)}(t,e.target,e.anchor),T()}var b,v,w;f(x)}class R{constructor(){e(this,"$$"),e(this,"$$set")}$destroy(){O(this,1),this.$destroy=s}$on(t,e){if(!c(e))return s;const n=this.$$.callbacks[t]||(this.$$.callbacks[t]=[]);return n.push(e),()=>{const t=n.indexOf(e);-1!==t&&n.splice(t,1)}}$set(t){var e;this.$$set&&(e=t,0!==Object.keys(e).length)&&(this.$$.skip_bound=!0,this.$$set(t),this.$$.skip_bound=!1)}}function M(t){const e=t.charCodeAt(0);if(e<44032||e>55203)return[t];const n=e-44032,s=Math.floor(n/588),i=Math.floor(n%588/28),r=n%28,o=["","ㄱ","ㄲ","ㄳ","ㄴ","ㄵ","ㄶ","ㄷ","ㄹ","ㄺ","ㄻ","ㄼ","ㄽ","ㄾ","ㄿ","ㅀ","ㅁ","ㅂ","ㅄ","ㅅ","ㅆ","ㅇ","ㅈ","ㅊ","ㅋ","ㅌ","ㅍ","ㅎ"],c=[];return c.push(["ㄱ","ㄲ","ㄴ","ㄷ","ㄸ","ㄹ","ㅁ","ㅂ","ㅃ","ㅅ","ㅆ","ㅇ","ㅈ","ㅉ","ㅊ","ㅋ","ㅌ","ㅍ","ㅎ"][s]),c.push(["ㅏ","ㅐ","ㅑ","ㅒ","ㅓ","ㅔ","ㅕ","ㅖ","ㅗ","ㅘ","ㅙ","ㅚ","ㅛ","ㅜ","ㅝ","ㅞ","ㅟ","ㅠ","ㅡ","ㅢ","ㅣ"][i]),r>0&&c.push(o[r]),c}function k(t,e,n){const s=["ㄱ","ㄲ","ㄴ","ㄷ","ㄸ","ㄹ","ㅁ","ㅂ","ㅃ","ㅅ","ㅆ","ㅇ","ㅈ","ㅉ","ㅊ","ㅋ","ㅌ","ㅍ","ㅎ"].indexOf(t),i=["ㅏ","ㅐ","ㅑ","ㅒ","ㅓ","ㅔ","ㅕ","ㅖ","ㅗ","ㅘ","ㅙ","ㅚ","ㅛ","ㅜ","ㅝ","ㅞ","ㅟ","ㅠ","ㅡ","ㅢ","ㅣ"].indexOf(e),r=n?["","ㄱ","ㄲ","ㄳ","ㄴ","ㄵ","ㄶ","ㄷ","ㄹ","ㄺ","ㄻ","ㄼ","ㄽ","ㄾ","ㄿ","ㅀ","ㅁ","ㅂ","ㅄ","ㅅ","ㅆ","ㅇ","ㅈ","ㅊ","ㅋ","ㅌ","ㅍ","ㅎ"].indexOf(n):0;if(-1===s||-1===i)return t+(e||"")+(n||"");const o=44032+21*s*28+28*i+r;return String.fromCharCode(o)}function E(t){const e=[],n=[];for(let s=0;s<t.length;s++){const i=t[s],r=i.charCodeAt(0),o=e.length;if(r>=44032&&r<=55203){const t=M(i);e.push(...t),n.push({start:o,end:e.length,isHangul:!0})}else e.push(i),n.push({start:o,end:e.length,isHangul:!1})}return{units:e,charUnitRanges:n}}"undefined"!=typeof window&&(window.__svelte||(window.__svelte={v:new Set})).v.add("4");class N{constructor(t,e){if(this.container="string"==typeof t?document.querySelector(t):t,!this.container)throw new Error("Container element not found");this.originalText=e.text,this.config={text:e.text,speed:e.speed??50,delay:e.delay??0,enabled:e.enabled??!0,threshold:e.threshold??.2,rootMargin:e.rootMargin??"0px 0px -100px 0px",triggerOnce:e.triggerOnce??!1,showCursor:e.showCursor??!0,cursorChar:e.cursorChar??"|",onUpdate:e.onUpdate||null,onComplete:e.onComplete||null};const n=E(this.config.text);this.textUnits=n.units,this.charUnitRanges=n.charUnitRanges,this.currentIndex=0,this.displayedText="",this.timeoutId=null,this.intersectionObserver=null,this.isRunning=!1,this.hasTriggered=!1,this.init()}init(){this.updateDisplay(""),this.setupIntersectionObserver()}setupIntersectionObserver(){"undefined"!=typeof window&&void 0!==window.IntersectionObserver?(this.intersectionObserver=new IntersectionObserver(t=>{var e;for(const n of t)n.target===this.container&&n.isIntersecting&&!this.hasTriggered&&(this.config.enabled&&setTimeout(()=>this.start(),this.config.delay),this.hasTriggered=!0,this.config.triggerOnce&&(null==(e=this.intersectionObserver)||e.disconnect()))},{threshold:this.config.threshold,rootMargin:this.config.rootMargin}),this.intersectionObserver.observe(this.container)):this.config.enabled&&setTimeout(()=>this.start(),this.config.delay)}buildTextFromUnits(t){if(0===t)return"";let e="";for(let n=0;n<this.charUnitRanges.length;n++){const s=this.charUnitRanges[n];if(s.start>=t)break;const i=Math.min(t-s.start,s.end-s.start);if(i<=0)break;if(s.isHangul){const t=this.textUnits.slice(s.start,s.start+i);1===t.length?e+=t[0]:2===t.length?e+=k(t[0],t[1]):t.length>=3&&(e+=k(t[0],t[1],t[2]))}else i>0&&(e+=this.textUnits[s.start])}return e}start(){this.isRunning||(this.isRunning=!0,this.currentIndex=0,this.displayedText="",this.typeNext())}typeNext(){if(this.currentIndex>=this.textUnits.length)return this.isRunning=!1,this.config.showCursor&&this.updateDisplay(this.originalText),void(this.config.onComplete&&this.config.onComplete());this.displayedText=this.buildTextFromUnits(this.currentIndex+1);let t=this.displayedText;this.config.showCursor&&(t+=this.config.cursorChar),this.updateDisplay(t),this.config.onUpdate&&this.config.onUpdate(this.displayedText),this.currentIndex++,this.timeoutId=setTimeout(()=>{this.typeNext()},this.config.speed)}stop(){this.isRunning=!1,this.timeoutId&&(clearTimeout(this.timeoutId),this.timeoutId=null)}reset(){this.stop(),this.currentIndex=0,this.displayedText="",this.hasTriggered=!1,this.updateDisplay("")}updateDisplay(t){this.container.textContent=t}setText(t){this.originalText=t,this.config.text=t;const e=E(t);this.textUnits=e.units,this.charUnitRanges=e.charUnitRanges,this.reset(),this.config.enabled&&setTimeout(()=>this.start(),this.config.delay)}destroy(){this.stop(),this.intersectionObserver&&(this.intersectionObserver.disconnect(),this.intersectionObserver=null)}}function A(t){let e;return{c(){var n;n="div",e=document.createElement(n),l(e,"class",t[1]),l(e,"style",t[2])},m(n,s){!function(t,e,n){t.insertBefore(e,n||null)}(n,e,s),t[8](e)},p:s,i:s,o:s,d(n){n&&a(e),t[8](null)}}}function D(t,e,s){let i,r;h(t,effect,t=>s(10,i=t)),h(t,props,t=>s(11,r=t));let{text:o,speed:c=50,delay:u=0,enabled:a=!0,threshold:l=.2,rootMargin:d="0px 0px -100px 0px",triggerOnce:f=!1,showCursor:g=!0,cursorChar:x="|",className:$="",style:y="",onUpdate:b,onComplete:m}=r(),v=null,w=null;return n.onMount(()=>{if(!v)return;w=new N(v,{text:o,speed:c,delay:u,enabled:a,threshold:l,rootMargin:d,triggerOnce:f,showCursor:g,cursorChar:x,onUpdate:b,onComplete:m})}),n.onDestroy(()=>{w&&(w.destroy(),w=null)}),i(()=>{w&&o!==w.originalText&&w.setText(o)}),[v,$,y,function(){null==w||w.start()},function(){null==w||w.stop()},function(){null==w||w.reset()},function(t){null==w||w.setText(t)},function(){w&&(w.destroy(),w=null)},function(t){p[t?"unshift":"push"](()=>{v=t,s(0,v)})}]}module.exports=class extends R{constructor(t){super(),I(this,t,D,A,u,{start:3,stop:4,reset:5,setText:6,destroy:7})}get start(){return this.$$.ctx[3]}get stop(){return this.$$.ctx[4]}get reset(){return this.$$.ctx[5]}get setText(){return this.$$.ctx[6]}get destroy(){return this.$$.ctx[7]}};
|
|
@@ -0,0 +1,216 @@
|
|
|
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
|
+
intersectionObserver: IntersectionObserver | null;
|
|
11
|
+
isRunning: boolean;
|
|
12
|
+
hasTriggered: boolean;
|
|
13
|
+
constructor(container: HTMLElement | string, options: CountOptions);
|
|
14
|
+
init(): void;
|
|
15
|
+
setupIntersectionObserver(): 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
|
+
/**
|
|
27
|
+
* Count - 숫자 카운팅 애니메이션 효과
|
|
28
|
+
* 바닐라 JS 코어 클래스
|
|
29
|
+
*
|
|
30
|
+
* 사용법:
|
|
31
|
+
* import { Count } from 'masoneffect/count';
|
|
32
|
+
*/
|
|
33
|
+
export declare interface CountOptions {
|
|
34
|
+
targetValue: number;
|
|
35
|
+
duration?: number;
|
|
36
|
+
startValue?: number;
|
|
37
|
+
enabled?: boolean;
|
|
38
|
+
easing?: (t: number) => number;
|
|
39
|
+
threshold?: number;
|
|
40
|
+
rootMargin?: string;
|
|
41
|
+
triggerOnce?: boolean;
|
|
42
|
+
onUpdate?: (value: number) => void;
|
|
43
|
+
onComplete?: () => void;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
export declare const easingFunctions: {
|
|
47
|
+
linear: (t: number) => number;
|
|
48
|
+
easeInQuad: (t: number) => number;
|
|
49
|
+
easeOutQuad: (t: number) => number;
|
|
50
|
+
easeInOutQuad: (t: number) => number;
|
|
51
|
+
easeOutCubic: (t: number) => number;
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
export declare interface Particle {
|
|
55
|
+
x: number;
|
|
56
|
+
y: number;
|
|
57
|
+
vx: number;
|
|
58
|
+
vy: number;
|
|
59
|
+
tx: number;
|
|
60
|
+
ty: number;
|
|
61
|
+
initialX?: number;
|
|
62
|
+
initialY?: number;
|
|
63
|
+
j: number;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
declare class TextToParticle {
|
|
67
|
+
container: HTMLElement;
|
|
68
|
+
config: Required<Omit<TextToParticleOptions, 'onReady' | 'onUpdate' | 'debounceDelay'>> & {
|
|
69
|
+
onReady: TextToParticleOptions['onReady'];
|
|
70
|
+
onUpdate: TextToParticleOptions['onUpdate'];
|
|
71
|
+
};
|
|
72
|
+
canvas: HTMLCanvasElement;
|
|
73
|
+
ctx: CanvasRenderingContext2D;
|
|
74
|
+
offCanvas: HTMLCanvasElement;
|
|
75
|
+
offCtx: CanvasRenderingContext2D;
|
|
76
|
+
W: number;
|
|
77
|
+
H: number;
|
|
78
|
+
DPR: number;
|
|
79
|
+
particles: Particle[];
|
|
80
|
+
mouse: {
|
|
81
|
+
x: number;
|
|
82
|
+
y: number;
|
|
83
|
+
down: boolean;
|
|
84
|
+
};
|
|
85
|
+
animationId: number | null;
|
|
86
|
+
isRunning: boolean;
|
|
87
|
+
isVisible: boolean;
|
|
88
|
+
intersectionObserver: IntersectionObserver | null;
|
|
89
|
+
debounceDelay: number;
|
|
90
|
+
_debouncedMorph: (textOrOptions?: string | Partial<TextToParticleOptions> | null) => void;
|
|
91
|
+
_debouncedUpdateConfig: (newConfig: Partial<TextToParticleOptions>) => void;
|
|
92
|
+
constructor(container: HTMLElement | string, options?: TextToParticleOptions);
|
|
93
|
+
init(): void;
|
|
94
|
+
setupIntersectionObserver(): void;
|
|
95
|
+
resize(): void;
|
|
96
|
+
/**
|
|
97
|
+
* 텍스트가 영역 안에 들어가는지 확인하는 헬퍼 함수 (줄바꿈 지원)
|
|
98
|
+
* @param fontSize 확인할 폰트 크기
|
|
99
|
+
* @param text 텍스트 (\n으로 줄바꿈 구분)
|
|
100
|
+
* @param maxWidth 최대 너비
|
|
101
|
+
* @param maxHeight 최대 높이
|
|
102
|
+
* @returns { width: number, height: number, fits: boolean }
|
|
103
|
+
*/
|
|
104
|
+
private measureTextFit;
|
|
105
|
+
/**
|
|
106
|
+
* 이진 검색을 사용하여 적절한 폰트 크기를 찾는 최적화된 함수
|
|
107
|
+
* 반복 횟수를 O(log n)으로 줄여 성능 개선 (최대 15회 반복, 기존 최대 100회에서 대폭 감소)
|
|
108
|
+
*/
|
|
109
|
+
private findOptimalFontSize;
|
|
110
|
+
buildTargets(): void;
|
|
111
|
+
makeParticle(): Particle;
|
|
112
|
+
initParticles(): void;
|
|
113
|
+
scatter(): void;
|
|
114
|
+
morph(textOrOptions?: string | Partial<TextToParticleOptions> | null): void;
|
|
115
|
+
_morphInternal(textOrOptions?: string | Partial<TextToParticleOptions> | null): void;
|
|
116
|
+
update(): void;
|
|
117
|
+
animate(): void;
|
|
118
|
+
start(): void;
|
|
119
|
+
stop(): void;
|
|
120
|
+
setupEventListeners(): void;
|
|
121
|
+
removeEventListeners(): void;
|
|
122
|
+
handleResize(): void;
|
|
123
|
+
handleMouseMove(e: MouseEvent): void;
|
|
124
|
+
handleMouseLeave(): void;
|
|
125
|
+
handleMouseDown(): void;
|
|
126
|
+
handleMouseUp(): void;
|
|
127
|
+
updateConfig(newConfig: Partial<TextToParticleOptions>): void;
|
|
128
|
+
_updateConfigInternal(newConfig: Partial<TextToParticleOptions>): void;
|
|
129
|
+
destroy(): void;
|
|
130
|
+
}
|
|
131
|
+
export { TextToParticle as MasonEffect }
|
|
132
|
+
export { TextToParticle }
|
|
133
|
+
export default TextToParticle;
|
|
134
|
+
|
|
135
|
+
/**
|
|
136
|
+
* TextToParticle - 텍스트를 파티클로 변환하는 효과
|
|
137
|
+
* 바닐라 JS 코어 클래스
|
|
138
|
+
*
|
|
139
|
+
* 사용법:
|
|
140
|
+
* import { TextToParticle } from 'masoneffect/textToParticle';
|
|
141
|
+
*/
|
|
142
|
+
declare interface TextToParticleOptions {
|
|
143
|
+
text?: string;
|
|
144
|
+
densityStep?: number;
|
|
145
|
+
maxParticles?: number;
|
|
146
|
+
pointSize?: number;
|
|
147
|
+
ease?: number;
|
|
148
|
+
repelRadius?: number;
|
|
149
|
+
repelStrength?: number;
|
|
150
|
+
particleColor?: string;
|
|
151
|
+
fontFamily?: string;
|
|
152
|
+
fontSize?: number | null;
|
|
153
|
+
width?: number | null;
|
|
154
|
+
height?: number | null;
|
|
155
|
+
devicePixelRatio?: number | null;
|
|
156
|
+
debounceDelay?: number;
|
|
157
|
+
onReady?: (instance: TextToParticle) => void;
|
|
158
|
+
onUpdate?: (instance: TextToParticle) => void;
|
|
159
|
+
}
|
|
160
|
+
export { TextToParticleOptions as MasonEffectOptions }
|
|
161
|
+
export { TextToParticleOptions }
|
|
162
|
+
|
|
163
|
+
export declare class Typing {
|
|
164
|
+
container: HTMLElement;
|
|
165
|
+
config: Required<Omit<TypingOptions, 'onUpdate' | 'onComplete'>> & {
|
|
166
|
+
onUpdate: TypingOptions['onUpdate'];
|
|
167
|
+
onComplete: TypingOptions['onComplete'];
|
|
168
|
+
};
|
|
169
|
+
textUnits: string[];
|
|
170
|
+
charUnitRanges: Array<{
|
|
171
|
+
start: number;
|
|
172
|
+
end: number;
|
|
173
|
+
isHangul: boolean;
|
|
174
|
+
}>;
|
|
175
|
+
currentIndex: number;
|
|
176
|
+
displayedText: string;
|
|
177
|
+
timeoutId: ReturnType<typeof setTimeout> | null;
|
|
178
|
+
intersectionObserver: IntersectionObserver | null;
|
|
179
|
+
isRunning: boolean;
|
|
180
|
+
hasTriggered: boolean;
|
|
181
|
+
originalText: string;
|
|
182
|
+
constructor(container: HTMLElement | string, options: TypingOptions);
|
|
183
|
+
init(): void;
|
|
184
|
+
setupIntersectionObserver(): void;
|
|
185
|
+
private buildTextFromUnits;
|
|
186
|
+
start(): void;
|
|
187
|
+
typeNext(): void;
|
|
188
|
+
stop(): void;
|
|
189
|
+
reset(): void;
|
|
190
|
+
updateDisplay(text: string): void;
|
|
191
|
+
setText(newText: string): void;
|
|
192
|
+
destroy(): void;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
/**
|
|
196
|
+
* Typing - 타이핑 애니메이션 효과
|
|
197
|
+
* 바닐라 JS 코어 클래스
|
|
198
|
+
*
|
|
199
|
+
* 사용법:
|
|
200
|
+
* import { Typing } from 'masoneffect/typing';
|
|
201
|
+
*/
|
|
202
|
+
export declare interface TypingOptions {
|
|
203
|
+
text: string;
|
|
204
|
+
speed?: number;
|
|
205
|
+
delay?: number;
|
|
206
|
+
enabled?: boolean;
|
|
207
|
+
threshold?: number;
|
|
208
|
+
rootMargin?: string;
|
|
209
|
+
triggerOnce?: boolean;
|
|
210
|
+
showCursor?: boolean;
|
|
211
|
+
cursorChar?: string;
|
|
212
|
+
onUpdate?: (text: string) => void;
|
|
213
|
+
onComplete?: () => void;
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
export { }
|