import { OperatorExecuterAttrRequire } from './OperatorExecuterAttrRequire'; import { RawSet } from '../rawsets/RawSet'; import { Render } from '../rawsets/Render'; import { AfterCallBack, ElementSource, ExecuteState, ReturnContainer, Source } from './OperatorExecuter'; import {ObjectUtils} from "@dooboostore/core"; export class DrStripElement extends OperatorExecuterAttrRequire { constructor(rawSet: RawSet, render: Render, returnContainer: ReturnContainer, elementSource: ElementSource, source: Source, afterCallBack: AfterCallBack) { source.operatorAround = undefined; super(rawSet, render, returnContainer, elementSource, source, afterCallBack, false); } async executeAttrRequire(attr: string): Promise { // const itRandom = RawSet.drItOtherEncoding(this.elementSource.element, 'DrStripElement'); // const vars = RawSet.drVarEncoding(this.elementSource.element, this.elementSource.attrs.drVarOption ?? ''); const newTemp = this.source.config.window.document.createElement('temp'); // Object.entries(this.__render.drAttr).filter(([k,v]) => k !== 'drIf' && v).forEach(([k, v]) => n.setAttribute(this.__render.drAttrsOriginName[k], v)); <-- 이부분은 다른 attr에도 적용을 할지말지 생각해야됨 엘리먼트 존재유무에 따라서 적용을 할지말지 결정해야됨 ObjectUtils.Script.evaluate(` ${this.render.bindScript} ${this.elementSource.attrs.drBeforeOption ?? ''} const n = $element.cloneNode(true); if(${attr}) { Array.from(n.childNodes).forEach(it => this.__render.fag.append(it)); } else { this.__render.fag.append(n); } ${this.elementSource.attrs.drAfterOption ?? ''}; return true; `, Object.assign(this.source.obj, { __render: Object.freeze({ fag: newTemp, drAttr: this.elementSource.attrs, drAttrsOriginName: RawSet.drAttrsOriginName, drStripOption: this.elementSource.attrs.drStripOption, ...this.render } as Render) } )); const tempalte = this.source.config.window.document.createElement('template'); tempalte.innerHTML = newTemp.innerHTML; this.returnContainer.fag.append(tempalte.content); const rr = RawSet.checkPointCreates(this.returnContainer.fag, this.source.obj, this.source.config); this.elementSource.element.parentNode?.replaceChild(this.returnContainer.fag, this.elementSource.element); this.returnContainer.raws.push(...rr); return ExecuteState.EXECUTE; } }