@nine-lab/nine-util 0.4.0 β 0.6.0
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/dist/nine-util.js +20 -1
- package/dist/nine-util.js.map +1 -1
- package/dist/nine-util.umd.cjs +1 -1
- package/dist/nine-util.umd.cjs.map +1 -1
- package/package.json +1 -1
package/dist/nine-util.js
CHANGED
|
@@ -6,15 +6,17 @@ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read fr
|
|
|
6
6
|
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
7
7
|
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
8
8
|
var __privateMethod = (obj, member, method) => (__accessCheck(obj, member, "access private method"), method);
|
|
9
|
-
var _name, _color, _enabled, _timer, _queue, _delay, _TaskDebouncer_instances, flush_fn;
|
|
9
|
+
var _name, _color, _enabled, _Trace_instances, autoConfig_fn, _timer, _queue, _delay, _TaskDebouncer_instances, flush_fn;
|
|
10
10
|
class Trace {
|
|
11
11
|
// π μ΄ μνκ°μ΄ κΈ°μ€μ΄ λ©λλ€.
|
|
12
12
|
constructor(name = "nine-util", color = "green") {
|
|
13
|
+
__privateAdd(this, _Trace_instances);
|
|
13
14
|
__privateAdd(this, _name);
|
|
14
15
|
__privateAdd(this, _color);
|
|
15
16
|
__privateAdd(this, _enabled, true);
|
|
16
17
|
__privateSet(this, _name, name);
|
|
17
18
|
__privateSet(this, _color, color);
|
|
19
|
+
__privateMethod(this, _Trace_instances, autoConfig_fn).call(this);
|
|
18
20
|
}
|
|
19
21
|
init(name, color = "green") {
|
|
20
22
|
__privateSet(this, _name, name);
|
|
@@ -44,6 +46,23 @@ class Trace {
|
|
|
44
46
|
_name = new WeakMap();
|
|
45
47
|
_color = new WeakMap();
|
|
46
48
|
_enabled = new WeakMap();
|
|
49
|
+
_Trace_instances = new WeakSet();
|
|
50
|
+
autoConfig_fn = function() {
|
|
51
|
+
if (typeof window === "undefined") return;
|
|
52
|
+
const isLocal = window.location.hostname === "localhost" || window.location.hostname === "127.0.0.1" || window.location.hostname.startsWith("192.168.");
|
|
53
|
+
if (isLocal) {
|
|
54
|
+
this.enable();
|
|
55
|
+
} else {
|
|
56
|
+
this.disable();
|
|
57
|
+
console.log(
|
|
58
|
+
`%c[${__privateGet(this, _name)}]%c μ΄μ λͺ¨λ: λ‘κ·Έκ° λΉνμ±νλμμ΅λλ€. %ctrace.enable()%c λ‘ μΌ€ μ μμ΅λλ€.`,
|
|
59
|
+
"color: #4CAF50; font-weight: bold;",
|
|
60
|
+
"",
|
|
61
|
+
"background: #333; color: yellow; padding: 2px 5px;",
|
|
62
|
+
""
|
|
63
|
+
);
|
|
64
|
+
}
|
|
65
|
+
};
|
|
47
66
|
const trace = new Trace();
|
|
48
67
|
if (typeof window !== "undefined") {
|
|
49
68
|
window.trace = trace;
|
package/dist/nine-util.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nine-util.js","sources":["../src/Trace.js","../src/TaskDebouncer.js"],"sourcesContent":["export class Trace {\r\n\t#name;\r\n\t#color;\r\n\t#enabled = true; // π μ΄ μνκ°μ΄ κΈ°μ€μ΄ λ©λλ€.\r\n\r\n\tconstructor(name = \"nine-util\", color = \"green\") {\r\n\t\tthis.#name = name;\r\n\t\tthis.#color = color;\r\n\t}\r\n\r\n\tinit(name, color = \"green\") {\r\n\t\tthis.#name = name;\r\n\t\tthis.#color = color;\r\n\t}\r\n\r\n\t// π΄ ν΅μ¬: ν¨μλ₯Ό κ°μλΌμ°μ§ μκ³ , νΈμΆλ λλ§λ€ μνλ₯Ό 체ν¬ν©λλ€.\r\n\tlog(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconst style = `color: ${this.#color}; font-weight: bold;`;\r\n\t\tconsole.log(`%c[${this.#name}]`, style, ...args);\r\n\t}\r\n\r\n\twarn(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconsole.warn(`%c[${this.#name}]`, \"color: cyan; font-weight: bold;\", ...args);\r\n\t}\r\n\r\n\terror(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconsole.error(`%c[${this.#name}]`, \"color: red; font-weight: bold;\", ...args);\r\n\t}\r\n\r\n\tenable() { this.#enabled = true; }\r\n\tdisable() { this.#enabled = false; }\r\n}\r\n\r\nexport const trace = new Trace();\r\n\r\n// λΈλΌμ°μ μ½μμμ μ¦μ μ μ΄ν μ μλλ‘ windowμ μ°κ²°\r\nif (typeof window !== 'undefined') {\r\n\twindow.trace = trace;\r\n}","export class TaskDebouncer {\r\n\t#timer = null;\r\n\t#queue = [];\r\n\t#delay;\r\n\r\n\tconstructor(delay = 50) {\r\n\t\tthis.#delay = delay;\r\n\t}\r\n\r\n\t/**\r\n\t * @param {Function} func - μ€νν ν¨μ\r\n\t * @param {...any} args - ν¨μμ μ λ¬ν μμμ νλΌλ―Έν°λ€\r\n\t */\r\n\texec(func, ...args) {\r\n\t\t// 1. μ΄λ€ ν¨μμ μ΄λ€ μΈμλ€μ΄ λ€μ΄μλμ§ νμ μ μ₯\r\n\t\tthis.#queue.push({ func, args });\r\n\r\n\t\t// 2. λλ°μ΄μ€ νμ΄λ¨Έ μ€μ \r\n\t\tif (this.#timer) clearTimeout(this.#timer);\r\n\r\n\t\tthis.#timer = setTimeout(() => {\r\n\t\t\tthis.#flush();\r\n\t\t}, this.#delay);\r\n\t}\r\n\r\n\t#flush() {\r\n\t\tif (this.#queue.length === 0) return;\r\n\r\n\t\t// 3. νμ¬κΉμ§ μμΈ νλ₯Ό μ λΉΌμ΄\r\n\t\tconst tasks = this.#queue.splice(0, this.#queue.length);\r\n\t\tconst seen = new Set();\r\n\r\n\t\ttasks.forEach(task => {\r\n\t\t\t// 4. ν΅μ¬: ν¨μ μ΄λ¦κ³Ό μΈμλ€μ λ¬Έμμ΄λ‘ ν©μ³μ μ λν¬ ν€ μμ±\r\n\t\t\t// JSON.stringifyλ₯Ό ν΅ν΄ [1, {a:1}] κ°μ νλΌλ―Έν°λ λ¬Έμμ΄λ‘ λΉκ΅ κ°λ₯\r\n\t\t\tconst identifier = `${task.func.name}_${JSON.stringify(task.args)}`;\r\n\r\n\t\t\tif (!seen.has(identifier)) {\r\n\t\t\t\t// 5. μ€λ³΅μ΄ μλ λλ§ μλ μΈμλ€(...args) κ·Έλλ‘ μ€ν\r\n\t\t\t\ttask.func(...task.args);\r\n\t\t\t\tseen.add(identifier);\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tthis.#timer = null;\r\n\t}\r\n}"],"names":[],"mappings":";;;;;;;;AAAO;AAAA,MAAM,MAAM;AAAA;AAAA,EAKlB,YAAY,OAAO,aAAa,QAAQ,SAAS;
|
|
1
|
+
{"version":3,"file":"nine-util.js","sources":["../src/Trace.js","../src/TaskDebouncer.js"],"sourcesContent":["export class Trace {\r\n\t#name;\r\n\t#color;\r\n\t#enabled = true; // π μ΄ μνκ°μ΄ κΈ°μ€μ΄ λ©λλ€.\r\n\r\n\tconstructor(name = \"nine-util\", color = \"green\") {\r\n\t\tthis.#name = name;\r\n\t\tthis.#color = color;\r\n\r\n\t\t// μΈμ€ν΄μ€κ° μμ±λ λ μλμΌλ‘ νκ²½μ 체ν¬ν΄μ λκ±°λ μΌλλ€.\r\n\t\tthis.#autoConfig();\r\n\t}\r\n\r\n\t#autoConfig() {\r\n\t\tif (typeof window === 'undefined') return;\r\n\r\n\t\tconst isLocal = window.location.hostname === 'localhost' ||\r\n\t\t\twindow.location.hostname === '127.0.0.1' ||\r\n\t\t\twindow.location.hostname.startsWith('192.168.'); // λ‘컬 IP μΆκ°\r\n\r\n\t\tif (isLocal) {\r\n\t\t\tthis.enable();\r\n\t\t\t// λ‘μ»¬μΌ λλ νμ λ©μμ§ (λ± ν λ²λ§ λμ€κ² νλ €λ©΄ ν΄λμ€ λ³μ νμ© κ°λ₯)\r\n\t\t} else {\r\n\t\t\tthis.disable();\r\n\t\t\t// μ΄μ νκ²½ μλ΄ λ©μμ§λ console.logλ‘ μ§μ μΆλ ₯\r\n\t\t\tconsole.log(\r\n\t\t\t\t`%c[${this.#name}]%c μ΄μ λͺ¨λ: λ‘κ·Έκ° λΉνμ±νλμμ΅λλ€. %ctrace.enable()%c λ‘ μΌ€ μ μμ΅λλ€.`,\r\n\t\t\t\t\"color: #4CAF50; font-weight: bold;\", \"\",\r\n\t\t\t\t\"background: #333; color: yellow; padding: 2px 5px;\", \"\"\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\r\n\tinit(name, color = \"green\") {\r\n\t\tthis.#name = name;\r\n\t\tthis.#color = color;\r\n\t}\r\n\r\n\t// π΄ ν΅μ¬: ν¨μλ₯Ό κ°μλΌμ°μ§ μκ³ , νΈμΆλ λλ§λ€ μνλ₯Ό 체ν¬ν©λλ€.\r\n\tlog(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconst style = `color: ${this.#color}; font-weight: bold;`;\r\n\t\tconsole.log(`%c[${this.#name}]`, style, ...args);\r\n\t}\r\n\r\n\twarn(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconsole.warn(`%c[${this.#name}]`, \"color: cyan; font-weight: bold;\", ...args);\r\n\t}\r\n\r\n\terror(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconsole.error(`%c[${this.#name}]`, \"color: red; font-weight: bold;\", ...args);\r\n\t}\r\n\r\n\tenable() { this.#enabled = true; }\r\n\tdisable() { this.#enabled = false; }\r\n}\r\n\r\nexport const trace = new Trace();\r\n\r\n// λΈλΌμ°μ μ½μμμ μ¦μ μ μ΄ν μ μλλ‘ windowμ μ°κ²°\r\nif (typeof window !== 'undefined') {\r\n\twindow.trace = trace;\r\n}","export class TaskDebouncer {\r\n\t#timer = null;\r\n\t#queue = [];\r\n\t#delay;\r\n\r\n\tconstructor(delay = 50) {\r\n\t\tthis.#delay = delay;\r\n\t}\r\n\r\n\t/**\r\n\t * @param {Function} func - μ€νν ν¨μ\r\n\t * @param {...any} args - ν¨μμ μ λ¬ν μμμ νλΌλ―Έν°λ€\r\n\t */\r\n\texec(func, ...args) {\r\n\t\t// 1. μ΄λ€ ν¨μμ μ΄λ€ μΈμλ€μ΄ λ€μ΄μλμ§ νμ μ μ₯\r\n\t\tthis.#queue.push({ func, args });\r\n\r\n\t\t// 2. λλ°μ΄μ€ νμ΄λ¨Έ μ€μ \r\n\t\tif (this.#timer) clearTimeout(this.#timer);\r\n\r\n\t\tthis.#timer = setTimeout(() => {\r\n\t\t\tthis.#flush();\r\n\t\t}, this.#delay);\r\n\t}\r\n\r\n\t#flush() {\r\n\t\tif (this.#queue.length === 0) return;\r\n\r\n\t\t// 3. νμ¬κΉμ§ μμΈ νλ₯Ό μ λΉΌμ΄\r\n\t\tconst tasks = this.#queue.splice(0, this.#queue.length);\r\n\t\tconst seen = new Set();\r\n\r\n\t\ttasks.forEach(task => {\r\n\t\t\t// 4. ν΅μ¬: ν¨μ μ΄λ¦κ³Ό μΈμλ€μ λ¬Έμμ΄λ‘ ν©μ³μ μ λν¬ ν€ μμ±\r\n\t\t\t// JSON.stringifyλ₯Ό ν΅ν΄ [1, {a:1}] κ°μ νλΌλ―Έν°λ λ¬Έμμ΄λ‘ λΉκ΅ κ°λ₯\r\n\t\t\tconst identifier = `${task.func.name}_${JSON.stringify(task.args)}`;\r\n\r\n\t\t\tif (!seen.has(identifier)) {\r\n\t\t\t\t// 5. μ€λ³΅μ΄ μλ λλ§ μλ μΈμλ€(...args) κ·Έλλ‘ μ€ν\r\n\t\t\t\ttask.func(...task.args);\r\n\t\t\t\tseen.add(identifier);\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tthis.#timer = null;\r\n\t}\r\n}"],"names":[],"mappings":";;;;;;;;AAAO;AAAA,MAAM,MAAM;AAAA;AAAA,EAKlB,YAAY,OAAO,aAAa,QAAQ,SAAS;AAL3C;AACN;AACA;AACA,iCAAW;AAGV,uBAAK,OAAQ;AACb,uBAAK,QAAS;AAGd,0BAAK,iCAAL;AAAA,EACD;AAAA,EAuBA,KAAK,MAAM,QAAQ,SAAS;AAC3B,uBAAK,OAAQ;AACb,uBAAK,QAAS;AAAA,EACf;AAAA;AAAA,EAGA,OAAO,MAAM;AACZ,QAAI,CAAC,mBAAK,UAAU;AACpB,UAAM,QAAQ,UAAU,mBAAK,OAAM;AACnC,YAAQ,IAAI,MAAM,mBAAK,MAAK,KAAK,OAAO,GAAG,IAAI;AAAA,EAChD;AAAA,EAEA,QAAQ,MAAM;AACb,QAAI,CAAC,mBAAK,UAAU;AACpB,YAAQ,KAAK,MAAM,mBAAK,MAAK,KAAK,mCAAmC,GAAG,IAAI;AAAA,EAC7E;AAAA,EAEA,SAAS,MAAM;AACd,QAAI,CAAC,mBAAK,UAAU;AACpB,YAAQ,MAAM,MAAM,mBAAK,MAAK,KAAK,kCAAkC,GAAG,IAAI;AAAA,EAC7E;AAAA,EAEA,SAAS;AAAE,uBAAK,UAAW;AAAA,EAAM;AAAA,EACjC,UAAU;AAAE,uBAAK,UAAW;AAAA,EAAO;AACpC;AAzDC;AACA;AACA;AAHM;AAaN,gBAAW,WAAG;AACb,MAAI,OAAO,WAAW,YAAa;AAEnC,QAAM,UAAU,OAAO,SAAS,aAAa,eAC5C,OAAO,SAAS,aAAa,eAC7B,OAAO,SAAS,SAAS,WAAW,UAAU;AAE/C,MAAI,SAAS;AACZ,SAAK,OAAM;AAAA,EAEZ,OAAO;AACN,SAAK,QAAO;AAEZ,YAAQ;AAAA,MACP,MAAM,mBAAK,MAAK;AAAA,MAChB;AAAA,MAAsC;AAAA,MACtC;AAAA,MAAsD;AAAA,IAC1D;AAAA,EACE;AACD;AA4BW,MAAC,QAAQ,IAAI,MAAK;AAG9B,IAAI,OAAO,WAAW,aAAa;AAClC,SAAO,QAAQ;AAChB;ACjEO,MAAM,cAAc;AAAA,EAK1B,YAAY,QAAQ,IAAI;AALlB;AACN,+BAAS;AACT,+BAAS,CAAA;AACT;AAGC,uBAAK,QAAS;AAAA,EACf;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,KAAK,SAAS,MAAM;AAEnB,uBAAK,QAAO,KAAK,EAAE,MAAM,KAAI,CAAE;AAG/B,QAAI,mBAAK,QAAQ,cAAa,mBAAK,OAAM;AAEzC,uBAAK,QAAS,WAAW,MAAM;AAC9B,4BAAK,oCAAL;AAAA,IACD,GAAG,mBAAK,OAAM;AAAA,EACf;AAuBD;AA7CC;AACA;AACA;AAHM;AAyBN,WAAM,WAAG;AACR,MAAI,mBAAK,QAAO,WAAW,EAAG;AAG9B,QAAM,QAAQ,mBAAK,QAAO,OAAO,GAAG,mBAAK,QAAO,MAAM;AACtD,QAAM,OAAO,oBAAI;AAEjB,QAAM,QAAQ,UAAQ;AAGrB,UAAM,aAAa,GAAG,KAAK,KAAK,IAAI,IAAI,KAAK,UAAU,KAAK,IAAI,CAAC;AAEjE,QAAI,CAAC,KAAK,IAAI,UAAU,GAAG;AAE1B,WAAK,KAAK,GAAG,KAAK,IAAI;AACtB,WAAK,IAAI,UAAU;AAAA,IACpB;AAAA,EACD,CAAC;AAED,qBAAK,QAAS;AACf;"}
|
package/dist/nine-util.umd.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).NineUtil={})}(this,function(e){"use strict";var t,i,n,s,
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).NineUtil={})}(this,function(e){"use strict";var t,i,n,o,s,a,h,c,r,l,d=e=>{throw TypeError(e)},f=(e,t,i)=>t.has(e)||d("Cannot "+i),w=(e,t,i)=>(f(e,t,"read from private field"),i?i.call(e):t.get(e)),u=(e,t,i)=>t.has(e)?d("Cannot add the same private member more than once"):t instanceof WeakSet?t.add(e):t.set(e,i),p=(e,t,i,n)=>(f(e,t,"write to private field"),n?n.call(e,i):t.set(e,i),i),g=(e,t,i)=>(f(e,t,"access private method"),i);class b{constructor(e="nine-util",a="green"){u(this,o),u(this,t),u(this,i),u(this,n,!0),p(this,t,e),p(this,i,a),g(this,o,s).call(this)}init(e,n="green"){p(this,t,e),p(this,i,n)}log(...e){if(!w(this,n))return;const o=`color: ${w(this,i)}; font-weight: bold;`;console.log(`%c[${w(this,t)}]`,o,...e)}warn(...e){w(this,n)&&console.warn(`%c[${w(this,t)}]`,"color: cyan; font-weight: bold;",...e)}error(...e){w(this,n)&&console.error(`%c[${w(this,t)}]`,"color: red; font-weight: bold;",...e)}enable(){p(this,n,!0)}disable(){p(this,n,!1)}}t=new WeakMap,i=new WeakMap,n=new WeakMap,o=new WeakSet,s=function(){if("undefined"==typeof window)return;"localhost"===window.location.hostname||"127.0.0.1"===window.location.hostname||window.location.hostname.startsWith("192.168.")?this.enable():(this.disable(),console.log(`%c[${w(this,t)}]%c μ΄μ λͺ¨λ: λ‘κ·Έκ° λΉνμ±νλμμ΅λλ€. %ctrace.enable()%c λ‘ μΌ€ μ μμ΅λλ€.`,"color: #4CAF50; font-weight: bold;","","background: #333; color: yellow; padding: 2px 5px;",""))};const m=new b;"undefined"!=typeof window&&(window.trace=m);a=new WeakMap,h=new WeakMap,c=new WeakMap,r=new WeakSet,l=function(){if(0===w(this,h).length)return;const e=w(this,h).splice(0,w(this,h).length),t=new Set;e.forEach(e=>{const i=`${e.func.name}_${JSON.stringify(e.args)}`;t.has(i)||(e.func(...e.args),t.add(i))}),p(this,a,null)},e.TaskDebouncer=class{constructor(e=50){u(this,r),u(this,a,null),u(this,h,[]),u(this,c),p(this,c,e)}exec(e,...t){w(this,h).push({func:e,args:t}),w(this,a)&&clearTimeout(w(this,a)),p(this,a,setTimeout(()=>{g(this,r,l).call(this)},w(this,c)))}},e.Trace=b,e.trace=m,Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})});
|
|
2
2
|
//# sourceMappingURL=nine-util.umd.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"nine-util.umd.cjs","sources":["../src/Trace.js","../src/TaskDebouncer.js"],"sourcesContent":["export class Trace {\r\n\t#name;\r\n\t#color;\r\n\t#enabled = true; // π μ΄ μνκ°μ΄ κΈ°μ€μ΄ λ©λλ€.\r\n\r\n\tconstructor(name = \"nine-util\", color = \"green\") {\r\n\t\tthis.#name = name;\r\n\t\tthis.#color = color;\r\n\t}\r\n\r\n\tinit(name, color = \"green\") {\r\n\t\tthis.#name = name;\r\n\t\tthis.#color = color;\r\n\t}\r\n\r\n\t// π΄ ν΅μ¬: ν¨μλ₯Ό κ°μλΌμ°μ§ μκ³ , νΈμΆλ λλ§λ€ μνλ₯Ό 체ν¬ν©λλ€.\r\n\tlog(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconst style = `color: ${this.#color}; font-weight: bold;`;\r\n\t\tconsole.log(`%c[${this.#name}]`, style, ...args);\r\n\t}\r\n\r\n\twarn(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconsole.warn(`%c[${this.#name}]`, \"color: cyan; font-weight: bold;\", ...args);\r\n\t}\r\n\r\n\terror(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconsole.error(`%c[${this.#name}]`, \"color: red; font-weight: bold;\", ...args);\r\n\t}\r\n\r\n\tenable() { this.#enabled = true; }\r\n\tdisable() { this.#enabled = false; }\r\n}\r\n\r\nexport const trace = new Trace();\r\n\r\n// λΈλΌμ°μ μ½μμμ μ¦μ μ μ΄ν μ μλλ‘ windowμ μ°κ²°\r\nif (typeof window !== 'undefined') {\r\n\twindow.trace = trace;\r\n}","export class TaskDebouncer {\r\n\t#timer = null;\r\n\t#queue = [];\r\n\t#delay;\r\n\r\n\tconstructor(delay = 50) {\r\n\t\tthis.#delay = delay;\r\n\t}\r\n\r\n\t/**\r\n\t * @param {Function} func - μ€νν ν¨μ\r\n\t * @param {...any} args - ν¨μμ μ λ¬ν μμμ νλΌλ―Έν°λ€\r\n\t */\r\n\texec(func, ...args) {\r\n\t\t// 1. μ΄λ€ ν¨μμ μ΄λ€ μΈμλ€μ΄ λ€μ΄μλμ§ νμ μ μ₯\r\n\t\tthis.#queue.push({ func, args });\r\n\r\n\t\t// 2. λλ°μ΄μ€ νμ΄λ¨Έ μ€μ \r\n\t\tif (this.#timer) clearTimeout(this.#timer);\r\n\r\n\t\tthis.#timer = setTimeout(() => {\r\n\t\t\tthis.#flush();\r\n\t\t}, this.#delay);\r\n\t}\r\n\r\n\t#flush() {\r\n\t\tif (this.#queue.length === 0) return;\r\n\r\n\t\t// 3. νμ¬κΉμ§ μμΈ νλ₯Ό μ λΉΌμ΄\r\n\t\tconst tasks = this.#queue.splice(0, this.#queue.length);\r\n\t\tconst seen = new Set();\r\n\r\n\t\ttasks.forEach(task => {\r\n\t\t\t// 4. ν΅μ¬: ν¨μ μ΄λ¦κ³Ό μΈμλ€μ λ¬Έμμ΄λ‘ ν©μ³μ μ λν¬ ν€ μμ±\r\n\t\t\t// JSON.stringifyλ₯Ό ν΅ν΄ [1, {a:1}] κ°μ νλΌλ―Έν°λ λ¬Έμμ΄λ‘ λΉκ΅ κ°λ₯\r\n\t\t\tconst identifier = `${task.func.name}_${JSON.stringify(task.args)}`;\r\n\r\n\t\t\tif (!seen.has(identifier)) {\r\n\t\t\t\t// 5. μ€λ³΅μ΄ μλ λλ§ μλ μΈμλ€(...args) κ·Έλλ‘ μ€ν\r\n\t\t\t\ttask.func(...task.args);\r\n\t\t\t\tseen.add(identifier);\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tthis.#timer = null;\r\n\t}\r\n}"],"names":["Trace","constructor","name","color","__privateAdd","this","_name","_color","_enabled","__privateSet","init","log","args","__privateGet","style","console","warn","error","enable","disable","WeakMap","
|
|
1
|
+
{"version":3,"file":"nine-util.umd.cjs","sources":["../src/Trace.js","../src/TaskDebouncer.js"],"sourcesContent":["export class Trace {\r\n\t#name;\r\n\t#color;\r\n\t#enabled = true; // π μ΄ μνκ°μ΄ κΈ°μ€μ΄ λ©λλ€.\r\n\r\n\tconstructor(name = \"nine-util\", color = \"green\") {\r\n\t\tthis.#name = name;\r\n\t\tthis.#color = color;\r\n\r\n\t\t// μΈμ€ν΄μ€κ° μμ±λ λ μλμΌλ‘ νκ²½μ 체ν¬ν΄μ λκ±°λ μΌλλ€.\r\n\t\tthis.#autoConfig();\r\n\t}\r\n\r\n\t#autoConfig() {\r\n\t\tif (typeof window === 'undefined') return;\r\n\r\n\t\tconst isLocal = window.location.hostname === 'localhost' ||\r\n\t\t\twindow.location.hostname === '127.0.0.1' ||\r\n\t\t\twindow.location.hostname.startsWith('192.168.'); // λ‘컬 IP μΆκ°\r\n\r\n\t\tif (isLocal) {\r\n\t\t\tthis.enable();\r\n\t\t\t// λ‘μ»¬μΌ λλ νμ λ©μμ§ (λ± ν λ²λ§ λμ€κ² νλ €λ©΄ ν΄λμ€ λ³μ νμ© κ°λ₯)\r\n\t\t} else {\r\n\t\t\tthis.disable();\r\n\t\t\t// μ΄μ νκ²½ μλ΄ λ©μμ§λ console.logλ‘ μ§μ μΆλ ₯\r\n\t\t\tconsole.log(\r\n\t\t\t\t`%c[${this.#name}]%c μ΄μ λͺ¨λ: λ‘κ·Έκ° λΉνμ±νλμμ΅λλ€. %ctrace.enable()%c λ‘ μΌ€ μ μμ΅λλ€.`,\r\n\t\t\t\t\"color: #4CAF50; font-weight: bold;\", \"\",\r\n\t\t\t\t\"background: #333; color: yellow; padding: 2px 5px;\", \"\"\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\r\n\tinit(name, color = \"green\") {\r\n\t\tthis.#name = name;\r\n\t\tthis.#color = color;\r\n\t}\r\n\r\n\t// π΄ ν΅μ¬: ν¨μλ₯Ό κ°μλΌμ°μ§ μκ³ , νΈμΆλ λλ§λ€ μνλ₯Ό 체ν¬ν©λλ€.\r\n\tlog(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconst style = `color: ${this.#color}; font-weight: bold;`;\r\n\t\tconsole.log(`%c[${this.#name}]`, style, ...args);\r\n\t}\r\n\r\n\twarn(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconsole.warn(`%c[${this.#name}]`, \"color: cyan; font-weight: bold;\", ...args);\r\n\t}\r\n\r\n\terror(...args) {\r\n\t\tif (!this.#enabled) return;\r\n\t\tconsole.error(`%c[${this.#name}]`, \"color: red; font-weight: bold;\", ...args);\r\n\t}\r\n\r\n\tenable() { this.#enabled = true; }\r\n\tdisable() { this.#enabled = false; }\r\n}\r\n\r\nexport const trace = new Trace();\r\n\r\n// λΈλΌμ°μ μ½μμμ μ¦μ μ μ΄ν μ μλλ‘ windowμ μ°κ²°\r\nif (typeof window !== 'undefined') {\r\n\twindow.trace = trace;\r\n}","export class TaskDebouncer {\r\n\t#timer = null;\r\n\t#queue = [];\r\n\t#delay;\r\n\r\n\tconstructor(delay = 50) {\r\n\t\tthis.#delay = delay;\r\n\t}\r\n\r\n\t/**\r\n\t * @param {Function} func - μ€νν ν¨μ\r\n\t * @param {...any} args - ν¨μμ μ λ¬ν μμμ νλΌλ―Έν°λ€\r\n\t */\r\n\texec(func, ...args) {\r\n\t\t// 1. μ΄λ€ ν¨μμ μ΄λ€ μΈμλ€μ΄ λ€μ΄μλμ§ νμ μ μ₯\r\n\t\tthis.#queue.push({ func, args });\r\n\r\n\t\t// 2. λλ°μ΄μ€ νμ΄λ¨Έ μ€μ \r\n\t\tif (this.#timer) clearTimeout(this.#timer);\r\n\r\n\t\tthis.#timer = setTimeout(() => {\r\n\t\t\tthis.#flush();\r\n\t\t}, this.#delay);\r\n\t}\r\n\r\n\t#flush() {\r\n\t\tif (this.#queue.length === 0) return;\r\n\r\n\t\t// 3. νμ¬κΉμ§ μμΈ νλ₯Ό μ λΉΌμ΄\r\n\t\tconst tasks = this.#queue.splice(0, this.#queue.length);\r\n\t\tconst seen = new Set();\r\n\r\n\t\ttasks.forEach(task => {\r\n\t\t\t// 4. ν΅μ¬: ν¨μ μ΄λ¦κ³Ό μΈμλ€μ λ¬Έμμ΄λ‘ ν©μ³μ μ λν¬ ν€ μμ±\r\n\t\t\t// JSON.stringifyλ₯Ό ν΅ν΄ [1, {a:1}] κ°μ νλΌλ―Έν°λ λ¬Έμμ΄λ‘ λΉκ΅ κ°λ₯\r\n\t\t\tconst identifier = `${task.func.name}_${JSON.stringify(task.args)}`;\r\n\r\n\t\t\tif (!seen.has(identifier)) {\r\n\t\t\t\t// 5. μ€λ³΅μ΄ μλ λλ§ μλ μΈμλ€(...args) κ·Έλλ‘ μ€ν\r\n\t\t\t\ttask.func(...task.args);\r\n\t\t\t\tseen.add(identifier);\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tthis.#timer = null;\r\n\t}\r\n}"],"names":["Trace","constructor","name","color","__privateAdd","this","_Trace_instances","_name","_color","_enabled","__privateSet","__privateMethod","autoConfig_fn","call","init","log","args","__privateGet","style","console","warn","error","enable","disable","WeakMap","WeakSet","window","location","hostname","startsWith","trace","_timer","_queue","_delay","_TaskDebouncer_instances","flush_fn","length","tasks","splice","seen","Set","forEach","task","identifier","func","JSON","stringify","has","add","delay","exec","push","clearTimeout","setTimeout"],"mappings":"onBAAO,MAAMA,EAKZ,WAAAC,CAAYC,EAAO,YAAaC,EAAQ,SALlCC,EAAAC,KAAAC,GACNF,EAAAC,KAAAE,GACAH,EAAAC,KAAAG,GACAJ,EAAAC,KAAAI,GAAW,GAGVC,EAAAL,KAAKE,EAAQL,GACbQ,EAAAL,KAAKG,EAASL,GAGdQ,EAAAN,KAAKC,EAAAM,GAALC,KAAAR,KACD,CAuBA,IAAAS,CAAKZ,EAAMC,EAAQ,SAClBO,EAAAL,KAAKE,EAAQL,GACbQ,EAAAL,KAAKG,EAASL,EACf,CAGA,GAAAY,IAAOC,GACN,IAAKC,OAAKR,GAAU,OACpB,MAAMS,EAAQ,UAAUD,EAAAZ,KAAKG,yBAC7BW,QAAQJ,IAAI,MAAME,EAAAZ,KAAKE,MAAUW,KAAUF,EAC5C,CAEA,IAAAI,IAAQJ,GACFC,OAAKR,IACVU,QAAQC,KAAK,MAAMH,EAAAZ,KAAKE,MAAU,qCAAsCS,EACzE,CAEA,KAAAK,IAASL,GACHC,OAAKR,IACVU,QAAQE,MAAM,MAAMJ,EAAAZ,KAAKE,MAAU,oCAAqCS,EACzE,CAEA,MAAAM,GAAWZ,EAAAL,KAAKI,GAAW,EAAM,CACjC,OAAAc,GAAYb,EAAAL,KAAKI,GAAW,EAAO,EAxDnCF,EAAA,IAAAiB,QACAhB,EAAA,IAAAgB,QACAf,EAAA,IAAAe,QAHMlB,EAAA,IAAAmB,QAaNb,EAAW,WACV,GAAsB,oBAAXc,OAAwB,OAEU,cAA7BA,OAAOC,SAASC,UACF,cAA7BF,OAAOC,SAASC,UAChBF,OAAOC,SAASC,SAASC,WAAW,YAGpCxB,KAAKiB,UAGLjB,KAAKkB,UAELJ,QAAQJ,IACP,MAAME,OAAKV,6DACX,qCAAsC,GACtC,qDAAsD,IAGzD,EA4BW,MAACuB,EAAQ,IAAI9B,EAGH,oBAAX0B,SACVA,OAAOI,MAAQA,GC/DfC,EAAA,IAAAP,QACAQ,EAAA,IAAAR,QACAS,EAAA,IAAAT,QAHMU,EAAA,IAAAT,QAyBNU,EAAM,WACL,GAA2B,IAAvBlB,EAAAZ,KAAK2B,GAAOI,OAAc,OAG9B,MAAMC,EAAQpB,EAAAZ,KAAK2B,GAAOM,OAAO,EAAGrB,EAAAZ,KAAK2B,GAAOI,QAC1CG,MAAWC,IAEjBH,EAAMI,QAAQC,IAGb,MAAMC,EAAa,GAAGD,EAAKE,KAAK1C,QAAQ2C,KAAKC,UAAUJ,EAAK1B,QAEvDuB,EAAKQ,IAAIJ,KAEbD,EAAKE,QAAQF,EAAK1B,MAClBuB,EAAKS,IAAIL,MAIXjC,EAAAL,KAAK0B,EAAS,KACf,kBA7CM,MAKN,WAAA9B,CAAYgD,EAAQ,IALd7C,EAAAC,KAAA6B,GACN9B,EAAAC,KAAA0B,EAAS,MACT3B,EAAAC,KAAA2B,EAAS,IACT5B,EAAAC,KAAA4B,GAGCvB,EAAAL,KAAK4B,EAASgB,EACf,CAMA,IAAAC,CAAKN,KAAS5B,GAEbC,EAAAZ,KAAK2B,GAAOmB,KAAK,CAAEP,OAAM5B,SAGrBC,EAAAZ,KAAK0B,IAAQqB,aAAanC,EAAAZ,KAAK0B,IAEnCrB,EAAAL,KAAK0B,EAASsB,WAAW,KACxB1C,EAAAN,KAAK6B,EAAAC,GAALtB,KAAAR,OACEY,OAAKgB,IACT"}
|