diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/rx.ts | 12 | 
1 files changed, 5 insertions, 7 deletions
| @@ -485,9 +485,9 @@ function appendChild(state: State, element: Element, child: Html, lastAdded?: No      const cancelAttributes = Object.entries(attributes).map(([key, value]) => {        if (isRx<AttributeValue>(value)) { -        return rxRun(state, value, newValue => setAttribute(state, setAttr, element, key, newValue)) +        return rxRun(state, value, newValue => setAttribute(setAttr, childElement, key, newValue))        } else { -        setAttribute(state, setAttr, element, key, value) +        setAttribute(setAttr, childElement, key, value)        }      }) @@ -659,7 +659,7 @@ function appendChild(state: State, element: Element, child: Html, lastAdded?: No    }  } -const svgElements = ['svg', 'circle', 'polygon', 'line', 'rect', 'ellipse', 'text'] +const svgElements = ['svg', 'circle', 'polygon', 'line', 'rect', 'ellipse', 'text', 'path']  function isSvg(tagName: string): boolean {      return !(svgElements.indexOf(tagName) === -1)  } @@ -700,16 +700,14 @@ function appendNode(base: Element, node: Node, lastAdded?: Node) {    }  } -function setAttribute(state: State, setAttr: (key: any, value: any) => void, element: Element, key: string, attribute: AttributeValue) { +function setAttribute(setAttr: (key: any, value: any) => void, element: Element, key: string, attribute: AttributeValue) {    if (attribute === undefined) {      // Do nothing    } else if (attribute === true) {      setAttr(key, 'true')    } else if (attribute === false) {      // @ts-ignore -    if (key in element) { -      setAttr(key, false) -    } +    if (key in element) setAttr(key, false)    } else if (typeof attribute === "number") {      setAttr(key, attribute.toString())    } else if (typeof attribute === "string") { | 
