Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@kdujs/runtime-dom-canary

Package Overview
Dependencies
Maintainers
0
Versions
116
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@kdujs/runtime-dom-canary - npm Package Compare versions

Comparing version 3.20241209.0-minor.0 to 3.20241209.0

259

dist/runtime-dom.cjs.js

@@ -0,1 +1,6 @@

/**
* @kdujs/runtime-dom-canary v3.20241209.0
* (c) 2021-present NKDuy
* @license MIT
**/
'use strict';

@@ -9,2 +14,3 @@

const svgNS = "http://www.w3.org/2000/svg";
const mathmlNS = "http://www.w3.org/1998/Math/MathML";
const doc = typeof document !== "undefined" ? document : null;

@@ -22,4 +28,4 @@ const templateContainer = doc && /* @__PURE__ */ doc.createElement("template");

},
createElement: (tag, isSVG, is, props) => {
const el = isSVG ? doc.createElementNS(svgNS, tag) : doc.createElement(tag, is ? { is } : void 0);
createElement: (tag, namespace, is, props) => {
const el = namespace === "svg" ? doc.createElementNS(svgNS, tag) : namespace === "mathml" ? doc.createElementNS(mathmlNS, tag) : doc.createElement(tag, is ? { is } : void 0);
if (tag === "select" && props && props.multiple != null) {

@@ -48,3 +54,3 @@ el.setAttribute("multiple", props.multiple);

// As long as the user only uses trusted templates, this is safe.
insertStaticContent(content, parent, anchor, isSVG, start, end) {
insertStaticContent(content, parent, anchor, namespace, start, end) {
const before = anchor ? anchor.previousSibling : parent.lastChild;

@@ -54,9 +60,8 @@ if (start && (start === end || start.nextSibling)) {

parent.insertBefore(start.cloneNode(true), anchor);
if (start === end || !(start = start.nextSibling))
break;
if (start === end || !(start = start.nextSibling)) break;
}
} else {
templateContainer.innerHTML = isSVG ? `<svg>${content}</svg>` : content;
templateContainer.innerHTML = namespace === "svg" ? `<svg>${content}</svg>` : namespace === "mathml" ? `<math>${content}</math>` : content;
const template = templateContainer.content;
if (isSVG) {
if (namespace === "svg" || namespace === "mathml") {
const wrapper = template.firstChild;

@@ -197,4 +202,4 @@ while (wrapper.firstChild) {

addTransitionClass(el, leaveFromClass);
addTransitionClass(el, leaveActiveClass);
forceReflow();
addTransitionClass(el, leaveActiveClass);
nextFrame(() => {

@@ -341,4 +346,3 @@ if (!el._isLeaving) {

function toMs(s) {
if (s === "auto")
return 0;
if (s === "auto") return 0;
return Number(s.slice(0, -1).replace(",", ".")) * 1e3;

@@ -364,6 +368,7 @@ }

const kShowOldKey = Symbol("_kod");
const kShowOriginalDisplay = Symbol("_kod");
const kShowHidden = Symbol("_ksh");
const kShow = {
beforeMount(el, { value }, { transition }) {
el[kShowOldKey] = el.style.display === "none" ? "" : el.style.display;
el[kShowOriginalDisplay] = el.style.display === "none" ? "" : el.style.display;
if (transition && value) {

@@ -381,4 +386,3 @@ transition.beforeEnter(el);

updated(el, { value, oldValue }, { transition }) {
if (!value === !oldValue)
return;
if (!value === !oldValue) return;
if (transition) {

@@ -402,4 +406,8 @@ if (value) {

};
{
kShow.name = "show";
}
function setDisplay(el, value) {
el.style.display = value ? el[kShowOldKey] : "none";
el.style.display = value ? el[kShowOriginalDisplay] : "none";
el[kShowHidden] = !value;
}

@@ -414,21 +422,44 @@ function initKShowForSSR() {

const CSS_VAR_TEXT = Symbol("CSS_VAR_TEXT" );
function useCssVars(getter) {
return;
}
const displayRE = /(^|;)\s*display\s*:/;
function patchStyle(el, prev, next) {
const style = el.style;
const isCssString = shared.isString(next);
let hasControlledDisplay = false;
if (next && !isCssString) {
if (prev && !shared.isString(prev)) {
for (const key in prev) {
if (next[key] == null) {
setStyle(style, key, "");
if (prev) {
if (!shared.isString(prev)) {
for (const key in prev) {
if (next[key] == null) {
setStyle(style, key, "");
}
}
} else {
for (const prevStyle of prev.split(";")) {
const key = prevStyle.slice(0, prevStyle.indexOf(":")).trim();
if (next[key] == null) {
setStyle(style, key, "");
}
}
}
}
for (const key in next) {
if (key === "display") {
hasControlledDisplay = true;
}
setStyle(style, key, next[key]);
}
} else {
const currentDisplay = style.display;
if (isCssString) {
if (prev !== next) {
const cssVarText = style[CSS_VAR_TEXT];
if (cssVarText) {
next += ";" + cssVarText;
}
style.cssText = next;
hasControlledDisplay = displayRE.test(next);
}

@@ -438,4 +469,7 @@ } else if (prev) {

}
if (kShowOldKey in el) {
style.display = currentDisplay;
}
if (kShowOriginalDisplay in el) {
el[kShowOriginalDisplay] = hasControlledDisplay ? style.display : "";
if (el[kShowHidden]) {
style.display = "none";
}

@@ -450,4 +484,3 @@ }

} else {
if (val == null)
val = "";
if (val == null) val = "";
{

@@ -526,6 +559,5 @@ if (semicolonRE.test(val)) {

!tag.includes("-")) {
el._value = value;
const oldValue = tag === "OPTION" ? el.getAttribute("value") : el.value;
const oldValue = tag === "OPTION" ? el.getAttribute("value") || "" : el.value;
const newValue = value == null ? "" : value;
if (oldValue !== newValue) {
if (oldValue !== newValue || !("_value" in el)) {
el.value = newValue;

@@ -536,2 +568,3 @@ }

}
el._value = value;
return;

@@ -576,7 +609,10 @@ }

if (nextValue && existingInvoker) {
existingInvoker.value = nextValue;
existingInvoker.value = sanitizeEventValue(nextValue, rawName) ;
} else {
const [name, options] = parseName(rawName);
if (nextValue) {
const invoker = invokers[rawName] = createInvoker(nextValue, instance);
const invoker = invokers[rawName] = createInvoker(
sanitizeEventValue(nextValue, rawName) ,
instance
);
addEventListener(el, name, invoker, options);

@@ -624,2 +660,12 @@ } else if (existingInvoker) {

}
function sanitizeEventValue(value, propName) {
if (shared.isFunction(value) || shared.isArray(value)) {
return value;
}
runtimeCore.warn(
`Wrong type passed as event handler to ${propName} - did you forget @ or : in front of your prop?
Expected function or array of functions, received type ${typeof value}.`
);
return shared.NOOP;
}
function patchStopImmediatePropagation(e, value) {

@@ -632,3 +678,5 @@ if (shared.isArray(value)) {

};
return value.map((fn) => (e2) => !e2._stopped && fn && fn(e2));
return value.map(
(fn) => (e2) => !e2._stopped && fn && fn(e2)
);
} else {

@@ -639,4 +687,6 @@ return value;

const nativeOnRE = /^on[a-z]/;
const patchProp = (el, key, prevValue, nextValue, isSVG = false, prevChildren, parentComponent, parentSuspense, unmountChildren) => {
const isNativeOn = (key) => key.charCodeAt(0) === 111 && key.charCodeAt(1) === 110 && // lowercase letter
key.charCodeAt(2) > 96 && key.charCodeAt(2) < 123;
const patchProp = (el, key, prevValue, nextValue, namespace, prevChildren, parentComponent, parentSuspense, unmountChildren) => {
const isSVG = namespace === "svg";
if (key === "class") {

@@ -674,3 +724,3 @@ patchClass(el, nextValue, isSVG);

}
if (key in el && nativeOnRE.test(key) && shared.isFunction(value)) {
if (key in el && isNativeOn(key) && shared.isFunction(value)) {
return true;

@@ -692,3 +742,9 @@ }

}
if (nativeOnRE.test(key) && shared.isString(value)) {
if (key === "width" || key === "height") {
const tag = el.tagName;
if (tag === "IMG" || tag === "VIDEO" || tag === "CANVAS" || tag === "SOURCE") {
return false;
}
}
if (isNativeOn(key) && shared.isString(value)) {
return false;

@@ -756,8 +812,8 @@ }

this._connected = false;
if (this._ob) {
this._ob.disconnect();
this._ob = null;
}
runtimeCore.nextTick(() => {
if (!this._connected) {
if (this._ob) {
this._ob.disconnect();
this._ob = null;
}
render(null, this.shadowRoot);

@@ -830,3 +886,3 @@ this._instance = null;

_setAttr(key) {
let value = this.getAttribute(key);
let value = this.hasAttribute(key) ? this.getAttribute(key) : void 0;
const camelKey = shared.camelize(key);

@@ -944,6 +1000,2 @@ if (this._numberProps && this._numberProps[camelKey]) {

function useCssVars(getter) {
return;
}
const positionMap = /* @__PURE__ */ new WeakMap();

@@ -1002,3 +1054,24 @@ const newPositionMap = /* @__PURE__ */ new WeakMap();

let tag = rawProps.tag || runtimeCore.Fragment;
prevChildren = children;
prevChildren = [];
if (children) {
for (let i = 0; i < children.length; i++) {
const child = children[i];
if (child.el && child.el instanceof Element) {
prevChildren.push(child);
runtimeCore.setTransitionHooks(
child,
runtimeCore.resolveTransitionHooks(
child,
cssTransitionProps,
state,
instance
)
);
positionMap.set(
child,
child.el.getBoundingClientRect()
);
}
}
}
children = slots.default ? runtimeCore.getTransitionRawChildren(slots.default()) : [];

@@ -1016,12 +1089,2 @@ for (let i = 0; i < children.length; i++) {

}
if (prevChildren) {
for (let i = 0; i < prevChildren.length; i++) {
const child = prevChildren[i];
runtimeCore.setTransitionHooks(
child,
runtimeCore.resolveTransitionHooks(child, cssTransitionProps, state, instance)
);
positionMap.set(child, child.el.getBoundingClientRect());
}
}
return runtimeCore.createKNode(tag, null, children);

@@ -1095,4 +1158,3 @@ };

addEventListener(el, lazy ? "change" : "input", (e) => {
if (e.target.composing)
return;
if (e.target.composing) return;
let domValue = el.value;

@@ -1124,4 +1186,8 @@ if (trim) {

el[assignKey] = getModelAssigner(knode);
if (el.composing)
if (el.composing) return;
const elValue = (number || el.type === "number") && !/^0\d/.test(el.value) ? shared.looseToNumber(el.value) : el.value;
const newValue = value == null ? "" : value;
if (elValue === newValue) {
return;
}
if (document.activeElement === el && el.type !== "range") {

@@ -1131,13 +1197,7 @@ if (lazy) {

}
if (trim && el.value.trim() === value) {
if (trim && el.value.trim() === newValue) {
return;
}
if ((number || el.type === "number") && shared.looseToNumber(el.value) === value) {
return;
}
}
const newValue = value == null ? "" : value;
if (el.value !== newValue) {
el.value = newValue;
}
el.value = newValue;
}

@@ -1222,2 +1282,6 @@ };

);
el._assigning = true;
runtimeCore.nextTick(() => {
el._assigning = false;
});
});

@@ -1228,3 +1292,3 @@ el[assignKey] = getModelAssigner(knode);

// <option>s.
mounted(el, { value }) {
mounted(el, { value, modifiers: { number } }) {
setSelected(el, value);

@@ -1235,9 +1299,12 @@ },

},
updated(el, { value }) {
setSelected(el, value);
updated(el, { value, modifiers: { number } }) {
if (!el._assigning) {
setSelected(el, value);
}
}
};
function setSelected(el, value) {
function setSelected(el, value, number) {
const isMultiple = el.multiple;
if (isMultiple && !shared.isArray(value) && !shared.isSet(value)) {
const isArrayValue = shared.isArray(value);
if (isMultiple && !isArrayValue && !shared.isSet(value)) {
runtimeCore.warn(

@@ -1252,13 +1319,15 @@ `<select multiple k-model> expects an Array or Set value for its binding, but got ${Object.prototype.toString.call(value).slice(8, -1)}.`

if (isMultiple) {
if (shared.isArray(value)) {
option.selected = shared.looseIndexOf(value, optionValue) > -1;
if (isArrayValue) {
const optionType = typeof optionValue;
if (optionType === "string" || optionType === "number") {
option.selected = value.some((v) => String(v) === String(optionValue));
} else {
option.selected = shared.looseIndexOf(value, optionValue) > -1;
}
} else {
option.selected = value.has(optionValue);
}
} else {
if (shared.looseEqual(getValue(option), value)) {
if (el.selectedIndex !== i)
el.selectedIndex = i;
return;
}
} else if (shared.looseEqual(getValue(option), value)) {
if (el.selectedIndex !== i) el.selectedIndex = i;
return;
}

@@ -1366,10 +1435,11 @@ }

const withModifiers = (fn, modifiers) => {
return (event, ...args) => {
const cache = fn._withMods || (fn._withMods = {});
const cacheKey = modifiers.join(".");
return cache[cacheKey] || (cache[cacheKey] = (event, ...args) => {
for (let i = 0; i < modifiers.length; i++) {
const guard = modifierGuards[modifiers[i]];
if (guard && guard(event, modifiers))
return;
if (guard && guard(event, modifiers)) return;
}
return fn(event, ...args);
};
});
};

@@ -1386,3 +1456,5 @@ const keyNames = {

const withKeys = (fn, modifiers) => {
return (event) => {
const cache = fn._withKeys || (fn._withKeys = {});
const cacheKey = modifiers.join(".");
return cache[cacheKey] || (cache[cacheKey] = (event) => {
if (!("key" in event)) {

@@ -1395,3 +1467,3 @@ return;

}
};
});
};

@@ -1425,4 +1497,3 @@

const container = normalizeContainer(containerOrSelector);
if (!container)
return;
if (!container) return;
const component = app._component;

@@ -1433,3 +1504,3 @@ if (!shared.isFunction(component) && !component.render && !component.template) {

container.innerHTML = "";
const proxy = mount(container, false, container instanceof SVGElement);
const proxy = mount(container, false, resolveRootNamespace(container));
if (container instanceof Element) {

@@ -1453,3 +1524,3 @@ container.removeAttribute("k-cloak");

if (container) {
return mount(container, true, container instanceof SVGElement);
return mount(container, true, resolveRootNamespace(container));
}

@@ -1459,5 +1530,13 @@ };

};
function resolveRootNamespace(container) {
if (container instanceof SVGElement) {
return "svg";
}
if (typeof MathMLElement === "function" && container instanceof MathMLElement) {
return "mathml";
}
}
function injectNativeTagCheck(app) {
Object.defineProperty(app.config, "isNativeTag", {
value: (tag) => shared.isHTMLTag(tag) || shared.isSVGTag(tag),
value: (tag) => shared.isHTMLTag(tag) || shared.isSVGTag(tag) || shared.isMathMLTag(tag),
writable: false

@@ -1483,3 +1562,3 @@ });

- For kdu-cli: see https://kdujs-cli.web.app/guide/webpack.html#modifying-options-of-a-loader
- For wite: pass it via @witejs/plugin-kdu options.`;
- For lahm: pass it via @lahmjs/plugin-kdu options.`;
Object.defineProperty(app.config, "compilerOptions", {

@@ -1486,0 +1565,0 @@ get() {

@@ -0,1 +1,6 @@

/**
* @kdujs/runtime-dom-canary v3.20241209.0
* (c) 2021-present NKDuy
* @license MIT
**/
'use strict';

@@ -9,2 +14,3 @@

const svgNS = "http://www.w3.org/2000/svg";
const mathmlNS = "http://www.w3.org/1998/Math/MathML";
const doc = typeof document !== "undefined" ? document : null;

@@ -22,4 +28,4 @@ const templateContainer = doc && /* @__PURE__ */ doc.createElement("template");

},
createElement: (tag, isSVG, is, props) => {
const el = isSVG ? doc.createElementNS(svgNS, tag) : doc.createElement(tag, is ? { is } : void 0);
createElement: (tag, namespace, is, props) => {
const el = namespace === "svg" ? doc.createElementNS(svgNS, tag) : namespace === "mathml" ? doc.createElementNS(mathmlNS, tag) : doc.createElement(tag, is ? { is } : void 0);
if (tag === "select" && props && props.multiple != null) {

@@ -48,3 +54,3 @@ el.setAttribute("multiple", props.multiple);

// As long as the user only uses trusted templates, this is safe.
insertStaticContent(content, parent, anchor, isSVG, start, end) {
insertStaticContent(content, parent, anchor, namespace, start, end) {
const before = anchor ? anchor.previousSibling : parent.lastChild;

@@ -54,9 +60,8 @@ if (start && (start === end || start.nextSibling)) {

parent.insertBefore(start.cloneNode(true), anchor);
if (start === end || !(start = start.nextSibling))
break;
if (start === end || !(start = start.nextSibling)) break;
}
} else {
templateContainer.innerHTML = isSVG ? `<svg>${content}</svg>` : content;
templateContainer.innerHTML = namespace === "svg" ? `<svg>${content}</svg>` : namespace === "mathml" ? `<math>${content}</math>` : content;
const template = templateContainer.content;
if (isSVG) {
if (namespace === "svg" || namespace === "mathml") {
const wrapper = template.firstChild;

@@ -197,4 +202,4 @@ while (wrapper.firstChild) {

addTransitionClass(el, leaveFromClass);
addTransitionClass(el, leaveActiveClass);
forceReflow();
addTransitionClass(el, leaveActiveClass);
nextFrame(() => {

@@ -338,4 +343,3 @@ if (!el._isLeaving) {

function toMs(s) {
if (s === "auto")
return 0;
if (s === "auto") return 0;
return Number(s.slice(0, -1).replace(",", ".")) * 1e3;

@@ -361,6 +365,7 @@ }

const kShowOldKey = Symbol("_kod");
const kShowOriginalDisplay = Symbol("_kod");
const kShowHidden = Symbol("_ksh");
const kShow = {
beforeMount(el, { value }, { transition }) {
el[kShowOldKey] = el.style.display === "none" ? "" : el.style.display;
el[kShowOriginalDisplay] = el.style.display === "none" ? "" : el.style.display;
if (transition && value) {

@@ -378,4 +383,3 @@ transition.beforeEnter(el);

updated(el, { value, oldValue }, { transition }) {
if (!value === !oldValue)
return;
if (!value === !oldValue) return;
if (transition) {

@@ -400,3 +404,4 @@ if (value) {

function setDisplay(el, value) {
el.style.display = value ? el[kShowOldKey] : "none";
el.style.display = value ? el[kShowOriginalDisplay] : "none";
el[kShowHidden] = !value;
}

@@ -411,21 +416,44 @@ function initKShowForSSR() {

const CSS_VAR_TEXT = Symbol("");
function useCssVars(getter) {
return;
}
const displayRE = /(^|;)\s*display\s*:/;
function patchStyle(el, prev, next) {
const style = el.style;
const isCssString = shared.isString(next);
let hasControlledDisplay = false;
if (next && !isCssString) {
if (prev && !shared.isString(prev)) {
for (const key in prev) {
if (next[key] == null) {
setStyle(style, key, "");
if (prev) {
if (!shared.isString(prev)) {
for (const key in prev) {
if (next[key] == null) {
setStyle(style, key, "");
}
}
} else {
for (const prevStyle of prev.split(";")) {
const key = prevStyle.slice(0, prevStyle.indexOf(":")).trim();
if (next[key] == null) {
setStyle(style, key, "");
}
}
}
}
for (const key in next) {
if (key === "display") {
hasControlledDisplay = true;
}
setStyle(style, key, next[key]);
}
} else {
const currentDisplay = style.display;
if (isCssString) {
if (prev !== next) {
const cssVarText = style[CSS_VAR_TEXT];
if (cssVarText) {
next += ";" + cssVarText;
}
style.cssText = next;
hasControlledDisplay = displayRE.test(next);
}

@@ -435,4 +463,7 @@ } else if (prev) {

}
if (kShowOldKey in el) {
style.display = currentDisplay;
}
if (kShowOriginalDisplay in el) {
el[kShowOriginalDisplay] = hasControlledDisplay ? style.display : "";
if (el[kShowHidden]) {
style.display = "none";
}

@@ -446,4 +477,3 @@ }

} else {
if (val == null)
val = "";
if (val == null) val = "";
if (name.startsWith("--")) {

@@ -515,6 +545,5 @@ style.setProperty(name, val);

!tag.includes("-")) {
el._value = value;
const oldValue = tag === "OPTION" ? el.getAttribute("value") : el.value;
const oldValue = tag === "OPTION" ? el.getAttribute("value") || "" : el.value;
const newValue = value == null ? "" : value;
if (oldValue !== newValue) {
if (oldValue !== newValue || !("_value" in el)) {
el.value = newValue;

@@ -525,2 +554,3 @@ }

}
el._value = value;
return;

@@ -563,3 +593,6 @@ }

if (nextValue) {
const invoker = invokers[rawName] = createInvoker(nextValue, instance);
const invoker = invokers[rawName] = createInvoker(
nextValue,
instance
);
addEventListener(el, name, invoker, options);

@@ -614,3 +647,5 @@ } else if (existingInvoker) {

};
return value.map((fn) => (e2) => !e2._stopped && fn && fn(e2));
return value.map(
(fn) => (e2) => !e2._stopped && fn && fn(e2)
);
} else {

@@ -621,4 +656,6 @@ return value;

const nativeOnRE = /^on[a-z]/;
const patchProp = (el, key, prevValue, nextValue, isSVG = false, prevChildren, parentComponent, parentSuspense, unmountChildren) => {
const isNativeOn = (key) => key.charCodeAt(0) === 111 && key.charCodeAt(1) === 110 && // lowercase letter
key.charCodeAt(2) > 96 && key.charCodeAt(2) < 123;
const patchProp = (el, key, prevValue, nextValue, namespace, prevChildren, parentComponent, parentSuspense, unmountChildren) => {
const isSVG = namespace === "svg";
if (key === "class") {

@@ -656,3 +693,3 @@ patchClass(el, nextValue, isSVG);

}
if (key in el && nativeOnRE.test(key) && shared.isFunction(value)) {
if (key in el && isNativeOn(key) && shared.isFunction(value)) {
return true;

@@ -674,3 +711,9 @@ }

}
if (nativeOnRE.test(key) && shared.isString(value)) {
if (key === "width" || key === "height") {
const tag = el.tagName;
if (tag === "IMG" || tag === "VIDEO" || tag === "CANVAS" || tag === "SOURCE") {
return false;
}
}
if (isNativeOn(key) && shared.isString(value)) {
return false;

@@ -733,8 +776,8 @@ }

this._connected = false;
if (this._ob) {
this._ob.disconnect();
this._ob = null;
}
runtimeCore.nextTick(() => {
if (!this._connected) {
if (this._ob) {
this._ob.disconnect();
this._ob = null;
}
render(null, this.shadowRoot);

@@ -807,3 +850,3 @@ this._instance = null;

_setAttr(key) {
let value = this.getAttribute(key);
let value = this.hasAttribute(key) ? this.getAttribute(key) : void 0;
const camelKey = shared.camelize(key);

@@ -904,6 +947,2 @@ if (this._numberProps && this._numberProps[camelKey]) {

function useCssVars(getter) {
return;
}
const positionMap = /* @__PURE__ */ new WeakMap();

@@ -962,3 +1001,24 @@ const newPositionMap = /* @__PURE__ */ new WeakMap();

let tag = rawProps.tag || runtimeCore.Fragment;
prevChildren = children;
prevChildren = [];
if (children) {
for (let i = 0; i < children.length; i++) {
const child = children[i];
if (child.el && child.el instanceof Element) {
prevChildren.push(child);
runtimeCore.setTransitionHooks(
child,
runtimeCore.resolveTransitionHooks(
child,
cssTransitionProps,
state,
instance
)
);
positionMap.set(
child,
child.el.getBoundingClientRect()
);
}
}
}
children = slots.default ? runtimeCore.getTransitionRawChildren(slots.default()) : [];

@@ -974,12 +1034,2 @@ for (let i = 0; i < children.length; i++) {

}
if (prevChildren) {
for (let i = 0; i < prevChildren.length; i++) {
const child = prevChildren[i];
runtimeCore.setTransitionHooks(
child,
runtimeCore.resolveTransitionHooks(child, cssTransitionProps, state, instance)
);
positionMap.set(child, child.el.getBoundingClientRect());
}
}
return runtimeCore.createKNode(tag, null, children);

@@ -1053,4 +1103,3 @@ };

addEventListener(el, lazy ? "change" : "input", (e) => {
if (e.target.composing)
return;
if (e.target.composing) return;
let domValue = el.value;

@@ -1082,4 +1131,8 @@ if (trim) {

el[assignKey] = getModelAssigner(knode);
if (el.composing)
if (el.composing) return;
const elValue = (number || el.type === "number") && !/^0\d/.test(el.value) ? shared.looseToNumber(el.value) : el.value;
const newValue = value == null ? "" : value;
if (elValue === newValue) {
return;
}
if (document.activeElement === el && el.type !== "range") {

@@ -1089,13 +1142,7 @@ if (lazy) {

}
if (trim && el.value.trim() === value) {
if (trim && el.value.trim() === newValue) {
return;
}
if ((number || el.type === "number") && shared.looseToNumber(el.value) === value) {
return;
}
}
const newValue = value == null ? "" : value;
if (el.value !== newValue) {
el.value = newValue;
}
el.value = newValue;
}

@@ -1180,2 +1227,6 @@ };

);
el._assigning = true;
runtimeCore.nextTick(() => {
el._assigning = false;
});
});

@@ -1186,3 +1237,3 @@ el[assignKey] = getModelAssigner(knode);

// <option>s.
mounted(el, { value }) {
mounted(el, { value, modifiers: { number } }) {
setSelected(el, value);

@@ -1193,9 +1244,12 @@ },

},
updated(el, { value }) {
setSelected(el, value);
updated(el, { value, modifiers: { number } }) {
if (!el._assigning) {
setSelected(el, value);
}
}
};
function setSelected(el, value) {
function setSelected(el, value, number) {
const isMultiple = el.multiple;
if (isMultiple && !shared.isArray(value) && !shared.isSet(value)) {
const isArrayValue = shared.isArray(value);
if (isMultiple && !isArrayValue && !shared.isSet(value)) {
return;

@@ -1207,13 +1261,15 @@ }

if (isMultiple) {
if (shared.isArray(value)) {
option.selected = shared.looseIndexOf(value, optionValue) > -1;
if (isArrayValue) {
const optionType = typeof optionValue;
if (optionType === "string" || optionType === "number") {
option.selected = value.some((v) => String(v) === String(optionValue));
} else {
option.selected = shared.looseIndexOf(value, optionValue) > -1;
}
} else {
option.selected = value.has(optionValue);
}
} else {
if (shared.looseEqual(getValue(option), value)) {
if (el.selectedIndex !== i)
el.selectedIndex = i;
return;
}
} else if (shared.looseEqual(getValue(option), value)) {
if (el.selectedIndex !== i) el.selectedIndex = i;
return;
}

@@ -1321,10 +1377,11 @@ }

const withModifiers = (fn, modifiers) => {
return (event, ...args) => {
const cache = fn._withMods || (fn._withMods = {});
const cacheKey = modifiers.join(".");
return cache[cacheKey] || (cache[cacheKey] = (event, ...args) => {
for (let i = 0; i < modifiers.length; i++) {
const guard = modifierGuards[modifiers[i]];
if (guard && guard(event, modifiers))
return;
if (guard && guard(event, modifiers)) return;
}
return fn(event, ...args);
};
});
};

@@ -1341,3 +1398,5 @@ const keyNames = {

const withKeys = (fn, modifiers) => {
return (event) => {
const cache = fn._withKeys || (fn._withKeys = {});
const cacheKey = modifiers.join(".");
return cache[cacheKey] || (cache[cacheKey] = (event) => {
if (!("key" in event)) {

@@ -1350,3 +1409,3 @@ return;

}
};
});
};

@@ -1376,4 +1435,3 @@

const container = normalizeContainer(containerOrSelector);
if (!container)
return;
if (!container) return;
const component = app._component;

@@ -1384,3 +1442,3 @@ if (!shared.isFunction(component) && !component.render && !component.template) {

container.innerHTML = "";
const proxy = mount(container, false, container instanceof SVGElement);
const proxy = mount(container, false, resolveRootNamespace(container));
if (container instanceof Element) {

@@ -1400,3 +1458,3 @@ container.removeAttribute("k-cloak");

if (container) {
return mount(container, true, container instanceof SVGElement);
return mount(container, true, resolveRootNamespace(container));
}

@@ -1406,2 +1464,10 @@ };

};
function resolveRootNamespace(container) {
if (container instanceof SVGElement) {
return "svg";
}
if (typeof MathMLElement === "function" && container instanceof MathMLElement) {
return "mathml";
}
}
function normalizeContainer(container) {

@@ -1408,0 +1474,0 @@ if (shared.isString(container)) {

@@ -1,2 +0,2 @@

import { SetupContext, RenderFunction, ComputedOptions, MethodOptions, ComponentOptionsMixin, EmitsOptions, ComponentInjectOptions, SlotsType, ComponentOptionsWithoutProps, ComponentOptionsWithArrayProps, ComponentPropsOptions, ComponentOptionsWithObjectProps, ExtractPropTypes, ComponentPublicInstance, RootHydrateFunction, ConcreteComponent, BaseTransitionProps, FunctionalComponent, ObjectDirective, KNodeRef, RootRenderFunction, CreateAppFunction } from '@kdujs/runtime-core';
import { SetupContext, RenderFunction, ComputedOptions, MethodOptions, ComponentOptionsMixin, EmitsOptions, ComponentInjectOptions, SlotsType, ComponentOptionsWithoutProps, ComponentOptionsWithArrayProps, ComponentPropsOptions, ComponentOptionsWithObjectProps, ExtractPropTypes, DefineComponent, RootHydrateFunction, ConcreteComponent, BaseTransitionProps, FunctionalComponent, ObjectDirective, KNodeRef, RootRenderFunction, CreateAppFunction } from '@kdujs/runtime-core';
export * from '@kdujs/runtime-core';

@@ -20,5 +20,3 @@ import * as CSS from 'csstype';

}): KduElementConstructor<ExtractPropTypes<PropsOptions>>;
export declare function defineCustomElement(options: {
new (...args: any[]): ComponentPublicInstance;
}): KduElementConstructor;
export declare function defineCustomElement<P>(options: DefineComponent<P, any, any, any>): KduElementConstructor<ExtractPropTypes<P>>;
/*! #__NO_SIDE_EFFECTS__ */

@@ -98,2 +96,3 @@ export declare const defineSSRCustomElement: typeof defineCustomElement;

[assignKey]: AssignerFn;
_assigning?: boolean;
}>;

@@ -106,16 +105,29 @@ export declare const kModelText: ModelDirective<HTMLInputElement | HTMLTextAreaElement>;

type ModifierGuardsKeys = 'stop' | 'prevent' | 'self' | 'ctrl' | 'shift' | 'alt' | 'meta' | 'left' | 'middle' | 'right' | 'exact';
/**
* @private
*/
export declare const withModifiers: (fn: Function, modifiers: string[]) => (event: Event, ...args: unknown[]) => any;
export declare const withModifiers: <T extends (event: Event, ...args: unknown[]) => any>(fn: T & {
_withMods?: {
[key: string]: T;
};
}, modifiers: ModifierGuardsKeys[]) => T;
/**
* @private
*/
export declare const withKeys: (fn: Function, modifiers: string[]) => (event: KeyboardEvent) => any;
export declare const withKeys: <T extends (event: KeyboardEvent) => any>(fn: T & {
_withKeys?: {
[k: string]: T;
};
}, modifiers: string[]) => T;
declare const kShowOldKey: unique symbol;
declare const kShowOriginalDisplay: unique symbol;
declare const kShowHidden: unique symbol;
interface KShowElement extends HTMLElement {
[kShowOldKey]: string;
[kShowOriginalDisplay]: string;
[kShowHidden]: boolean;
}
export declare const kShow: ObjectDirective<KShowElement>;
export declare const kShow: ObjectDirective<KShowElement> & {
name?: 'show';
};

@@ -135,3 +147,3 @@ export interface CSSProperties extends CSS.Properties<string | number>, CSS.PropertiesHyphen<string | number> {

type Numberish = number | string;
interface AriaAttributes {
export interface AriaAttributes {
/** Identifies the currently active element when DOM focus is on a composite widget, textbox, group, or application. */

@@ -278,3 +290,3 @@ 'aria-activedescendant'?: string;

*/
'aria-relevant'?: 'additions' | 'additions text' | 'all' | 'removals' | 'text';
'aria-relevant'?: 'additions' | 'additions removals' | 'additions text' | 'all' | 'removals' | 'removals additions' | 'removals text' | 'text' | 'text additions' | 'text removals';
/** Indicates that user input is required on the element before a form may be submitted. */

@@ -323,3 +335,3 @@ 'aria-required'?: Booleanish;

}
export type StyleValue = string | CSSProperties | Array<StyleValue>;
export type StyleValue = false | null | undefined | string | CSSProperties | Array<StyleValue>;
export interface HTMLAttributes extends AriaAttributes, EventHandlers<Events> {

@@ -330,3 +342,3 @@ innerHTML?: string;

accesskey?: string;
contenteditable?: Booleanish | 'inherit';
contenteditable?: Booleanish | 'inherit' | 'plaintext-only';
contextmenu?: string;

@@ -421,3 +433,3 @@ dir?: string;

type?: 'submit' | 'reset' | 'button';
value?: string | string[] | number;
value?: string | ReadonlyArray<string> | number;
}

@@ -436,6 +448,7 @@ export interface CanvasHTMLAttributes extends HTMLAttributes {

export interface DataHTMLAttributes extends HTMLAttributes {
value?: string | string[] | number;
value?: string | ReadonlyArray<string> | number;
}
export interface DetailsHTMLAttributes extends HTMLAttributes {
open?: Booleanish;
onToggle?: (payload: ToggleEvent) => void;
}

@@ -477,5 +490,8 @@ export interface DelHTMLAttributes extends HTMLAttributes {

allowtransparency?: Booleanish;
/** @deprecated */
frameborder?: Numberish;
height?: Numberish;
/** @deprecated */
marginheight?: Numberish;
/** @deprecated */
marginwidth?: Numberish;

@@ -485,2 +501,3 @@ name?: string;

sandbox?: string;
/** @deprecated */
scrolling?: string;

@@ -497,2 +514,3 @@ seamless?: Booleanish;

height?: Numberish;
loading?: 'eager' | 'lazy';
referrerpolicy?: HTMLAttributeReferrerPolicy;

@@ -504,3 +522,2 @@ sizes?: string;

width?: Numberish;
loading?: 'lazy' | 'eager';
}

@@ -521,2 +538,3 @@ export interface InsHTMLAttributes extends HTMLAttributes {

disabled?: Booleanish;
enterKeyHint?: 'enter' | 'done' | 'go' | 'next' | 'previous' | 'search' | 'send';
form?: string;

@@ -562,3 +580,3 @@ formaction?: string;

export interface LiHTMLAttributes extends HTMLAttributes {
value?: string | string[] | number;
value?: string | ReadonlyArray<string> | number;
}

@@ -576,2 +594,3 @@ export interface LinkHTMLAttributes extends HTMLAttributes {

type?: string;
charset?: string;
}

@@ -609,3 +628,3 @@ export interface MapHTMLAttributes extends HTMLAttributes {

optimum?: Numberish;
value?: string | string[] | number;
value?: string | ReadonlyArray<string> | number;
}

@@ -648,10 +667,11 @@ export interface QuoteHTMLAttributes extends HTMLAttributes {

name?: string;
value?: string | string[] | number;
value?: string | ReadonlyArray<string> | number;
}
export interface ProgressHTMLAttributes extends HTMLAttributes {
max?: Numberish;
value?: string | string[] | number;
value?: string | ReadonlyArray<string> | number;
}
export interface ScriptHTMLAttributes extends HTMLAttributes {
async?: Booleanish;
/** @deprecated */
charset?: string;

@@ -695,2 +715,3 @@ crossorigin?: string;

summary?: string;
width?: Numberish;
}

@@ -711,3 +732,3 @@ export interface TextareaHTMLAttributes extends HTMLAttributes {

rows?: Numberish;
value?: string | string[] | number;
value?: string | ReadonlyArray<string> | number | null;
wrap?: string;

@@ -721,2 +742,5 @@ }

scope?: string;
abbr?: string;
height?: Numberish;
width?: Numberish;
valign?: 'top' | 'middle' | 'bottom' | 'baseline';

@@ -730,2 +754,3 @@ }

scope?: string;
abbr?: string;
}

@@ -748,2 +773,3 @@ export interface TimeHTMLAttributes extends HTMLAttributes {

disablePictureInPicture?: Booleanish;
disableRemotePlayback?: Booleanish;
}

@@ -791,2 +817,3 @@ export interface WebViewHTMLAttributes extends HTMLAttributes {

tabindex?: Numberish;
crossOrigin?: 'anonymous' | 'use-credentials' | '';
'accent-height'?: Numberish;

@@ -1022,2 +1049,3 @@ accumulate?: 'none' | 'sum';

xmlns?: string;
xmlnsXlink?: string;
y1?: Numberish;

@@ -1268,3 +1296,4 @@ y2?: Numberish;

onSelect: Event;
onScroll: UIEvent;
onScroll: Event;
onScrollend: Event;
onTouchcancel: TouchEvent;

@@ -1271,0 +1300,0 @@ onTouchend: TouchEvent;

@@ -1,6 +0,12 @@

import { h, BaseTransition, BaseTransitionPropsValidators, assertNumber, warn, camelize, callWithAsyncErrorHandling, defineComponent, nextTick, createKNode, getCurrentInstance, watchPostEffect, onMounted, onUnmounted, Fragment, Static, useTransitionState, onUpdated, toRaw, getTransitionRawChildren, setTransitionHooks, resolveTransitionHooks, isRuntimeOnly, createRenderer, createHydrationRenderer } from '@kdujs/runtime-core';
/**
* @kdujs/runtime-dom-canary v3.20241209.0
* (c) 2021-present NKDuy
* @license MIT
**/
import { h, BaseTransition, BaseTransitionPropsValidators, assertNumber, getCurrentInstance, warn, onMounted, watchPostEffect, onUnmounted, Fragment, Static, camelize, callWithAsyncErrorHandling, defineComponent, nextTick, createKNode, useTransitionState, onUpdated, toRaw, getTransitionRawChildren, setTransitionHooks, resolveTransitionHooks, isRuntimeOnly, createRenderer, createHydrationRenderer } from '@kdujs/runtime-core';
export * from '@kdujs/runtime-core';
import { extend, isObject, toNumber, isArray, isString, hyphenate, capitalize, isSpecialBooleanAttr, includeBooleanAttr, isOn, isModelListener, isFunction, camelize as camelize$1, EMPTY_OBJ, looseToNumber, looseIndexOf, isSet, looseEqual, invokeArrayFns, isHTMLTag, isSVGTag } from '@kdujs/shared';
import { extend, isObject, toNumber, isArray, isString, hyphenate, capitalize, isSpecialBooleanAttr, includeBooleanAttr, isFunction, NOOP, isOn, isModelListener, camelize as camelize$1, EMPTY_OBJ, looseToNumber, looseIndexOf, isSet, looseEqual, invokeArrayFns, isHTMLTag, isSVGTag, isMathMLTag } from '@kdujs/shared';
const svgNS = "http://www.w3.org/2000/svg";
const mathmlNS = "http://www.w3.org/1998/Math/MathML";
const doc = typeof document !== "undefined" ? document : null;

@@ -18,4 +24,4 @@ const templateContainer = doc && /* @__PURE__ */ doc.createElement("template");

},
createElement: (tag, isSVG, is, props) => {
const el = isSVG ? doc.createElementNS(svgNS, tag) : doc.createElement(tag, is ? { is } : void 0);
createElement: (tag, namespace, is, props) => {
const el = namespace === "svg" ? doc.createElementNS(svgNS, tag) : namespace === "mathml" ? doc.createElementNS(mathmlNS, tag) : doc.createElement(tag, is ? { is } : void 0);
if (tag === "select" && props && props.multiple != null) {

@@ -44,3 +50,3 @@ el.setAttribute("multiple", props.multiple);

// As long as the user only uses trusted templates, this is safe.
insertStaticContent(content, parent, anchor, isSVG, start, end) {
insertStaticContent(content, parent, anchor, namespace, start, end) {
const before = anchor ? anchor.previousSibling : parent.lastChild;

@@ -50,9 +56,8 @@ if (start && (start === end || start.nextSibling)) {

parent.insertBefore(start.cloneNode(true), anchor);
if (start === end || !(start = start.nextSibling))
break;
if (start === end || !(start = start.nextSibling)) break;
}
} else {
templateContainer.innerHTML = isSVG ? `<svg>${content}</svg>` : content;
templateContainer.innerHTML = namespace === "svg" ? `<svg>${content}</svg>` : namespace === "mathml" ? `<math>${content}</math>` : content;
const template = templateContainer.content;
if (isSVG) {
if (namespace === "svg" || namespace === "mathml") {
const wrapper = template.firstChild;

@@ -193,4 +198,4 @@ while (wrapper.firstChild) {

addTransitionClass(el, leaveFromClass);
addTransitionClass(el, leaveActiveClass);
forceReflow();
addTransitionClass(el, leaveActiveClass);
nextFrame(() => {

@@ -337,4 +342,3 @@ if (!el._isLeaving) {

function toMs(s) {
if (s === "auto")
return 0;
if (s === "auto") return 0;
return Number(s.slice(0, -1).replace(",", ".")) * 1e3;

@@ -360,6 +364,7 @@ }

const kShowOldKey = Symbol("_kod");
const kShowOriginalDisplay = Symbol("_kod");
const kShowHidden = Symbol("_ksh");
const kShow = {
beforeMount(el, { value }, { transition }) {
el[kShowOldKey] = el.style.display === "none" ? "" : el.style.display;
el[kShowOriginalDisplay] = el.style.display === "none" ? "" : el.style.display;
if (transition && value) {

@@ -377,4 +382,3 @@ transition.beforeEnter(el);

updated(el, { value, oldValue }, { transition }) {
if (!value === !oldValue)
return;
if (!value === !oldValue) return;
if (transition) {

@@ -398,4 +402,8 @@ if (value) {

};
if (!!(process.env.NODE_ENV !== "production")) {
kShow.name = "show";
}
function setDisplay(el, value) {
el.style.display = value ? el[kShowOldKey] : "none";
el.style.display = value ? el[kShowOriginalDisplay] : "none";
el[kShowHidden] = !value;
}

@@ -410,21 +418,104 @@ function initKShowForSSR() {

const CSS_VAR_TEXT = Symbol(!!(process.env.NODE_ENV !== "production") ? "CSS_VAR_TEXT" : "");
function useCssVars(getter) {
const instance = getCurrentInstance();
if (!instance) {
!!(process.env.NODE_ENV !== "production") && warn(`useCssVars is called without current active component instance.`);
return;
}
const updateTeleports = instance.ut = (vars = getter(instance.proxy)) => {
Array.from(
document.querySelectorAll(`[data-k-owner="${instance.uid}"]`)
).forEach((node) => setVarsOnNode(node, vars));
};
if (!!(process.env.NODE_ENV !== "production")) {
instance.getCssVars = () => getter(instance.proxy);
}
const setVars = () => {
const vars = getter(instance.proxy);
setVarsOnKNode(instance.subTree, vars);
updateTeleports(vars);
};
onMounted(() => {
watchPostEffect(setVars);
const ob = new MutationObserver(setVars);
ob.observe(instance.subTree.el.parentNode, { childList: true });
onUnmounted(() => ob.disconnect());
});
}
function setVarsOnKNode(knode, vars) {
if (knode.shapeFlag & 128) {
const suspense = knode.suspense;
knode = suspense.activeBranch;
if (suspense.pendingBranch && !suspense.isHydrating) {
suspense.effects.push(() => {
setVarsOnKNode(suspense.activeBranch, vars);
});
}
}
while (knode.component) {
knode = knode.component.subTree;
}
if (knode.shapeFlag & 1 && knode.el) {
setVarsOnNode(knode.el, vars);
} else if (knode.type === Fragment) {
knode.children.forEach((c) => setVarsOnKNode(c, vars));
} else if (knode.type === Static) {
let { el, anchor } = knode;
while (el) {
setVarsOnNode(el, vars);
if (el === anchor) break;
el = el.nextSibling;
}
}
}
function setVarsOnNode(el, vars) {
if (el.nodeType === 1) {
const style = el.style;
let cssText = "";
for (const key in vars) {
style.setProperty(`--${key}`, vars[key]);
cssText += `--${key}: ${vars[key]};`;
}
style[CSS_VAR_TEXT] = cssText;
}
}
const displayRE = /(^|;)\s*display\s*:/;
function patchStyle(el, prev, next) {
const style = el.style;
const isCssString = isString(next);
let hasControlledDisplay = false;
if (next && !isCssString) {
if (prev && !isString(prev)) {
for (const key in prev) {
if (next[key] == null) {
setStyle(style, key, "");
if (prev) {
if (!isString(prev)) {
for (const key in prev) {
if (next[key] == null) {
setStyle(style, key, "");
}
}
} else {
for (const prevStyle of prev.split(";")) {
const key = prevStyle.slice(0, prevStyle.indexOf(":")).trim();
if (next[key] == null) {
setStyle(style, key, "");
}
}
}
}
for (const key in next) {
if (key === "display") {
hasControlledDisplay = true;
}
setStyle(style, key, next[key]);
}
} else {
const currentDisplay = style.display;
if (isCssString) {
if (prev !== next) {
const cssVarText = style[CSS_VAR_TEXT];
if (cssVarText) {
next += ";" + cssVarText;
}
style.cssText = next;
hasControlledDisplay = displayRE.test(next);
}

@@ -434,4 +525,7 @@ } else if (prev) {

}
if (kShowOldKey in el) {
style.display = currentDisplay;
}
if (kShowOriginalDisplay in el) {
el[kShowOriginalDisplay] = hasControlledDisplay ? style.display : "";
if (el[kShowHidden]) {
style.display = "none";
}

@@ -446,4 +540,3 @@ }

} else {
if (val == null)
val = "";
if (val == null) val = "";
if (!!(process.env.NODE_ENV !== "production")) {

@@ -522,6 +615,5 @@ if (semicolonRE.test(val)) {

!tag.includes("-")) {
el._value = value;
const oldValue = tag === "OPTION" ? el.getAttribute("value") : el.value;
const oldValue = tag === "OPTION" ? el.getAttribute("value") || "" : el.value;
const newValue = value == null ? "" : value;
if (oldValue !== newValue) {
if (oldValue !== newValue || !("_value" in el)) {
el.value = newValue;

@@ -532,2 +624,3 @@ }

}
el._value = value;
return;

@@ -572,7 +665,10 @@ }

if (nextValue && existingInvoker) {
existingInvoker.value = nextValue;
existingInvoker.value = !!(process.env.NODE_ENV !== "production") ? sanitizeEventValue(nextValue, rawName) : nextValue;
} else {
const [name, options] = parseName(rawName);
if (nextValue) {
const invoker = invokers[rawName] = createInvoker(nextValue, instance);
const invoker = invokers[rawName] = createInvoker(
!!(process.env.NODE_ENV !== "production") ? sanitizeEventValue(nextValue, rawName) : nextValue,
instance
);
addEventListener(el, name, invoker, options);

@@ -620,2 +716,12 @@ } else if (existingInvoker) {

}
function sanitizeEventValue(value, propName) {
if (isFunction(value) || isArray(value)) {
return value;
}
warn(
`Wrong type passed as event handler to ${propName} - did you forget @ or : in front of your prop?
Expected function or array of functions, received type ${typeof value}.`
);
return NOOP;
}
function patchStopImmediatePropagation(e, value) {

@@ -628,3 +734,5 @@ if (isArray(value)) {

};
return value.map((fn) => (e2) => !e2._stopped && fn && fn(e2));
return value.map(
(fn) => (e2) => !e2._stopped && fn && fn(e2)
);
} else {

@@ -635,4 +743,6 @@ return value;

const nativeOnRE = /^on[a-z]/;
const patchProp = (el, key, prevValue, nextValue, isSVG = false, prevChildren, parentComponent, parentSuspense, unmountChildren) => {
const isNativeOn = (key) => key.charCodeAt(0) === 111 && key.charCodeAt(1) === 110 && // lowercase letter
key.charCodeAt(2) > 96 && key.charCodeAt(2) < 123;
const patchProp = (el, key, prevValue, nextValue, namespace, prevChildren, parentComponent, parentSuspense, unmountChildren) => {
const isSVG = namespace === "svg";
if (key === "class") {

@@ -670,3 +780,3 @@ patchClass(el, nextValue, isSVG);

}
if (key in el && nativeOnRE.test(key) && isFunction(value)) {
if (key in el && isNativeOn(key) && isFunction(value)) {
return true;

@@ -688,3 +798,9 @@ }

}
if (nativeOnRE.test(key) && isString(value)) {
if (key === "width" || key === "height") {
const tag = el.tagName;
if (tag === "IMG" || tag === "VIDEO" || tag === "CANVAS" || tag === "SOURCE") {
return false;
}
}
if (isNativeOn(key) && isString(value)) {
return false;

@@ -752,8 +868,8 @@ }

this._connected = false;
if (this._ob) {
this._ob.disconnect();
this._ob = null;
}
nextTick(() => {
if (!this._connected) {
if (this._ob) {
this._ob.disconnect();
this._ob = null;
}
render(null, this.shadowRoot);

@@ -826,3 +942,3 @@ this._instance = null;

_setAttr(key) {
let value = this.getAttribute(key);
let value = this.hasAttribute(key) ? this.getAttribute(key) : void 0;
const camelKey = camelize$1(key);

@@ -940,61 +1056,2 @@ if (this._numberProps && this._numberProps[camelKey]) {

function useCssVars(getter) {
const instance = getCurrentInstance();
if (!instance) {
!!(process.env.NODE_ENV !== "production") && warn(`useCssVars is called without current active component instance.`);
return;
}
const updateTeleports = instance.ut = (vars = getter(instance.proxy)) => {
Array.from(
document.querySelectorAll(`[data-k-owner="${instance.uid}"]`)
).forEach((node) => setVarsOnNode(node, vars));
};
const setVars = () => {
const vars = getter(instance.proxy);
setVarsOnKNode(instance.subTree, vars);
updateTeleports(vars);
};
watchPostEffect(setVars);
onMounted(() => {
const ob = new MutationObserver(setVars);
ob.observe(instance.subTree.el.parentNode, { childList: true });
onUnmounted(() => ob.disconnect());
});
}
function setVarsOnKNode(knode, vars) {
if (knode.shapeFlag & 128) {
const suspense = knode.suspense;
knode = suspense.activeBranch;
if (suspense.pendingBranch && !suspense.isHydrating) {
suspense.effects.push(() => {
setVarsOnKNode(suspense.activeBranch, vars);
});
}
}
while (knode.component) {
knode = knode.component.subTree;
}
if (knode.shapeFlag & 1 && knode.el) {
setVarsOnNode(knode.el, vars);
} else if (knode.type === Fragment) {
knode.children.forEach((c) => setVarsOnKNode(c, vars));
} else if (knode.type === Static) {
let { el, anchor } = knode;
while (el) {
setVarsOnNode(el, vars);
if (el === anchor)
break;
el = el.nextSibling;
}
}
}
function setVarsOnNode(el, vars) {
if (el.nodeType === 1) {
const style = el.style;
for (const key in vars) {
style.setProperty(`--${key}`, vars[key]);
}
}
}
const positionMap = /* @__PURE__ */ new WeakMap();

@@ -1053,3 +1110,24 @@ const newPositionMap = /* @__PURE__ */ new WeakMap();

let tag = rawProps.tag || Fragment;
prevChildren = children;
prevChildren = [];
if (children) {
for (let i = 0; i < children.length; i++) {
const child = children[i];
if (child.el && child.el instanceof Element) {
prevChildren.push(child);
setTransitionHooks(
child,
resolveTransitionHooks(
child,
cssTransitionProps,
state,
instance
)
);
positionMap.set(
child,
child.el.getBoundingClientRect()
);
}
}
}
children = slots.default ? getTransitionRawChildren(slots.default()) : [];

@@ -1067,12 +1145,2 @@ for (let i = 0; i < children.length; i++) {

}
if (prevChildren) {
for (let i = 0; i < prevChildren.length; i++) {
const child = prevChildren[i];
setTransitionHooks(
child,
resolveTransitionHooks(child, cssTransitionProps, state, instance)
);
positionMap.set(child, child.el.getBoundingClientRect());
}
}
return createKNode(tag, null, children);

@@ -1146,4 +1214,3 @@ };

addEventListener(el, lazy ? "change" : "input", (e) => {
if (e.target.composing)
return;
if (e.target.composing) return;
let domValue = el.value;

@@ -1175,4 +1242,8 @@ if (trim) {

el[assignKey] = getModelAssigner(knode);
if (el.composing)
if (el.composing) return;
const elValue = (number || el.type === "number") && !/^0\d/.test(el.value) ? looseToNumber(el.value) : el.value;
const newValue = value == null ? "" : value;
if (elValue === newValue) {
return;
}
if (document.activeElement === el && el.type !== "range") {

@@ -1182,13 +1253,7 @@ if (lazy) {

}
if (trim && el.value.trim() === value) {
if (trim && el.value.trim() === newValue) {
return;
}
if ((number || el.type === "number") && looseToNumber(el.value) === value) {
return;
}
}
const newValue = value == null ? "" : value;
if (el.value !== newValue) {
el.value = newValue;
}
el.value = newValue;
}

@@ -1273,2 +1338,6 @@ };

);
el._assigning = true;
nextTick(() => {
el._assigning = false;
});
});

@@ -1279,3 +1348,3 @@ el[assignKey] = getModelAssigner(knode);

// <option>s.
mounted(el, { value }) {
mounted(el, { value, modifiers: { number } }) {
setSelected(el, value);

@@ -1286,9 +1355,12 @@ },

},
updated(el, { value }) {
setSelected(el, value);
updated(el, { value, modifiers: { number } }) {
if (!el._assigning) {
setSelected(el, value);
}
}
};
function setSelected(el, value) {
function setSelected(el, value, number) {
const isMultiple = el.multiple;
if (isMultiple && !isArray(value) && !isSet(value)) {
const isArrayValue = isArray(value);
if (isMultiple && !isArrayValue && !isSet(value)) {
!!(process.env.NODE_ENV !== "production") && warn(

@@ -1303,13 +1375,15 @@ `<select multiple k-model> expects an Array or Set value for its binding, but got ${Object.prototype.toString.call(value).slice(8, -1)}.`

if (isMultiple) {
if (isArray(value)) {
option.selected = looseIndexOf(value, optionValue) > -1;
if (isArrayValue) {
const optionType = typeof optionValue;
if (optionType === "string" || optionType === "number") {
option.selected = value.some((v) => String(v) === String(optionValue));
} else {
option.selected = looseIndexOf(value, optionValue) > -1;
}
} else {
option.selected = value.has(optionValue);
}
} else {
if (looseEqual(getValue(option), value)) {
if (el.selectedIndex !== i)
el.selectedIndex = i;
return;
}
} else if (looseEqual(getValue(option), value)) {
if (el.selectedIndex !== i) el.selectedIndex = i;
return;
}

@@ -1417,10 +1491,11 @@ }

const withModifiers = (fn, modifiers) => {
return (event, ...args) => {
const cache = fn._withMods || (fn._withMods = {});
const cacheKey = modifiers.join(".");
return cache[cacheKey] || (cache[cacheKey] = (event, ...args) => {
for (let i = 0; i < modifiers.length; i++) {
const guard = modifierGuards[modifiers[i]];
if (guard && guard(event, modifiers))
return;
if (guard && guard(event, modifiers)) return;
}
return fn(event, ...args);
};
});
};

@@ -1437,3 +1512,5 @@ const keyNames = {

const withKeys = (fn, modifiers) => {
return (event) => {
const cache = fn._withKeys || (fn._withKeys = {});
const cacheKey = modifiers.join(".");
return cache[cacheKey] || (cache[cacheKey] = (event) => {
if (!("key" in event)) {

@@ -1446,3 +1523,3 @@ return;

}
};
});
};

@@ -1476,4 +1553,3 @@

const container = normalizeContainer(containerOrSelector);
if (!container)
return;
if (!container) return;
const component = app._component;

@@ -1484,3 +1560,3 @@ if (!isFunction(component) && !component.render && !component.template) {

container.innerHTML = "";
const proxy = mount(container, false, container instanceof SVGElement);
const proxy = mount(container, false, resolveRootNamespace(container));
if (container instanceof Element) {

@@ -1504,3 +1580,3 @@ container.removeAttribute("k-cloak");

if (container) {
return mount(container, true, container instanceof SVGElement);
return mount(container, true, resolveRootNamespace(container));
}

@@ -1510,5 +1586,13 @@ };

};
function resolveRootNamespace(container) {
if (container instanceof SVGElement) {
return "svg";
}
if (typeof MathMLElement === "function" && container instanceof MathMLElement) {
return "mathml";
}
}
function injectNativeTagCheck(app) {
Object.defineProperty(app.config, "isNativeTag", {
value: (tag) => isHTMLTag(tag) || isSVGTag(tag),
value: (tag) => isHTMLTag(tag) || isSVGTag(tag) || isMathMLTag(tag),
writable: false

@@ -1534,3 +1618,3 @@ });

- For kdu-cli: see https://kdujs-cli.web.app/guide/webpack.html#modifying-options-of-a-loader
- For wite: pass it via @witejs/plugin-kdu options.`;
- For lahm: pass it via @lahmjs/plugin-kdu options.`;
Object.defineProperty(app.config, "compilerOptions", {

@@ -1537,0 +1621,0 @@ get() {

{
"name": "@kdujs/runtime-dom-canary",
"version": "3.20241209.0-minor.0",
"version": "3.20241209.0",
"description": "@kdujs/runtime-dom",

@@ -13,2 +13,16 @@ "main": "index.js",

],
"exports": {
".": {
"types": "./dist/runtime-dom.d.ts",
"node": {
"production": "./dist/runtime-dom.cjs.prod.js",
"development": "./dist/runtime-dom.cjs.js",
"default": "./index.js"
},
"module": "./dist/runtime-dom.esm-bundler.js",
"import": "./dist/runtime-dom.esm-bundler.js",
"require": "./index.js"
},
"./*": "./*"
},
"sideEffects": false,

@@ -39,6 +53,6 @@ "buildOptions": {

"dependencies": {
"@kdujs/shared": "npm:@kdujs/shared-canary@3.20241209.0-minor.0",
"@kdujs/runtime-core": "npm:@kdujs/runtime-core-canary@3.20241209.0-minor.0",
"csstype": "^3.1.2"
"@kdujs/shared": "npm:@kdujs/shared-canary@3.20241209.0",
"@kdujs/runtime-core": "npm:@kdujs/runtime-core-canary@3.20241209.0",
"csstype": "^3.1.3"
}
}

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc