@dooboostore/simple-web-component 1.0.5 → 1.0.7
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 +151 -58
- package/dist/cjs/decorators/addEventListener.js +3 -2
- package/dist/cjs/decorators/addEventListener.js.map +2 -2
- package/dist/cjs/decorators/attribute.js +79 -0
- package/dist/cjs/decorators/attribute.js.map +7 -0
- package/dist/cjs/decorators/elementDefine.js +261 -106
- package/dist/cjs/decorators/elementDefine.js.map +2 -2
- package/dist/cjs/decorators/emitCustomEvent.js +60 -0
- package/dist/cjs/decorators/emitCustomEvent.js.map +7 -0
- package/dist/cjs/decorators/lifecycles.js +38 -0
- package/dist/cjs/decorators/lifecycles.js.map +2 -2
- package/dist/cjs/decorators/query.js +27 -5
- package/dist/cjs/decorators/query.js.map +2 -2
- package/dist/cjs/decorators/queryAll.js +27 -5
- package/dist/cjs/decorators/queryAll.js.map +2 -2
- package/dist/cjs/decorators/state.js +50 -0
- package/dist/cjs/decorators/state.js.map +7 -0
- package/dist/cjs/elements/SwcChoose.js.map +2 -2
- package/dist/cjs/elements/SwcForOf.js +3 -1
- package/dist/cjs/elements/SwcForOf.js.map +2 -2
- package/dist/cjs/elements/SwcObject.js +8 -6
- package/dist/cjs/elements/SwcObject.js.map +2 -2
- package/dist/cjs/index.js +6 -7
- package/dist/cjs/index.js.map +2 -2
- package/dist/cjs/is/SwcChooseAnchor.js.map +2 -2
- package/dist/cjs/is/SwcChooseArea.js.map +2 -2
- package/dist/cjs/is/SwcChooseAudio.js.map +2 -2
- package/dist/cjs/is/SwcChooseBase.js.map +2 -2
- package/dist/cjs/is/SwcChooseButton.js.map +2 -2
- package/dist/cjs/is/SwcChooseCanvas.js.map +2 -2
- package/dist/cjs/is/SwcChooseData.js.map +2 -2
- package/dist/cjs/is/SwcChooseDataList.js.map +2 -2
- package/dist/cjs/is/SwcChooseDetails.js.map +2 -2
- package/dist/cjs/is/SwcChooseDialog.js.map +2 -2
- package/dist/cjs/is/SwcChooseDiv.js.map +2 -2
- package/dist/cjs/is/SwcChooseDl.js.map +2 -2
- package/dist/cjs/is/SwcChooseEmbed.js.map +2 -2
- package/dist/cjs/is/SwcChooseFieldSet.js.map +2 -2
- package/dist/cjs/is/SwcChooseForm.js.map +2 -2
- package/dist/cjs/is/SwcChooseHeading.js.map +2 -2
- package/dist/cjs/is/SwcChooseHr.js.map +2 -2
- package/dist/cjs/is/SwcChooseIFrame.js.map +2 -2
- package/dist/cjs/is/SwcChooseImage.js.map +2 -2
- package/dist/cjs/is/SwcChooseInput.js.map +2 -2
- package/dist/cjs/is/SwcChooseLabel.js.map +2 -2
- package/dist/cjs/is/SwcChooseLegend.js.map +2 -2
- package/dist/cjs/is/SwcChooseLi.js.map +2 -2
- package/dist/cjs/is/SwcChooseLink.js.map +2 -2
- package/dist/cjs/is/SwcChooseMap.js.map +2 -2
- package/dist/cjs/is/SwcChooseMeta.js.map +2 -2
- package/dist/cjs/is/SwcChooseMeter.js.map +2 -2
- package/dist/cjs/is/SwcChooseMod.js.map +2 -2
- package/dist/cjs/is/SwcChooseObject.js.map +2 -2
- package/dist/cjs/is/SwcChooseOl.js.map +2 -2
- package/dist/cjs/is/SwcChooseOptGroup.js.map +2 -2
- package/dist/cjs/is/SwcChooseOption.js.map +2 -2
- package/dist/cjs/is/SwcChooseOutput.js.map +2 -2
- package/dist/cjs/is/SwcChooseParagraph.js.map +2 -2
- package/dist/cjs/is/SwcChooseParam.js.map +2 -2
- package/dist/cjs/is/SwcChoosePicture.js.map +2 -2
- package/dist/cjs/is/SwcChoosePre.js.map +2 -2
- package/dist/cjs/is/SwcChooseProgress.js.map +2 -2
- package/dist/cjs/is/SwcChooseQuote.js.map +2 -2
- package/dist/cjs/is/SwcChooseScript.js.map +2 -2
- package/dist/cjs/is/SwcChooseSelect.js.map +2 -2
- package/dist/cjs/is/SwcChooseSlot.js.map +2 -2
- package/dist/cjs/is/SwcChooseSource.js.map +2 -2
- package/dist/cjs/is/SwcChooseSpan.js.map +2 -2
- package/dist/cjs/is/SwcChooseStyle.js.map +2 -2
- package/dist/cjs/is/SwcChooseTable.js.map +2 -2
- package/dist/cjs/is/SwcChooseTableCell.js.map +2 -2
- package/dist/cjs/is/SwcChooseTableRow.js.map +2 -2
- package/dist/cjs/is/SwcChooseTableSection.js.map +2 -2
- package/dist/cjs/is/SwcChooseTemplate.js.map +2 -2
- package/dist/cjs/is/SwcChooseTextArea.js.map +2 -2
- package/dist/cjs/is/SwcChooseTime.js.map +2 -2
- package/dist/cjs/is/SwcChooseTitle.js.map +2 -2
- package/dist/cjs/is/SwcChooseTrack.js.map +2 -2
- package/dist/cjs/is/SwcChooseUl.js.map +2 -2
- package/dist/cjs/is/SwcChooseVideo.js.map +2 -2
- package/dist/cjs/is/SwcIfAnchor.js.map +2 -2
- package/dist/cjs/is/SwcIfArea.js.map +2 -2
- package/dist/cjs/is/SwcIfAudio.js.map +2 -2
- package/dist/cjs/is/SwcIfBase.js.map +2 -2
- package/dist/cjs/is/SwcIfButton.js.map +2 -2
- package/dist/cjs/is/SwcIfCanvas.js.map +2 -2
- package/dist/cjs/is/SwcIfData.js.map +2 -2
- package/dist/cjs/is/SwcIfDataList.js.map +2 -2
- package/dist/cjs/is/SwcIfDetails.js.map +2 -2
- package/dist/cjs/is/SwcIfDialog.js.map +2 -2
- package/dist/cjs/is/SwcIfDiv.js.map +2 -2
- package/dist/cjs/is/SwcIfDl.js.map +2 -2
- package/dist/cjs/is/SwcIfEmbed.js.map +2 -2
- package/dist/cjs/is/SwcIfFieldSet.js.map +2 -2
- package/dist/cjs/is/SwcIfForm.js.map +2 -2
- package/dist/cjs/is/SwcIfHeading.js.map +2 -2
- package/dist/cjs/is/SwcIfHr.js.map +2 -2
- package/dist/cjs/is/SwcIfIFrame.js.map +2 -2
- package/dist/cjs/is/SwcIfImage.js.map +2 -2
- package/dist/cjs/is/SwcIfInput.js.map +2 -2
- package/dist/cjs/is/SwcIfLabel.js.map +2 -2
- package/dist/cjs/is/SwcIfLegend.js.map +2 -2
- package/dist/cjs/is/SwcIfLi.js.map +2 -2
- package/dist/cjs/is/SwcIfLink.js.map +2 -2
- package/dist/cjs/is/SwcIfMap.js.map +2 -2
- package/dist/cjs/is/SwcIfMeta.js.map +2 -2
- package/dist/cjs/is/SwcIfMeter.js.map +2 -2
- package/dist/cjs/is/SwcIfMod.js.map +2 -2
- package/dist/cjs/is/SwcIfObject.js.map +2 -2
- package/dist/cjs/is/SwcIfOl.js.map +2 -2
- package/dist/cjs/is/SwcIfOptGroup.js.map +2 -2
- package/dist/cjs/is/SwcIfOption.js.map +2 -2
- package/dist/cjs/is/SwcIfOutput.js.map +2 -2
- package/dist/cjs/is/SwcIfParagraph.js.map +2 -2
- package/dist/cjs/is/SwcIfParam.js.map +2 -2
- package/dist/cjs/is/SwcIfPicture.js.map +2 -2
- package/dist/cjs/is/SwcIfPre.js.map +2 -2
- package/dist/cjs/is/SwcIfProgress.js.map +2 -2
- package/dist/cjs/is/SwcIfQuote.js.map +2 -2
- package/dist/cjs/is/SwcIfScript.js.map +2 -2
- package/dist/cjs/is/SwcIfSelect.js.map +2 -2
- package/dist/cjs/is/SwcIfSlot.js.map +2 -2
- package/dist/cjs/is/SwcIfSource.js.map +2 -2
- package/dist/cjs/is/SwcIfSpan.js.map +2 -2
- package/dist/cjs/is/SwcIfStyle.js.map +2 -2
- package/dist/cjs/is/SwcIfTable.js.map +2 -2
- package/dist/cjs/is/SwcIfTableCell.js.map +2 -2
- package/dist/cjs/is/SwcIfTableRow.js.map +2 -2
- package/dist/cjs/is/SwcIfTableSection.js.map +2 -2
- package/dist/cjs/is/SwcIfTemplate.js.map +2 -2
- package/dist/cjs/is/SwcIfTextArea.js.map +2 -2
- package/dist/cjs/is/SwcIfTime.js.map +2 -2
- package/dist/cjs/is/SwcIfTitle.js.map +2 -2
- package/dist/cjs/is/SwcIfTrack.js.map +2 -2
- package/dist/cjs/is/SwcIfUl.js.map +2 -2
- package/dist/cjs/is/SwcIfVideo.js.map +2 -2
- package/dist/cjs/is/SwcOtherAnchor.js.map +2 -2
- package/dist/cjs/is/SwcOtherArea.js.map +2 -2
- package/dist/cjs/is/SwcOtherAudio.js.map +2 -2
- package/dist/cjs/is/SwcOtherBase.js.map +2 -2
- package/dist/cjs/is/SwcOtherButton.js.map +2 -2
- package/dist/cjs/is/SwcOtherCanvas.js.map +2 -2
- package/dist/cjs/is/SwcOtherData.js.map +2 -2
- package/dist/cjs/is/SwcOtherDataList.js.map +2 -2
- package/dist/cjs/is/SwcOtherDetails.js.map +2 -2
- package/dist/cjs/is/SwcOtherDialog.js.map +2 -2
- package/dist/cjs/is/SwcOtherDiv.js.map +2 -2
- package/dist/cjs/is/SwcOtherDl.js.map +2 -2
- package/dist/cjs/is/SwcOtherEmbed.js.map +2 -2
- package/dist/cjs/is/SwcOtherFieldSet.js.map +2 -2
- package/dist/cjs/is/SwcOtherForm.js.map +2 -2
- package/dist/cjs/is/SwcOtherHeading.js.map +2 -2
- package/dist/cjs/is/SwcOtherHr.js.map +2 -2
- package/dist/cjs/is/SwcOtherIFrame.js.map +2 -2
- package/dist/cjs/is/SwcOtherImage.js.map +2 -2
- package/dist/cjs/is/SwcOtherInput.js.map +2 -2
- package/dist/cjs/is/SwcOtherLabel.js.map +2 -2
- package/dist/cjs/is/SwcOtherLegend.js.map +2 -2
- package/dist/cjs/is/SwcOtherLi.js.map +2 -2
- package/dist/cjs/is/SwcOtherLink.js.map +2 -2
- package/dist/cjs/is/SwcOtherMap.js.map +2 -2
- package/dist/cjs/is/SwcOtherMeta.js.map +2 -2
- package/dist/cjs/is/SwcOtherMeter.js.map +2 -2
- package/dist/cjs/is/SwcOtherMod.js.map +2 -2
- package/dist/cjs/is/SwcOtherObject.js.map +2 -2
- package/dist/cjs/is/SwcOtherOl.js.map +2 -2
- package/dist/cjs/is/SwcOtherOptGroup.js.map +2 -2
- package/dist/cjs/is/SwcOtherOption.js.map +2 -2
- package/dist/cjs/is/SwcOtherOutput.js.map +2 -2
- package/dist/cjs/is/SwcOtherParagraph.js.map +2 -2
- package/dist/cjs/is/SwcOtherParam.js.map +2 -2
- package/dist/cjs/is/SwcOtherPicture.js.map +2 -2
- package/dist/cjs/is/SwcOtherPre.js.map +2 -2
- package/dist/cjs/is/SwcOtherProgress.js.map +2 -2
- package/dist/cjs/is/SwcOtherQuote.js.map +2 -2
- package/dist/cjs/is/SwcOtherScript.js.map +2 -2
- package/dist/cjs/is/SwcOtherSelect.js.map +2 -2
- package/dist/cjs/is/SwcOtherSlot.js.map +2 -2
- package/dist/cjs/is/SwcOtherSource.js.map +2 -2
- package/dist/cjs/is/SwcOtherSpan.js.map +2 -2
- package/dist/cjs/is/SwcOtherStyle.js.map +2 -2
- package/dist/cjs/is/SwcOtherTable.js.map +2 -2
- package/dist/cjs/is/SwcOtherTableCell.js.map +2 -2
- package/dist/cjs/is/SwcOtherTableRow.js.map +2 -2
- package/dist/cjs/is/SwcOtherTableSection.js.map +2 -2
- package/dist/cjs/is/SwcOtherTemplate.js.map +2 -2
- package/dist/cjs/is/SwcOtherTextArea.js.map +2 -2
- package/dist/cjs/is/SwcOtherTime.js.map +2 -2
- package/dist/cjs/is/SwcOtherTitle.js.map +2 -2
- package/dist/cjs/is/SwcOtherTrack.js.map +2 -2
- package/dist/cjs/is/SwcOtherUl.js.map +2 -2
- package/dist/cjs/is/SwcOtherVideo.js.map +2 -2
- package/dist/cjs/is/SwcWhenAnchor.js.map +2 -2
- package/dist/cjs/is/SwcWhenArea.js.map +2 -2
- package/dist/cjs/is/SwcWhenAudio.js.map +2 -2
- package/dist/cjs/is/SwcWhenBase.js.map +2 -2
- package/dist/cjs/is/SwcWhenButton.js.map +2 -2
- package/dist/cjs/is/SwcWhenCanvas.js.map +2 -2
- package/dist/cjs/is/SwcWhenData.js.map +2 -2
- package/dist/cjs/is/SwcWhenDataList.js.map +2 -2
- package/dist/cjs/is/SwcWhenDetails.js.map +2 -2
- package/dist/cjs/is/SwcWhenDialog.js.map +2 -2
- package/dist/cjs/is/SwcWhenDiv.js.map +2 -2
- package/dist/cjs/is/SwcWhenDl.js.map +2 -2
- package/dist/cjs/is/SwcWhenEmbed.js.map +2 -2
- package/dist/cjs/is/SwcWhenFieldSet.js.map +2 -2
- package/dist/cjs/is/SwcWhenForm.js.map +2 -2
- package/dist/cjs/is/SwcWhenHeading.js.map +2 -2
- package/dist/cjs/is/SwcWhenHr.js.map +2 -2
- package/dist/cjs/is/SwcWhenIFrame.js.map +2 -2
- package/dist/cjs/is/SwcWhenImage.js.map +2 -2
- package/dist/cjs/is/SwcWhenInput.js.map +2 -2
- package/dist/cjs/is/SwcWhenLabel.js.map +2 -2
- package/dist/cjs/is/SwcWhenLegend.js.map +2 -2
- package/dist/cjs/is/SwcWhenLi.js.map +2 -2
- package/dist/cjs/is/SwcWhenLink.js.map +2 -2
- package/dist/cjs/is/SwcWhenMap.js.map +2 -2
- package/dist/cjs/is/SwcWhenMeta.js.map +2 -2
- package/dist/cjs/is/SwcWhenMeter.js.map +2 -2
- package/dist/cjs/is/SwcWhenMod.js.map +2 -2
- package/dist/cjs/is/SwcWhenObject.js.map +2 -2
- package/dist/cjs/is/SwcWhenOl.js.map +2 -2
- package/dist/cjs/is/SwcWhenOptGroup.js.map +2 -2
- package/dist/cjs/is/SwcWhenOption.js.map +2 -2
- package/dist/cjs/is/SwcWhenOutput.js.map +2 -2
- package/dist/cjs/is/SwcWhenParagraph.js.map +2 -2
- package/dist/cjs/is/SwcWhenParam.js.map +2 -2
- package/dist/cjs/is/SwcWhenPicture.js.map +2 -2
- package/dist/cjs/is/SwcWhenPre.js.map +2 -2
- package/dist/cjs/is/SwcWhenProgress.js.map +2 -2
- package/dist/cjs/is/SwcWhenQuote.js.map +2 -2
- package/dist/cjs/is/SwcWhenScript.js.map +2 -2
- package/dist/cjs/is/SwcWhenSelect.js.map +2 -2
- package/dist/cjs/is/SwcWhenSlot.js.map +2 -2
- package/dist/cjs/is/SwcWhenSource.js.map +2 -2
- package/dist/cjs/is/SwcWhenSpan.js.map +2 -2
- package/dist/cjs/is/SwcWhenStyle.js.map +2 -2
- package/dist/cjs/is/SwcWhenTable.js.map +2 -2
- package/dist/cjs/is/SwcWhenTableCell.js.map +2 -2
- package/dist/cjs/is/SwcWhenTableRow.js.map +2 -2
- package/dist/cjs/is/SwcWhenTableSection.js.map +2 -2
- package/dist/cjs/is/SwcWhenTemplate.js.map +2 -2
- package/dist/cjs/is/SwcWhenTextArea.js.map +2 -2
- package/dist/cjs/is/SwcWhenTime.js.map +2 -2
- package/dist/cjs/is/SwcWhenTitle.js.map +2 -2
- package/dist/cjs/is/SwcWhenTrack.js.map +2 -2
- package/dist/cjs/is/SwcWhenUl.js.map +2 -2
- package/dist/cjs/is/SwcWhenVideo.js.map +2 -2
- package/dist/cjs/utils/Utils.js +49 -17
- package/dist/cjs/utils/Utils.js.map +2 -2
- package/dist/esm/decorators/addEventListener.js +3 -2
- package/dist/esm/decorators/addEventListener.js.map +2 -2
- package/dist/esm/decorators/attribute.js +60 -0
- package/dist/esm/decorators/attribute.js.map +7 -0
- package/dist/esm/decorators/elementDefine.js +262 -107
- package/dist/esm/decorators/elementDefine.js.map +2 -2
- package/dist/esm/decorators/emitCustomEvent.js +41 -0
- package/dist/esm/decorators/emitCustomEvent.js.map +7 -0
- package/dist/esm/decorators/lifecycles.js +38 -0
- package/dist/esm/decorators/lifecycles.js.map +2 -2
- package/dist/esm/decorators/query.js +27 -5
- package/dist/esm/decorators/query.js.map +2 -2
- package/dist/esm/decorators/queryAll.js +27 -5
- package/dist/esm/decorators/queryAll.js.map +2 -2
- package/dist/esm/decorators/state.js +31 -0
- package/dist/esm/decorators/state.js.map +7 -0
- package/dist/esm/elements/SwcChoose.js.map +2 -2
- package/dist/esm/elements/SwcForOf.js +3 -1
- package/dist/esm/elements/SwcForOf.js.map +2 -2
- package/dist/esm/elements/SwcObject.js +8 -6
- package/dist/esm/elements/SwcObject.js.map +2 -2
- package/dist/esm/index.js +6 -7
- package/dist/esm/index.js.map +2 -2
- package/dist/esm/is/SwcChooseAnchor.js.map +2 -2
- package/dist/esm/is/SwcChooseArea.js.map +2 -2
- package/dist/esm/is/SwcChooseAudio.js.map +2 -2
- package/dist/esm/is/SwcChooseBase.js.map +2 -2
- package/dist/esm/is/SwcChooseButton.js.map +2 -2
- package/dist/esm/is/SwcChooseCanvas.js.map +2 -2
- package/dist/esm/is/SwcChooseData.js.map +2 -2
- package/dist/esm/is/SwcChooseDataList.js.map +2 -2
- package/dist/esm/is/SwcChooseDetails.js.map +2 -2
- package/dist/esm/is/SwcChooseDialog.js.map +2 -2
- package/dist/esm/is/SwcChooseDiv.js.map +2 -2
- package/dist/esm/is/SwcChooseDl.js.map +2 -2
- package/dist/esm/is/SwcChooseEmbed.js.map +2 -2
- package/dist/esm/is/SwcChooseFieldSet.js.map +2 -2
- package/dist/esm/is/SwcChooseForm.js.map +2 -2
- package/dist/esm/is/SwcChooseHeading.js.map +2 -2
- package/dist/esm/is/SwcChooseHr.js.map +2 -2
- package/dist/esm/is/SwcChooseIFrame.js.map +2 -2
- package/dist/esm/is/SwcChooseImage.js.map +2 -2
- package/dist/esm/is/SwcChooseInput.js.map +2 -2
- package/dist/esm/is/SwcChooseLabel.js.map +2 -2
- package/dist/esm/is/SwcChooseLegend.js.map +2 -2
- package/dist/esm/is/SwcChooseLi.js.map +2 -2
- package/dist/esm/is/SwcChooseLink.js.map +2 -2
- package/dist/esm/is/SwcChooseMap.js.map +2 -2
- package/dist/esm/is/SwcChooseMeta.js.map +2 -2
- package/dist/esm/is/SwcChooseMeter.js.map +2 -2
- package/dist/esm/is/SwcChooseMod.js.map +2 -2
- package/dist/esm/is/SwcChooseObject.js.map +2 -2
- package/dist/esm/is/SwcChooseOl.js.map +2 -2
- package/dist/esm/is/SwcChooseOptGroup.js.map +2 -2
- package/dist/esm/is/SwcChooseOption.js.map +2 -2
- package/dist/esm/is/SwcChooseOutput.js.map +2 -2
- package/dist/esm/is/SwcChooseParagraph.js.map +2 -2
- package/dist/esm/is/SwcChooseParam.js.map +2 -2
- package/dist/esm/is/SwcChoosePicture.js.map +2 -2
- package/dist/esm/is/SwcChoosePre.js.map +2 -2
- package/dist/esm/is/SwcChooseProgress.js.map +2 -2
- package/dist/esm/is/SwcChooseQuote.js.map +2 -2
- package/dist/esm/is/SwcChooseScript.js.map +2 -2
- package/dist/esm/is/SwcChooseSelect.js.map +2 -2
- package/dist/esm/is/SwcChooseSlot.js.map +2 -2
- package/dist/esm/is/SwcChooseSource.js.map +2 -2
- package/dist/esm/is/SwcChooseSpan.js.map +2 -2
- package/dist/esm/is/SwcChooseStyle.js.map +2 -2
- package/dist/esm/is/SwcChooseTable.js.map +2 -2
- package/dist/esm/is/SwcChooseTableCell.js.map +2 -2
- package/dist/esm/is/SwcChooseTableRow.js.map +2 -2
- package/dist/esm/is/SwcChooseTableSection.js.map +2 -2
- package/dist/esm/is/SwcChooseTemplate.js.map +2 -2
- package/dist/esm/is/SwcChooseTextArea.js.map +2 -2
- package/dist/esm/is/SwcChooseTime.js.map +2 -2
- package/dist/esm/is/SwcChooseTitle.js.map +2 -2
- package/dist/esm/is/SwcChooseTrack.js.map +2 -2
- package/dist/esm/is/SwcChooseUl.js.map +2 -2
- package/dist/esm/is/SwcChooseVideo.js.map +2 -2
- package/dist/esm/is/SwcIfAnchor.js.map +2 -2
- package/dist/esm/is/SwcIfArea.js.map +2 -2
- package/dist/esm/is/SwcIfAudio.js.map +2 -2
- package/dist/esm/is/SwcIfBase.js.map +2 -2
- package/dist/esm/is/SwcIfButton.js.map +2 -2
- package/dist/esm/is/SwcIfCanvas.js.map +2 -2
- package/dist/esm/is/SwcIfData.js.map +2 -2
- package/dist/esm/is/SwcIfDataList.js.map +2 -2
- package/dist/esm/is/SwcIfDetails.js.map +2 -2
- package/dist/esm/is/SwcIfDialog.js.map +2 -2
- package/dist/esm/is/SwcIfDiv.js.map +2 -2
- package/dist/esm/is/SwcIfDl.js.map +2 -2
- package/dist/esm/is/SwcIfEmbed.js.map +2 -2
- package/dist/esm/is/SwcIfFieldSet.js.map +2 -2
- package/dist/esm/is/SwcIfForm.js.map +2 -2
- package/dist/esm/is/SwcIfHeading.js.map +2 -2
- package/dist/esm/is/SwcIfHr.js.map +2 -2
- package/dist/esm/is/SwcIfIFrame.js.map +2 -2
- package/dist/esm/is/SwcIfImage.js.map +2 -2
- package/dist/esm/is/SwcIfInput.js.map +2 -2
- package/dist/esm/is/SwcIfLabel.js.map +2 -2
- package/dist/esm/is/SwcIfLegend.js.map +2 -2
- package/dist/esm/is/SwcIfLi.js.map +2 -2
- package/dist/esm/is/SwcIfLink.js.map +2 -2
- package/dist/esm/is/SwcIfMap.js.map +2 -2
- package/dist/esm/is/SwcIfMeta.js.map +2 -2
- package/dist/esm/is/SwcIfMeter.js.map +2 -2
- package/dist/esm/is/SwcIfMod.js.map +2 -2
- package/dist/esm/is/SwcIfObject.js.map +2 -2
- package/dist/esm/is/SwcIfOl.js.map +2 -2
- package/dist/esm/is/SwcIfOptGroup.js.map +2 -2
- package/dist/esm/is/SwcIfOption.js.map +2 -2
- package/dist/esm/is/SwcIfOutput.js.map +2 -2
- package/dist/esm/is/SwcIfParagraph.js.map +2 -2
- package/dist/esm/is/SwcIfParam.js.map +2 -2
- package/dist/esm/is/SwcIfPicture.js.map +2 -2
- package/dist/esm/is/SwcIfPre.js.map +2 -2
- package/dist/esm/is/SwcIfProgress.js.map +2 -2
- package/dist/esm/is/SwcIfQuote.js.map +2 -2
- package/dist/esm/is/SwcIfScript.js.map +2 -2
- package/dist/esm/is/SwcIfSelect.js.map +2 -2
- package/dist/esm/is/SwcIfSlot.js.map +2 -2
- package/dist/esm/is/SwcIfSource.js.map +2 -2
- package/dist/esm/is/SwcIfSpan.js.map +2 -2
- package/dist/esm/is/SwcIfStyle.js.map +2 -2
- package/dist/esm/is/SwcIfTable.js.map +2 -2
- package/dist/esm/is/SwcIfTableCell.js.map +2 -2
- package/dist/esm/is/SwcIfTableRow.js.map +2 -2
- package/dist/esm/is/SwcIfTableSection.js.map +2 -2
- package/dist/esm/is/SwcIfTemplate.js.map +2 -2
- package/dist/esm/is/SwcIfTextArea.js.map +2 -2
- package/dist/esm/is/SwcIfTime.js.map +2 -2
- package/dist/esm/is/SwcIfTitle.js.map +2 -2
- package/dist/esm/is/SwcIfTrack.js.map +2 -2
- package/dist/esm/is/SwcIfUl.js.map +2 -2
- package/dist/esm/is/SwcIfVideo.js.map +2 -2
- package/dist/esm/is/SwcOtherAnchor.js.map +2 -2
- package/dist/esm/is/SwcOtherArea.js.map +2 -2
- package/dist/esm/is/SwcOtherAudio.js.map +2 -2
- package/dist/esm/is/SwcOtherBase.js.map +2 -2
- package/dist/esm/is/SwcOtherButton.js.map +2 -2
- package/dist/esm/is/SwcOtherCanvas.js.map +2 -2
- package/dist/esm/is/SwcOtherData.js.map +2 -2
- package/dist/esm/is/SwcOtherDataList.js.map +2 -2
- package/dist/esm/is/SwcOtherDetails.js.map +2 -2
- package/dist/esm/is/SwcOtherDialog.js.map +2 -2
- package/dist/esm/is/SwcOtherDiv.js.map +2 -2
- package/dist/esm/is/SwcOtherDl.js.map +2 -2
- package/dist/esm/is/SwcOtherEmbed.js.map +2 -2
- package/dist/esm/is/SwcOtherFieldSet.js.map +2 -2
- package/dist/esm/is/SwcOtherForm.js.map +2 -2
- package/dist/esm/is/SwcOtherHeading.js.map +2 -2
- package/dist/esm/is/SwcOtherHr.js.map +2 -2
- package/dist/esm/is/SwcOtherIFrame.js.map +2 -2
- package/dist/esm/is/SwcOtherImage.js.map +2 -2
- package/dist/esm/is/SwcOtherInput.js.map +2 -2
- package/dist/esm/is/SwcOtherLabel.js.map +2 -2
- package/dist/esm/is/SwcOtherLegend.js.map +2 -2
- package/dist/esm/is/SwcOtherLi.js.map +2 -2
- package/dist/esm/is/SwcOtherLink.js.map +2 -2
- package/dist/esm/is/SwcOtherMap.js.map +2 -2
- package/dist/esm/is/SwcOtherMeta.js.map +2 -2
- package/dist/esm/is/SwcOtherMeter.js.map +2 -2
- package/dist/esm/is/SwcOtherMod.js.map +2 -2
- package/dist/esm/is/SwcOtherObject.js.map +2 -2
- package/dist/esm/is/SwcOtherOl.js.map +2 -2
- package/dist/esm/is/SwcOtherOptGroup.js.map +2 -2
- package/dist/esm/is/SwcOtherOption.js.map +2 -2
- package/dist/esm/is/SwcOtherOutput.js.map +2 -2
- package/dist/esm/is/SwcOtherParagraph.js.map +2 -2
- package/dist/esm/is/SwcOtherParam.js.map +2 -2
- package/dist/esm/is/SwcOtherPicture.js.map +2 -2
- package/dist/esm/is/SwcOtherPre.js.map +2 -2
- package/dist/esm/is/SwcOtherProgress.js.map +2 -2
- package/dist/esm/is/SwcOtherQuote.js.map +2 -2
- package/dist/esm/is/SwcOtherScript.js.map +2 -2
- package/dist/esm/is/SwcOtherSelect.js.map +2 -2
- package/dist/esm/is/SwcOtherSlot.js.map +2 -2
- package/dist/esm/is/SwcOtherSource.js.map +2 -2
- package/dist/esm/is/SwcOtherSpan.js.map +2 -2
- package/dist/esm/is/SwcOtherStyle.js.map +2 -2
- package/dist/esm/is/SwcOtherTable.js.map +2 -2
- package/dist/esm/is/SwcOtherTableCell.js.map +2 -2
- package/dist/esm/is/SwcOtherTableRow.js.map +2 -2
- package/dist/esm/is/SwcOtherTableSection.js.map +2 -2
- package/dist/esm/is/SwcOtherTemplate.js.map +2 -2
- package/dist/esm/is/SwcOtherTextArea.js.map +2 -2
- package/dist/esm/is/SwcOtherTime.js.map +2 -2
- package/dist/esm/is/SwcOtherTitle.js.map +2 -2
- package/dist/esm/is/SwcOtherTrack.js.map +2 -2
- package/dist/esm/is/SwcOtherUl.js.map +2 -2
- package/dist/esm/is/SwcOtherVideo.js.map +2 -2
- package/dist/esm/is/SwcWhenAnchor.js.map +2 -2
- package/dist/esm/is/SwcWhenArea.js.map +2 -2
- package/dist/esm/is/SwcWhenAudio.js.map +2 -2
- package/dist/esm/is/SwcWhenBase.js.map +2 -2
- package/dist/esm/is/SwcWhenButton.js.map +2 -2
- package/dist/esm/is/SwcWhenCanvas.js.map +2 -2
- package/dist/esm/is/SwcWhenData.js.map +2 -2
- package/dist/esm/is/SwcWhenDataList.js.map +2 -2
- package/dist/esm/is/SwcWhenDetails.js.map +2 -2
- package/dist/esm/is/SwcWhenDialog.js.map +2 -2
- package/dist/esm/is/SwcWhenDiv.js.map +2 -2
- package/dist/esm/is/SwcWhenDl.js.map +2 -2
- package/dist/esm/is/SwcWhenEmbed.js.map +2 -2
- package/dist/esm/is/SwcWhenFieldSet.js.map +2 -2
- package/dist/esm/is/SwcWhenForm.js.map +2 -2
- package/dist/esm/is/SwcWhenHeading.js.map +2 -2
- package/dist/esm/is/SwcWhenHr.js.map +2 -2
- package/dist/esm/is/SwcWhenIFrame.js.map +2 -2
- package/dist/esm/is/SwcWhenImage.js.map +2 -2
- package/dist/esm/is/SwcWhenInput.js.map +2 -2
- package/dist/esm/is/SwcWhenLabel.js.map +2 -2
- package/dist/esm/is/SwcWhenLegend.js.map +2 -2
- package/dist/esm/is/SwcWhenLi.js.map +2 -2
- package/dist/esm/is/SwcWhenLink.js.map +2 -2
- package/dist/esm/is/SwcWhenMap.js.map +2 -2
- package/dist/esm/is/SwcWhenMeta.js.map +2 -2
- package/dist/esm/is/SwcWhenMeter.js.map +2 -2
- package/dist/esm/is/SwcWhenMod.js.map +2 -2
- package/dist/esm/is/SwcWhenObject.js.map +2 -2
- package/dist/esm/is/SwcWhenOl.js.map +2 -2
- package/dist/esm/is/SwcWhenOptGroup.js.map +2 -2
- package/dist/esm/is/SwcWhenOption.js.map +2 -2
- package/dist/esm/is/SwcWhenOutput.js.map +2 -2
- package/dist/esm/is/SwcWhenParagraph.js.map +2 -2
- package/dist/esm/is/SwcWhenParam.js.map +2 -2
- package/dist/esm/is/SwcWhenPicture.js.map +2 -2
- package/dist/esm/is/SwcWhenPre.js.map +2 -2
- package/dist/esm/is/SwcWhenProgress.js.map +2 -2
- package/dist/esm/is/SwcWhenQuote.js.map +2 -2
- package/dist/esm/is/SwcWhenScript.js.map +2 -2
- package/dist/esm/is/SwcWhenSelect.js.map +2 -2
- package/dist/esm/is/SwcWhenSlot.js.map +2 -2
- package/dist/esm/is/SwcWhenSource.js.map +2 -2
- package/dist/esm/is/SwcWhenSpan.js.map +2 -2
- package/dist/esm/is/SwcWhenStyle.js.map +2 -2
- package/dist/esm/is/SwcWhenTable.js.map +2 -2
- package/dist/esm/is/SwcWhenTableCell.js.map +2 -2
- package/dist/esm/is/SwcWhenTableRow.js.map +2 -2
- package/dist/esm/is/SwcWhenTableSection.js.map +2 -2
- package/dist/esm/is/SwcWhenTemplate.js.map +2 -2
- package/dist/esm/is/SwcWhenTextArea.js.map +2 -2
- package/dist/esm/is/SwcWhenTime.js.map +2 -2
- package/dist/esm/is/SwcWhenTitle.js.map +2 -2
- package/dist/esm/is/SwcWhenTrack.js.map +2 -2
- package/dist/esm/is/SwcWhenUl.js.map +2 -2
- package/dist/esm/is/SwcWhenVideo.js.map +2 -2
- package/dist/esm/utils/Utils.js +49 -17
- package/dist/esm/utils/Utils.js.map +2 -2
- package/dist/esm-bundle/dooboostore-simple-web-component.esm.js +2344 -2136
- package/dist/esm-bundle/dooboostore-simple-web-component.esm.js.map +4 -4
- package/dist/types/decorators/addEventListener.d.ts +8 -4
- package/dist/types/decorators/addEventListener.d.ts.map +1 -1
- package/dist/types/decorators/attribute.d.ts +13 -0
- package/dist/types/decorators/attribute.d.ts.map +1 -0
- package/dist/types/decorators/elementDefine.d.ts +2 -0
- package/dist/types/decorators/elementDefine.d.ts.map +1 -1
- package/dist/types/decorators/emitCustomEvent.d.ts +15 -0
- package/dist/types/decorators/emitCustomEvent.d.ts.map +1 -0
- package/dist/types/decorators/lifecycles.d.ts +7 -1
- package/dist/types/decorators/lifecycles.d.ts.map +1 -1
- package/dist/types/decorators/query.d.ts +5 -2
- package/dist/types/decorators/query.d.ts.map +1 -1
- package/dist/types/decorators/queryAll.d.ts +5 -2
- package/dist/types/decorators/queryAll.d.ts.map +1 -1
- package/dist/types/decorators/state.d.ts +12 -0
- package/dist/types/decorators/state.d.ts.map +1 -0
- package/dist/types/elements/SwcChoose.d.ts.map +1 -1
- package/dist/types/elements/SwcForOf.d.ts.map +1 -1
- package/dist/types/elements/SwcObject.d.ts.map +1 -1
- package/dist/types/index.d.ts +6 -7
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/is/SwcChooseAnchor.d.ts.map +1 -1
- package/dist/types/is/SwcChooseArea.d.ts.map +1 -1
- package/dist/types/is/SwcChooseAudio.d.ts.map +1 -1
- package/dist/types/is/SwcChooseBase.d.ts.map +1 -1
- package/dist/types/is/SwcChooseButton.d.ts.map +1 -1
- package/dist/types/is/SwcChooseCanvas.d.ts.map +1 -1
- package/dist/types/is/SwcChooseData.d.ts.map +1 -1
- package/dist/types/is/SwcChooseDataList.d.ts.map +1 -1
- package/dist/types/is/SwcChooseDetails.d.ts.map +1 -1
- package/dist/types/is/SwcChooseDialog.d.ts.map +1 -1
- package/dist/types/is/SwcChooseDiv.d.ts.map +1 -1
- package/dist/types/is/SwcChooseDl.d.ts.map +1 -1
- package/dist/types/is/SwcChooseEmbed.d.ts.map +1 -1
- package/dist/types/is/SwcChooseFieldSet.d.ts.map +1 -1
- package/dist/types/is/SwcChooseForm.d.ts.map +1 -1
- package/dist/types/is/SwcChooseHeading.d.ts.map +1 -1
- package/dist/types/is/SwcChooseHr.d.ts.map +1 -1
- package/dist/types/is/SwcChooseIFrame.d.ts.map +1 -1
- package/dist/types/is/SwcChooseImage.d.ts.map +1 -1
- package/dist/types/is/SwcChooseInput.d.ts.map +1 -1
- package/dist/types/is/SwcChooseLabel.d.ts.map +1 -1
- package/dist/types/is/SwcChooseLegend.d.ts.map +1 -1
- package/dist/types/is/SwcChooseLi.d.ts.map +1 -1
- package/dist/types/is/SwcChooseLink.d.ts.map +1 -1
- package/dist/types/is/SwcChooseMap.d.ts.map +1 -1
- package/dist/types/is/SwcChooseMeta.d.ts.map +1 -1
- package/dist/types/is/SwcChooseMeter.d.ts.map +1 -1
- package/dist/types/is/SwcChooseMod.d.ts.map +1 -1
- package/dist/types/is/SwcChooseObject.d.ts.map +1 -1
- package/dist/types/is/SwcChooseOl.d.ts.map +1 -1
- package/dist/types/is/SwcChooseOptGroup.d.ts.map +1 -1
- package/dist/types/is/SwcChooseOption.d.ts.map +1 -1
- package/dist/types/is/SwcChooseOutput.d.ts.map +1 -1
- package/dist/types/is/SwcChooseParagraph.d.ts.map +1 -1
- package/dist/types/is/SwcChooseParam.d.ts.map +1 -1
- package/dist/types/is/SwcChoosePicture.d.ts.map +1 -1
- package/dist/types/is/SwcChoosePre.d.ts.map +1 -1
- package/dist/types/is/SwcChooseProgress.d.ts.map +1 -1
- package/dist/types/is/SwcChooseQuote.d.ts.map +1 -1
- package/dist/types/is/SwcChooseScript.d.ts.map +1 -1
- package/dist/types/is/SwcChooseSelect.d.ts.map +1 -1
- package/dist/types/is/SwcChooseSlot.d.ts.map +1 -1
- package/dist/types/is/SwcChooseSource.d.ts.map +1 -1
- package/dist/types/is/SwcChooseSpan.d.ts.map +1 -1
- package/dist/types/is/SwcChooseStyle.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTable.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTableCell.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTableRow.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTableSection.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTemplate.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTextArea.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTime.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTitle.d.ts.map +1 -1
- package/dist/types/is/SwcChooseTrack.d.ts.map +1 -1
- package/dist/types/is/SwcChooseUl.d.ts.map +1 -1
- package/dist/types/is/SwcChooseVideo.d.ts.map +1 -1
- package/dist/types/is/SwcIfAnchor.d.ts.map +1 -1
- package/dist/types/is/SwcIfArea.d.ts.map +1 -1
- package/dist/types/is/SwcIfAudio.d.ts.map +1 -1
- package/dist/types/is/SwcIfBase.d.ts.map +1 -1
- package/dist/types/is/SwcIfButton.d.ts.map +1 -1
- package/dist/types/is/SwcIfCanvas.d.ts.map +1 -1
- package/dist/types/is/SwcIfData.d.ts.map +1 -1
- package/dist/types/is/SwcIfDataList.d.ts.map +1 -1
- package/dist/types/is/SwcIfDetails.d.ts.map +1 -1
- package/dist/types/is/SwcIfDialog.d.ts.map +1 -1
- package/dist/types/is/SwcIfDiv.d.ts.map +1 -1
- package/dist/types/is/SwcIfDl.d.ts.map +1 -1
- package/dist/types/is/SwcIfEmbed.d.ts.map +1 -1
- package/dist/types/is/SwcIfFieldSet.d.ts.map +1 -1
- package/dist/types/is/SwcIfForm.d.ts.map +1 -1
- package/dist/types/is/SwcIfHeading.d.ts.map +1 -1
- package/dist/types/is/SwcIfHr.d.ts.map +1 -1
- package/dist/types/is/SwcIfIFrame.d.ts.map +1 -1
- package/dist/types/is/SwcIfImage.d.ts.map +1 -1
- package/dist/types/is/SwcIfInput.d.ts.map +1 -1
- package/dist/types/is/SwcIfLabel.d.ts.map +1 -1
- package/dist/types/is/SwcIfLegend.d.ts.map +1 -1
- package/dist/types/is/SwcIfLi.d.ts.map +1 -1
- package/dist/types/is/SwcIfLink.d.ts.map +1 -1
- package/dist/types/is/SwcIfMap.d.ts.map +1 -1
- package/dist/types/is/SwcIfMeta.d.ts.map +1 -1
- package/dist/types/is/SwcIfMeter.d.ts.map +1 -1
- package/dist/types/is/SwcIfMod.d.ts.map +1 -1
- package/dist/types/is/SwcIfObject.d.ts.map +1 -1
- package/dist/types/is/SwcIfOl.d.ts.map +1 -1
- package/dist/types/is/SwcIfOptGroup.d.ts.map +1 -1
- package/dist/types/is/SwcIfOption.d.ts.map +1 -1
- package/dist/types/is/SwcIfOutput.d.ts.map +1 -1
- package/dist/types/is/SwcIfParagraph.d.ts.map +1 -1
- package/dist/types/is/SwcIfParam.d.ts.map +1 -1
- package/dist/types/is/SwcIfPicture.d.ts.map +1 -1
- package/dist/types/is/SwcIfPre.d.ts.map +1 -1
- package/dist/types/is/SwcIfProgress.d.ts.map +1 -1
- package/dist/types/is/SwcIfQuote.d.ts.map +1 -1
- package/dist/types/is/SwcIfScript.d.ts.map +1 -1
- package/dist/types/is/SwcIfSelect.d.ts.map +1 -1
- package/dist/types/is/SwcIfSlot.d.ts.map +1 -1
- package/dist/types/is/SwcIfSource.d.ts.map +1 -1
- package/dist/types/is/SwcIfSpan.d.ts.map +1 -1
- package/dist/types/is/SwcIfStyle.d.ts.map +1 -1
- package/dist/types/is/SwcIfTable.d.ts.map +1 -1
- package/dist/types/is/SwcIfTableCell.d.ts.map +1 -1
- package/dist/types/is/SwcIfTableRow.d.ts.map +1 -1
- package/dist/types/is/SwcIfTableSection.d.ts.map +1 -1
- package/dist/types/is/SwcIfTemplate.d.ts.map +1 -1
- package/dist/types/is/SwcIfTextArea.d.ts.map +1 -1
- package/dist/types/is/SwcIfTime.d.ts.map +1 -1
- package/dist/types/is/SwcIfTitle.d.ts.map +1 -1
- package/dist/types/is/SwcIfTrack.d.ts.map +1 -1
- package/dist/types/is/SwcIfUl.d.ts.map +1 -1
- package/dist/types/is/SwcIfVideo.d.ts.map +1 -1
- package/dist/types/is/SwcWhenAnchor.d.ts.map +1 -1
- package/dist/types/is/SwcWhenArea.d.ts.map +1 -1
- package/dist/types/is/SwcWhenAudio.d.ts.map +1 -1
- package/dist/types/is/SwcWhenBase.d.ts.map +1 -1
- package/dist/types/is/SwcWhenButton.d.ts.map +1 -1
- package/dist/types/is/SwcWhenCanvas.d.ts.map +1 -1
- package/dist/types/is/SwcWhenData.d.ts.map +1 -1
- package/dist/types/is/SwcWhenDataList.d.ts.map +1 -1
- package/dist/types/is/SwcWhenDetails.d.ts.map +1 -1
- package/dist/types/is/SwcWhenDialog.d.ts.map +1 -1
- package/dist/types/is/SwcWhenDiv.d.ts.map +1 -1
- package/dist/types/is/SwcWhenDl.d.ts.map +1 -1
- package/dist/types/is/SwcWhenEmbed.d.ts.map +1 -1
- package/dist/types/is/SwcWhenFieldSet.d.ts.map +1 -1
- package/dist/types/is/SwcWhenForm.d.ts.map +1 -1
- package/dist/types/is/SwcWhenHeading.d.ts.map +1 -1
- package/dist/types/is/SwcWhenHr.d.ts.map +1 -1
- package/dist/types/is/SwcWhenIFrame.d.ts.map +1 -1
- package/dist/types/is/SwcWhenImage.d.ts.map +1 -1
- package/dist/types/is/SwcWhenInput.d.ts.map +1 -1
- package/dist/types/is/SwcWhenLabel.d.ts.map +1 -1
- package/dist/types/is/SwcWhenLegend.d.ts.map +1 -1
- package/dist/types/is/SwcWhenLi.d.ts.map +1 -1
- package/dist/types/is/SwcWhenLink.d.ts.map +1 -1
- package/dist/types/is/SwcWhenMap.d.ts.map +1 -1
- package/dist/types/is/SwcWhenMeta.d.ts.map +1 -1
- package/dist/types/is/SwcWhenMeter.d.ts.map +1 -1
- package/dist/types/is/SwcWhenMod.d.ts.map +1 -1
- package/dist/types/is/SwcWhenObject.d.ts.map +1 -1
- package/dist/types/is/SwcWhenOl.d.ts.map +1 -1
- package/dist/types/is/SwcWhenOptGroup.d.ts.map +1 -1
- package/dist/types/is/SwcWhenOption.d.ts.map +1 -1
- package/dist/types/is/SwcWhenOutput.d.ts.map +1 -1
- package/dist/types/is/SwcWhenParagraph.d.ts.map +1 -1
- package/dist/types/is/SwcWhenParam.d.ts.map +1 -1
- package/dist/types/is/SwcWhenPicture.d.ts.map +1 -1
- package/dist/types/is/SwcWhenPre.d.ts.map +1 -1
- package/dist/types/is/SwcWhenProgress.d.ts.map +1 -1
- package/dist/types/is/SwcWhenQuote.d.ts.map +1 -1
- package/dist/types/is/SwcWhenScript.d.ts.map +1 -1
- package/dist/types/is/SwcWhenSelect.d.ts.map +1 -1
- package/dist/types/is/SwcWhenSlot.d.ts.map +1 -1
- package/dist/types/is/SwcWhenSource.d.ts.map +1 -1
- package/dist/types/is/SwcWhenSpan.d.ts.map +1 -1
- package/dist/types/is/SwcWhenStyle.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTable.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTableCell.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTableRow.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTableSection.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTemplate.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTextArea.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTime.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTitle.d.ts.map +1 -1
- package/dist/types/is/SwcWhenTrack.d.ts.map +1 -1
- package/dist/types/is/SwcWhenUl.d.ts.map +1 -1
- package/dist/types/is/SwcWhenVideo.d.ts.map +1 -1
- package/dist/types/utils/Utils.d.ts.map +1 -1
- package/dist/umd-bundle/dooboostore-simple-web-component.umd.js +2344 -2136
- package/dist/umd-bundle/dooboostore-simple-web-component.umd.js.map +4 -4
- package/package.json +4 -4
- package/src/decorators/addEventListener.ts +11 -5
- package/src/decorators/attribute.ts +77 -0
- package/src/decorators/elementDefine.ts +269 -149
- package/src/decorators/emitCustomEvent.ts +57 -0
- package/src/decorators/lifecycles.ts +44 -4
- package/src/decorators/query.ts +35 -8
- package/src/decorators/queryAll.ts +35 -8
- package/src/decorators/state.ts +44 -0
- package/src/elements/SwcChoose.ts +1 -5
- package/src/elements/SwcForOf.ts +2 -1
- package/src/elements/SwcObject.ts +8 -6
- package/src/index.ts +6 -7
- package/src/is/SwcChooseAnchor.ts +0 -1
- package/src/is/SwcChooseArea.ts +0 -1
- package/src/is/SwcChooseAudio.ts +0 -1
- package/src/is/SwcChooseBase.ts +0 -1
- package/src/is/SwcChooseButton.ts +0 -1
- package/src/is/SwcChooseCanvas.ts +0 -1
- package/src/is/SwcChooseData.ts +0 -1
- package/src/is/SwcChooseDataList.ts +0 -1
- package/src/is/SwcChooseDetails.ts +0 -1
- package/src/is/SwcChooseDialog.ts +0 -1
- package/src/is/SwcChooseDiv.ts +0 -1
- package/src/is/SwcChooseDl.ts +0 -1
- package/src/is/SwcChooseEmbed.ts +0 -1
- package/src/is/SwcChooseFieldSet.ts +0 -1
- package/src/is/SwcChooseForm.ts +0 -1
- package/src/is/SwcChooseHeading.ts +0 -1
- package/src/is/SwcChooseHr.ts +0 -1
- package/src/is/SwcChooseIFrame.ts +0 -1
- package/src/is/SwcChooseImage.ts +0 -1
- package/src/is/SwcChooseInput.ts +0 -1
- package/src/is/SwcChooseLabel.ts +0 -1
- package/src/is/SwcChooseLegend.ts +0 -1
- package/src/is/SwcChooseLi.ts +0 -1
- package/src/is/SwcChooseLink.ts +0 -1
- package/src/is/SwcChooseMap.ts +0 -1
- package/src/is/SwcChooseMeta.ts +0 -1
- package/src/is/SwcChooseMeter.ts +0 -1
- package/src/is/SwcChooseMod.ts +0 -1
- package/src/is/SwcChooseObject.ts +0 -1
- package/src/is/SwcChooseOl.ts +0 -1
- package/src/is/SwcChooseOptGroup.ts +0 -1
- package/src/is/SwcChooseOption.ts +0 -1
- package/src/is/SwcChooseOutput.ts +0 -1
- package/src/is/SwcChooseParagraph.ts +0 -1
- package/src/is/SwcChooseParam.ts +0 -1
- package/src/is/SwcChoosePicture.ts +0 -1
- package/src/is/SwcChoosePre.ts +0 -1
- package/src/is/SwcChooseProgress.ts +0 -1
- package/src/is/SwcChooseQuote.ts +0 -1
- package/src/is/SwcChooseScript.ts +0 -1
- package/src/is/SwcChooseSelect.ts +0 -1
- package/src/is/SwcChooseSlot.ts +0 -1
- package/src/is/SwcChooseSource.ts +0 -1
- package/src/is/SwcChooseSpan.ts +0 -1
- package/src/is/SwcChooseStyle.ts +0 -1
- package/src/is/SwcChooseTable.ts +0 -1
- package/src/is/SwcChooseTableCell.ts +0 -1
- package/src/is/SwcChooseTableRow.ts +0 -1
- package/src/is/SwcChooseTableSection.ts +0 -1
- package/src/is/SwcChooseTemplate.ts +0 -1
- package/src/is/SwcChooseTextArea.ts +0 -1
- package/src/is/SwcChooseTime.ts +0 -1
- package/src/is/SwcChooseTitle.ts +0 -1
- package/src/is/SwcChooseTrack.ts +0 -1
- package/src/is/SwcChooseUl.ts +0 -1
- package/src/is/SwcChooseVideo.ts +0 -1
- package/src/is/SwcIfAnchor.ts +0 -1
- package/src/is/SwcIfArea.ts +0 -1
- package/src/is/SwcIfAudio.ts +0 -1
- package/src/is/SwcIfBase.ts +0 -1
- package/src/is/SwcIfButton.ts +0 -1
- package/src/is/SwcIfCanvas.ts +0 -1
- package/src/is/SwcIfData.ts +0 -1
- package/src/is/SwcIfDataList.ts +0 -1
- package/src/is/SwcIfDetails.ts +0 -1
- package/src/is/SwcIfDialog.ts +0 -1
- package/src/is/SwcIfDiv.ts +0 -1
- package/src/is/SwcIfDl.ts +0 -1
- package/src/is/SwcIfEmbed.ts +0 -1
- package/src/is/SwcIfFieldSet.ts +0 -1
- package/src/is/SwcIfForm.ts +0 -1
- package/src/is/SwcIfHeading.ts +0 -1
- package/src/is/SwcIfHr.ts +0 -1
- package/src/is/SwcIfIFrame.ts +0 -1
- package/src/is/SwcIfImage.ts +0 -1
- package/src/is/SwcIfInput.ts +0 -1
- package/src/is/SwcIfLabel.ts +0 -1
- package/src/is/SwcIfLegend.ts +0 -1
- package/src/is/SwcIfLi.ts +0 -1
- package/src/is/SwcIfLink.ts +0 -1
- package/src/is/SwcIfMap.ts +0 -1
- package/src/is/SwcIfMeta.ts +0 -1
- package/src/is/SwcIfMeter.ts +0 -1
- package/src/is/SwcIfMod.ts +0 -1
- package/src/is/SwcIfObject.ts +0 -1
- package/src/is/SwcIfOl.ts +0 -1
- package/src/is/SwcIfOptGroup.ts +0 -1
- package/src/is/SwcIfOption.ts +0 -1
- package/src/is/SwcIfOutput.ts +0 -1
- package/src/is/SwcIfParagraph.ts +0 -1
- package/src/is/SwcIfParam.ts +0 -1
- package/src/is/SwcIfPicture.ts +0 -1
- package/src/is/SwcIfPre.ts +0 -1
- package/src/is/SwcIfProgress.ts +0 -1
- package/src/is/SwcIfQuote.ts +0 -1
- package/src/is/SwcIfScript.ts +0 -1
- package/src/is/SwcIfSelect.ts +0 -1
- package/src/is/SwcIfSlot.ts +0 -1
- package/src/is/SwcIfSource.ts +0 -1
- package/src/is/SwcIfSpan.ts +0 -1
- package/src/is/SwcIfStyle.ts +0 -1
- package/src/is/SwcIfTable.ts +0 -1
- package/src/is/SwcIfTableCell.ts +0 -1
- package/src/is/SwcIfTableRow.ts +0 -1
- package/src/is/SwcIfTableSection.ts +0 -1
- package/src/is/SwcIfTemplate.ts +0 -1
- package/src/is/SwcIfTextArea.ts +0 -1
- package/src/is/SwcIfTime.ts +0 -1
- package/src/is/SwcIfTitle.ts +0 -1
- package/src/is/SwcIfTrack.ts +0 -1
- package/src/is/SwcIfUl.ts +0 -1
- package/src/is/SwcIfVideo.ts +0 -1
- package/src/is/SwcOtherAnchor.ts +1 -1
- package/src/is/SwcOtherArea.ts +1 -1
- package/src/is/SwcOtherAudio.ts +1 -1
- package/src/is/SwcOtherBase.ts +1 -1
- package/src/is/SwcOtherButton.ts +1 -1
- package/src/is/SwcOtherCanvas.ts +1 -1
- package/src/is/SwcOtherData.ts +1 -1
- package/src/is/SwcOtherDataList.ts +1 -1
- package/src/is/SwcOtherDetails.ts +1 -1
- package/src/is/SwcOtherDialog.ts +1 -1
- package/src/is/SwcOtherDiv.ts +1 -1
- package/src/is/SwcOtherDl.ts +1 -1
- package/src/is/SwcOtherEmbed.ts +1 -1
- package/src/is/SwcOtherFieldSet.ts +1 -1
- package/src/is/SwcOtherForm.ts +1 -1
- package/src/is/SwcOtherHeading.ts +1 -1
- package/src/is/SwcOtherHr.ts +1 -1
- package/src/is/SwcOtherIFrame.ts +1 -1
- package/src/is/SwcOtherImage.ts +1 -1
- package/src/is/SwcOtherInput.ts +1 -1
- package/src/is/SwcOtherLabel.ts +1 -1
- package/src/is/SwcOtherLegend.ts +1 -1
- package/src/is/SwcOtherLi.ts +1 -1
- package/src/is/SwcOtherLink.ts +1 -1
- package/src/is/SwcOtherMap.ts +1 -1
- package/src/is/SwcOtherMeta.ts +1 -1
- package/src/is/SwcOtherMeter.ts +1 -1
- package/src/is/SwcOtherMod.ts +1 -1
- package/src/is/SwcOtherObject.ts +1 -1
- package/src/is/SwcOtherOl.ts +1 -1
- package/src/is/SwcOtherOptGroup.ts +1 -1
- package/src/is/SwcOtherOption.ts +1 -1
- package/src/is/SwcOtherOutput.ts +1 -1
- package/src/is/SwcOtherParagraph.ts +1 -1
- package/src/is/SwcOtherParam.ts +1 -1
- package/src/is/SwcOtherPicture.ts +1 -1
- package/src/is/SwcOtherPre.ts +1 -1
- package/src/is/SwcOtherProgress.ts +1 -1
- package/src/is/SwcOtherQuote.ts +1 -1
- package/src/is/SwcOtherScript.ts +1 -1
- package/src/is/SwcOtherSelect.ts +1 -1
- package/src/is/SwcOtherSlot.ts +1 -1
- package/src/is/SwcOtherSource.ts +1 -1
- package/src/is/SwcOtherSpan.ts +1 -1
- package/src/is/SwcOtherStyle.ts +1 -1
- package/src/is/SwcOtherTable.ts +1 -1
- package/src/is/SwcOtherTableCell.ts +1 -1
- package/src/is/SwcOtherTableRow.ts +1 -1
- package/src/is/SwcOtherTableSection.ts +1 -1
- package/src/is/SwcOtherTemplate.ts +1 -1
- package/src/is/SwcOtherTextArea.ts +1 -1
- package/src/is/SwcOtherTime.ts +1 -1
- package/src/is/SwcOtherTitle.ts +1 -1
- package/src/is/SwcOtherTrack.ts +1 -1
- package/src/is/SwcOtherUl.ts +1 -1
- package/src/is/SwcOtherVideo.ts +1 -1
- package/src/is/SwcWhenAnchor.ts +1 -3
- package/src/is/SwcWhenArea.ts +1 -3
- package/src/is/SwcWhenAudio.ts +1 -3
- package/src/is/SwcWhenBase.ts +1 -3
- package/src/is/SwcWhenButton.ts +1 -3
- package/src/is/SwcWhenCanvas.ts +1 -3
- package/src/is/SwcWhenData.ts +1 -3
- package/src/is/SwcWhenDataList.ts +1 -3
- package/src/is/SwcWhenDetails.ts +1 -3
- package/src/is/SwcWhenDialog.ts +1 -3
- package/src/is/SwcWhenDiv.ts +1 -3
- package/src/is/SwcWhenDl.ts +1 -3
- package/src/is/SwcWhenEmbed.ts +1 -3
- package/src/is/SwcWhenFieldSet.ts +1 -3
- package/src/is/SwcWhenForm.ts +1 -3
- package/src/is/SwcWhenHeading.ts +1 -3
- package/src/is/SwcWhenHr.ts +1 -3
- package/src/is/SwcWhenIFrame.ts +1 -3
- package/src/is/SwcWhenImage.ts +1 -3
- package/src/is/SwcWhenInput.ts +1 -3
- package/src/is/SwcWhenLabel.ts +1 -3
- package/src/is/SwcWhenLegend.ts +1 -3
- package/src/is/SwcWhenLi.ts +1 -3
- package/src/is/SwcWhenLink.ts +1 -3
- package/src/is/SwcWhenMap.ts +1 -3
- package/src/is/SwcWhenMeta.ts +1 -3
- package/src/is/SwcWhenMeter.ts +1 -3
- package/src/is/SwcWhenMod.ts +1 -3
- package/src/is/SwcWhenObject.ts +1 -3
- package/src/is/SwcWhenOl.ts +1 -3
- package/src/is/SwcWhenOptGroup.ts +1 -3
- package/src/is/SwcWhenOption.ts +1 -3
- package/src/is/SwcWhenOutput.ts +1 -3
- package/src/is/SwcWhenParagraph.ts +1 -3
- package/src/is/SwcWhenParam.ts +1 -3
- package/src/is/SwcWhenPicture.ts +1 -3
- package/src/is/SwcWhenPre.ts +1 -3
- package/src/is/SwcWhenProgress.ts +1 -3
- package/src/is/SwcWhenQuote.ts +1 -3
- package/src/is/SwcWhenScript.ts +1 -3
- package/src/is/SwcWhenSelect.ts +1 -3
- package/src/is/SwcWhenSlot.ts +1 -3
- package/src/is/SwcWhenSource.ts +1 -3
- package/src/is/SwcWhenSpan.ts +1 -3
- package/src/is/SwcWhenStyle.ts +1 -3
- package/src/is/SwcWhenTable.ts +1 -3
- package/src/is/SwcWhenTableCell.ts +1 -3
- package/src/is/SwcWhenTableRow.ts +1 -3
- package/src/is/SwcWhenTableSection.ts +1 -3
- package/src/is/SwcWhenTemplate.ts +1 -3
- package/src/is/SwcWhenTextArea.ts +1 -3
- package/src/is/SwcWhenTime.ts +1 -3
- package/src/is/SwcWhenTitle.ts +1 -3
- package/src/is/SwcWhenTrack.ts +1 -3
- package/src/is/SwcWhenUl.ts +1 -3
- package/src/is/SwcWhenVideo.ts +1 -3
- package/src/utils/Utils.ts +65 -22
- package/dist/cjs/decorators/attributeChanged.js +0 -62
- package/dist/cjs/decorators/attributeChanged.js.map +0 -7
- package/dist/esm/decorators/attributeChanged.js +0 -43
- package/dist/esm/decorators/attributeChanged.js.map +0 -7
- package/dist/types/decorators/attributeChanged.d.ts +0 -6
- package/dist/types/decorators/attributeChanged.d.ts.map +0 -1
- package/src/decorators/attributeChanged.ts +0 -43
|
@@ -1,19 +1,24 @@
|
|
|
1
1
|
import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';
|
|
2
|
-
import { getAttributeChangedMap, ATTRIBUTE_CHANGED_WILDCARD } from './attributeChanged';
|
|
3
2
|
import { getInnerHtmlMetadataList } from './innerHtml';
|
|
4
3
|
import { getQueryMetadata } from './query';
|
|
5
4
|
import { getQueryAllMetadata } from './queryAll';
|
|
6
5
|
import { getAddEventListenerMetadata } from './addEventListener';
|
|
7
|
-
import { getLifecycleMetadata, ON_BEFORE_CONNECTED_METADATA_KEY, ON_AFTER_CONNECTED_METADATA_KEY, ON_BEFORE_DISCONNECTED_METADATA_KEY, ON_AFTER_DISCONNECTED_METADATA_KEY, ON_BEFORE_ADOPTED_METADATA_KEY, ON_AFTER_ADOPTED_METADATA_KEY } from './lifecycles';
|
|
6
|
+
import { getLifecycleMetadata, ON_BEFORE_CONNECTED_METADATA_KEY, ON_AFTER_CONNECTED_METADATA_KEY, ON_BEFORE_DISCONNECTED_METADATA_KEY, ON_AFTER_DISCONNECTED_METADATA_KEY, ON_BEFORE_ADOPTED_METADATA_KEY, ON_AFTER_ADOPTED_METADATA_KEY, ON_ADD_EVENT_LISTENER_METADATA_KEY, ON_ATTRIBUTE_CHANGED_METADATA_KEY, ATTRIBUTE_CHANGED_WILDCARD } from './lifecycles';
|
|
7
|
+
import { getAttributeMetadataList } from './attribute';
|
|
8
|
+
import { getStateMetadataList } from './state';
|
|
9
|
+
import { getEmitCustomEventMetadataList } from './emitCustomEvent';
|
|
10
|
+
import { SwcUtils } from '../utils/Utils';
|
|
8
11
|
|
|
9
12
|
export interface ElementConfig {
|
|
10
13
|
name: string;
|
|
11
14
|
extends?: string;
|
|
12
15
|
observedAttributes?: string[];
|
|
13
16
|
customElementRegistry?: CustomElementRegistry;
|
|
17
|
+
autoRemoveEventListeners?: boolean;
|
|
14
18
|
}
|
|
15
19
|
|
|
16
20
|
export const ELEMENT_CONFIG_KEY = Symbol('simple-web-component:element-config');
|
|
21
|
+
export const STATE_CHANGE_EVENT = 'swc:state-change';
|
|
17
22
|
|
|
18
23
|
const BUILT_IN_TAG_MAP = new Map<any, string>();
|
|
19
24
|
|
|
@@ -23,7 +28,6 @@ const registerTag = (className: string, tagName: string) => {
|
|
|
23
28
|
}
|
|
24
29
|
};
|
|
25
30
|
|
|
26
|
-
// Register comprehensive list of supported tags for automatic extends inference
|
|
27
31
|
[
|
|
28
32
|
['HTMLAnchorElement', 'a'],
|
|
29
33
|
['HTMLAreaElement', 'area'],
|
|
@@ -88,7 +92,6 @@ export const elementDefine =
|
|
|
88
92
|
(constructor: any) => {
|
|
89
93
|
const config: ElementConfig = typeof inConfig === 'string' ? { name: inConfig } : inConfig;
|
|
90
94
|
|
|
91
|
-
// 1. Automatically derive extendsTagName from prototype chain if not provided
|
|
92
95
|
let extendsTagName = config.extends;
|
|
93
96
|
if (!extendsTagName) {
|
|
94
97
|
let proto = Object.getPrototypeOf(constructor);
|
|
@@ -99,15 +102,22 @@ export const elementDefine =
|
|
|
99
102
|
}
|
|
100
103
|
}
|
|
101
104
|
|
|
102
|
-
|
|
103
|
-
const
|
|
104
|
-
const
|
|
105
|
-
const
|
|
105
|
+
const attributePropsList = getAttributeMetadataList(constructor);
|
|
106
|
+
const emitCustomEventList = getEmitCustomEventMetadataList(constructor);
|
|
107
|
+
const stateList = getStateMetadataList(constructor);
|
|
108
|
+
const observedFromProps = attributePropsList ? attributePropsList.map(it => it.options.name!) : [];
|
|
109
|
+
const observedFromEmits = emitCustomEventList ? emitCustomEventList.map(it => it.options.attributeName!) : [];
|
|
110
|
+
const mergedObservedAttributes = [...new Set([...(config.observedAttributes ?? []), ...observedFromProps, ...observedFromEmits])];
|
|
106
111
|
|
|
107
|
-
// 3. Create a new anonymous class that extends the original constructor
|
|
108
112
|
const NewClass = class extends (constructor as any) {
|
|
113
|
+
private _swcId = Math.random().toString(36).substring(2, 11);
|
|
109
114
|
private _observer: MutationObserver | null = null;
|
|
110
115
|
private _boundElements = new WeakMap<Element, Set<string | symbol>>();
|
|
116
|
+
private _activeListeners: Array<{ el: Element | HTMLElement; type: string; handler: EventListener; options?: any }> = [];
|
|
117
|
+
private _emitHandlers = new Map<string, EventListener>();
|
|
118
|
+
private _stateBindings = new Map<string, any[]>();
|
|
119
|
+
private _internalStates = new Map<string | symbol, any>();
|
|
120
|
+
private _externalSources = new Map<string, HTMLElement>();
|
|
111
121
|
|
|
112
122
|
static get observedAttributes() {
|
|
113
123
|
return mergedObservedAttributes;
|
|
@@ -115,32 +125,74 @@ export const elementDefine =
|
|
|
115
125
|
|
|
116
126
|
constructor(...args: any[]) {
|
|
117
127
|
super(...args);
|
|
128
|
+
if (stateList) {
|
|
129
|
+
stateList.forEach(meta => {
|
|
130
|
+
const key = meta.propertyKey;
|
|
131
|
+
const stateName = meta.options.name!;
|
|
132
|
+
const initialVal = (this as any)[key];
|
|
133
|
+
this._internalStates.set(
|
|
134
|
+
key,
|
|
135
|
+
SwcUtils.createReactiveProxy(initialVal, () => this._updateState(stateName))
|
|
136
|
+
);
|
|
137
|
+
Object.defineProperty(this, key, {
|
|
138
|
+
get: () => this._internalStates.get(key),
|
|
139
|
+
set: newVal => {
|
|
140
|
+
if (this._internalStates.get(key) === newVal) return;
|
|
141
|
+
this._internalStates.set(
|
|
142
|
+
key,
|
|
143
|
+
SwcUtils.createReactiveProxy(newVal, () => this._updateState(stateName))
|
|
144
|
+
);
|
|
145
|
+
this._updateState(stateName);
|
|
146
|
+
},
|
|
147
|
+
enumerable: true,
|
|
148
|
+
configurable: true
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
}
|
|
118
152
|
const innerHtmlList = getInnerHtmlMetadataList(this);
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
if (useShadow === true && !this.shadowRoot) {
|
|
153
|
+
if (innerHtmlList?.some(it => it.options.useShadow === true) && !this.shadowRoot) {
|
|
122
154
|
this.attachShadow({ mode: 'open' });
|
|
123
155
|
}
|
|
124
156
|
}
|
|
125
157
|
|
|
126
158
|
private _syncDecorators() {
|
|
127
|
-
|
|
159
|
+
this._buildStateMap();
|
|
160
|
+
|
|
161
|
+
const getSearchRoots = (rootOption?: string): Node[] => {
|
|
162
|
+
const roots: Node[] = [];
|
|
163
|
+
if (rootOption === 'shadow') {
|
|
164
|
+
if (this.shadowRoot) roots.push(this.shadowRoot);
|
|
165
|
+
} else if (rootOption === 'light') {
|
|
166
|
+
roots.push(this as any as Node);
|
|
167
|
+
} else if (rootOption === 'all') {
|
|
168
|
+
if (this.shadowRoot) roots.push(this.shadowRoot);
|
|
169
|
+
roots.push(this as any as Node);
|
|
170
|
+
} else {
|
|
171
|
+
// Default: 'auto'
|
|
172
|
+
roots.push(this.shadowRoot || (this as any as Node));
|
|
173
|
+
}
|
|
174
|
+
return roots;
|
|
175
|
+
};
|
|
176
|
+
|
|
128
177
|
const queryMetadata = getQueryMetadata(this);
|
|
129
178
|
if (queryMetadata) {
|
|
130
179
|
queryMetadata
|
|
131
180
|
.filter(it => it.isMethod)
|
|
132
181
|
.forEach(it => {
|
|
133
|
-
const
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
182
|
+
const searchRoots = getSearchRoots(it.options.root);
|
|
183
|
+
let foundEl: Element | null = null;
|
|
184
|
+
for (const root of searchRoots) {
|
|
185
|
+
foundEl = it.selector ? (root as HTMLElement).querySelector(it.selector) : (this as any as Element);
|
|
186
|
+
if (foundEl) break;
|
|
187
|
+
}
|
|
188
|
+
if (foundEl) {
|
|
189
|
+
let bound = this._boundElements.get(foundEl);
|
|
138
190
|
if (!bound) {
|
|
139
191
|
bound = new Set();
|
|
140
|
-
this._boundElements.set(
|
|
192
|
+
this._boundElements.set(foundEl, bound);
|
|
141
193
|
}
|
|
142
194
|
if (!bound.has(it.propertyKey)) {
|
|
143
|
-
(this as any)[it.propertyKey](
|
|
195
|
+
(this as any)[it.propertyKey](foundEl);
|
|
144
196
|
bound.add(it.propertyKey);
|
|
145
197
|
}
|
|
146
198
|
}
|
|
@@ -152,188 +204,256 @@ export const elementDefine =
|
|
|
152
204
|
queryAllMetadata
|
|
153
205
|
.filter(it => it.isMethod)
|
|
154
206
|
.forEach(it => {
|
|
155
|
-
const
|
|
156
|
-
const
|
|
157
|
-
(
|
|
207
|
+
const searchRoots = getSearchRoots(it.options.root);
|
|
208
|
+
const allElements: Element[] = [];
|
|
209
|
+
searchRoots.forEach(root => {
|
|
210
|
+
const found = it.selector ? (root as HTMLElement).querySelectorAll(it.selector) : [this as any as Element];
|
|
211
|
+
allElements.push(...Array.from(found));
|
|
212
|
+
});
|
|
213
|
+
(this as any)[it.propertyKey](allElements);
|
|
158
214
|
});
|
|
159
215
|
}
|
|
160
216
|
|
|
161
|
-
// 6. Register @addEventListener methods
|
|
162
217
|
const eventListeners = getAddEventListenerMetadata(this);
|
|
163
218
|
if (eventListeners) {
|
|
164
219
|
eventListeners.forEach(it => {
|
|
165
|
-
const {
|
|
166
|
-
const
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
220
|
+
const { query, type, root: rootOption, ...options } = it.options;
|
|
221
|
+
const searchRoots = getSearchRoots(rootOption);
|
|
222
|
+
searchRoots.forEach(root => {
|
|
223
|
+
const targetElements = query ? (root as HTMLElement).querySelectorAll(query) : [this as any as Element];
|
|
224
|
+
targetElements.forEach(targetElement => {
|
|
225
|
+
if (targetElement) {
|
|
226
|
+
let bound = this._boundElements.get(targetElement);
|
|
227
|
+
if (!bound) {
|
|
228
|
+
bound = new Set();
|
|
229
|
+
this._boundElements.set(targetElement, bound);
|
|
230
|
+
}
|
|
231
|
+
const eventKey = `event:${String(it.propertyKey)}:${type}`;
|
|
232
|
+
if (!bound.has(eventKey)) {
|
|
233
|
+
const handler = (event: any) => {
|
|
234
|
+
if (it.options.stopImmediatePropagation) event.stopImmediatePropagation();
|
|
235
|
+
if (it.options.stopPropagation) event.stopPropagation();
|
|
236
|
+
if (it.options.preventDefault) event.preventDefault();
|
|
237
|
+
(this as any)[it.propertyKey](event, targetElement);
|
|
238
|
+
};
|
|
239
|
+
targetElement.addEventListener(type, handler, options);
|
|
240
|
+
bound.add(eventKey);
|
|
241
|
+
if (config.autoRemoveEventListeners) this._activeListeners.push({ el: targetElement, type, handler, options });
|
|
242
|
+
const addEventMethods = getLifecycleMetadata(this, ON_ADD_EVENT_LISTENER_METADATA_KEY);
|
|
243
|
+
addEventMethods?.forEach(m => {
|
|
244
|
+
if (typeof (this as any)[m] === 'function') (this as any)[m](targetElement, type, handler);
|
|
245
|
+
});
|
|
246
|
+
}
|
|
175
247
|
}
|
|
176
|
-
|
|
177
|
-
const eventKey = `event:${String(it.propertyKey)}:${eventName}`;
|
|
178
|
-
if (!bound.has(eventKey)) {
|
|
179
|
-
targetElement.addEventListener(
|
|
180
|
-
eventName,
|
|
181
|
-
event => {
|
|
182
|
-
(this as any)[it.propertyKey](event);
|
|
183
|
-
},
|
|
184
|
-
options
|
|
185
|
-
);
|
|
186
|
-
bound.add(eventKey);
|
|
187
|
-
}
|
|
188
|
-
}
|
|
248
|
+
});
|
|
189
249
|
});
|
|
190
250
|
});
|
|
191
251
|
}
|
|
192
252
|
}
|
|
193
253
|
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
254
|
+
private _buildStateMap() {
|
|
255
|
+
this._stateBindings.clear();
|
|
256
|
+
this._externalSources.clear();
|
|
257
|
+
const scan = (root: Node) => {
|
|
258
|
+
const walker = document.createTreeWalker(root, NodeFilter.SHOW_ELEMENT | NodeFilter.SHOW_TEXT);
|
|
259
|
+
let node: Node | null = null;
|
|
260
|
+
while ((node = walker.nextNode())) {
|
|
261
|
+
if (node.nodeType === Node.TEXT_NODE) this._parseAndBind(node, 'text');
|
|
262
|
+
else if (node.nodeType === Node.ELEMENT_NODE) {
|
|
263
|
+
const el = node as HTMLElement;
|
|
264
|
+
const alias = el.getAttribute('as');
|
|
265
|
+
if (alias) {
|
|
266
|
+
this._externalSources.set(alias, el);
|
|
267
|
+
el.addEventListener(STATE_CHANGE_EVENT, () => this._updateState(alias));
|
|
268
|
+
}
|
|
269
|
+
Array.from(el.attributes).forEach(attr => this._parseAndBind(attr, 'attribute', el));
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
};
|
|
273
|
+
if (this.shadowRoot) scan(this.shadowRoot);
|
|
274
|
+
scan(this as any as Node);
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
private _parseAndBind(node: Node | Attr, type: 'text' | 'attribute', owner?: HTMLElement) {
|
|
278
|
+
const content = node.textContent || '';
|
|
279
|
+
const matches = Array.from(content.matchAll(/{{(.*?)}}/g));
|
|
280
|
+
if (matches.length === 0) return;
|
|
281
|
+
matches.forEach(match => {
|
|
282
|
+
const fullPath = match[1].trim();
|
|
283
|
+
const rootName = fullPath.split('.')[0];
|
|
284
|
+
const isState = stateList?.some(s => s.options.name === rootName);
|
|
285
|
+
const isLogicKey = (this as any)._asKey === rootName || (this as any)._asIndexKey === rootName;
|
|
286
|
+
const isExternal = this._externalSources.has(rootName);
|
|
287
|
+
const isSelfAlias = this.getAttribute('as') === rootName;
|
|
288
|
+
if (!isState && !isLogicKey && !isExternal && !isSelfAlias) return;
|
|
289
|
+
if (!this._stateBindings.has(rootName)) this._stateBindings.set(rootName, []);
|
|
290
|
+
const tplKey = `__swc_original_${this._swcId}`;
|
|
291
|
+
if (!(node as any)[tplKey]) (node as any)[tplKey] = content;
|
|
292
|
+
this._stateBindings.get(rootName)!.push({ node, type, owner, path: fullPath });
|
|
293
|
+
this._updateState(rootName);
|
|
199
294
|
});
|
|
295
|
+
}
|
|
200
296
|
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
297
|
+
private _updateState(stateName: string) {
|
|
298
|
+
if (!this._stateBindings) return;
|
|
299
|
+
this._executeBindingUpdate(stateName);
|
|
300
|
+
const selfAlias = this.getAttribute('as');
|
|
301
|
+
if (selfAlias && selfAlias !== stateName) this._executeBindingUpdate(selfAlias);
|
|
302
|
+
this.dispatchEvent(new CustomEvent(STATE_CHANGE_EVENT, { bubbles: true, composed: true }));
|
|
303
|
+
}
|
|
204
304
|
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
305
|
+
private _executeBindingUpdate(stateName: string) {
|
|
306
|
+
const bindings = this._stateBindings.get(stateName);
|
|
307
|
+
if (!bindings) return;
|
|
308
|
+
const tplKey = `__swc_original_${this._swcId}`;
|
|
309
|
+
bindings.forEach(bin => {
|
|
310
|
+
let text = (bin.node as any)[tplKey];
|
|
311
|
+
const matches = Array.from(text.matchAll(/{{(.*?)}}/g));
|
|
312
|
+
for (const match of matches) {
|
|
313
|
+
const path = match[1].trim();
|
|
314
|
+
const root = path.split('.')[0];
|
|
315
|
+
let val: any = undefined;
|
|
316
|
+
let current: HTMLElement | null = this as any as HTMLElement;
|
|
317
|
+
while (current) {
|
|
318
|
+
const currentNewClass = current as any;
|
|
319
|
+
if (current.getAttribute('as') === root) {
|
|
320
|
+
val = SwcUtils.getValueByPath(current, path.split('.').slice(1).join('.') || 'value', 'value');
|
|
321
|
+
if (val !== undefined) break;
|
|
322
|
+
}
|
|
323
|
+
const externalSource = currentNewClass._externalSources?.get(root);
|
|
324
|
+
if (externalSource) {
|
|
325
|
+
val = SwcUtils.getValueByPath(externalSource, path.split('.').slice(1).join('.') || 'value', 'value');
|
|
326
|
+
if (val !== undefined) break;
|
|
327
|
+
}
|
|
328
|
+
const cStates = getStateMetadataList(current.constructor);
|
|
329
|
+
const cAttrs = getAttributeMetadataList(current.constructor);
|
|
330
|
+
const sMeta = cStates?.find(s => s.options.name === root);
|
|
331
|
+
const aMeta = cAttrs?.find(a => a.options.name === root);
|
|
332
|
+
if (sMeta || aMeta) {
|
|
333
|
+
let aPath = path;
|
|
334
|
+
if (sMeta && sMeta.options.name !== String(sMeta.propertyKey)) aPath = path.replace(sMeta.options.name!, String(sMeta.propertyKey));
|
|
335
|
+
else if (aMeta && aMeta.options.name !== String(aMeta.propertyKey)) aPath = path.replace(aMeta.options.name!, String(aMeta.propertyKey));
|
|
336
|
+
val = SwcUtils.getValueByPath(current, aPath, root);
|
|
337
|
+
if (val !== undefined) break;
|
|
338
|
+
}
|
|
339
|
+
current = current.parentElement || (current.getRootNode() as any).host;
|
|
340
|
+
}
|
|
341
|
+
if (val !== undefined) {
|
|
342
|
+
const strVal = val === null || val === undefined ? '' : typeof val === 'object' ? '[Object]' : String(val);
|
|
343
|
+
text = text.replace(match[0], strVal);
|
|
344
|
+
if (bin.type === 'attribute' && bin.owner) {
|
|
345
|
+
if (val === null || val === undefined) bin.owner.removeAttribute(bin.attrName!);
|
|
346
|
+
else bin.owner.setAttribute(bin.attrName!, text);
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
if (bin.type === 'text') bin.node.textContent = text;
|
|
351
|
+
});
|
|
352
|
+
}
|
|
208
353
|
|
|
209
|
-
|
|
210
|
-
const
|
|
211
|
-
|
|
354
|
+
disconnectedCallback() {
|
|
355
|
+
const bMethods = getLifecycleMetadata(this, ON_BEFORE_DISCONNECTED_METADATA_KEY);
|
|
356
|
+
bMethods?.forEach(m => {
|
|
357
|
+
if (typeof (this as any)[m] === 'function') (this as any)[m]();
|
|
358
|
+
});
|
|
359
|
+
if (this._observer) this._observer.disconnect();
|
|
360
|
+
if (config.autoRemoveEventListeners) {
|
|
361
|
+
this._activeListeners.forEach(({ el, type, handler, options }) => el.removeEventListener(type, handler, options));
|
|
362
|
+
this._activeListeners = [];
|
|
363
|
+
}
|
|
364
|
+
if (super.disconnectedCallback) super.disconnectedCallback();
|
|
365
|
+
const aMethods = getLifecycleMetadata(this, ON_AFTER_DISCONNECTED_METADATA_KEY);
|
|
366
|
+
aMethods?.forEach(m => {
|
|
212
367
|
if (typeof (this as any)[m] === 'function') (this as any)[m]();
|
|
213
368
|
});
|
|
214
369
|
}
|
|
215
370
|
|
|
216
371
|
adoptedCallback() {
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
beforeMethods?.forEach(m => {
|
|
372
|
+
const bMethods = getLifecycleMetadata(this, ON_BEFORE_ADOPTED_METADATA_KEY);
|
|
373
|
+
bMethods?.forEach(m => {
|
|
220
374
|
if (typeof (this as any)[m] === 'function') (this as any)[m]();
|
|
221
375
|
});
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
}
|
|
226
|
-
|
|
227
|
-
// 2. onAfterAdopted
|
|
228
|
-
const afterMethods = getLifecycleMetadata(this, ON_AFTER_ADOPTED_METADATA_KEY);
|
|
229
|
-
afterMethods?.forEach(m => {
|
|
376
|
+
if (super.adoptedCallback) super.adoptedCallback();
|
|
377
|
+
const aMethods = getLifecycleMetadata(this, ON_AFTER_ADOPTED_METADATA_KEY);
|
|
378
|
+
aMethods?.forEach(m => {
|
|
230
379
|
if (typeof (this as any)[m] === 'function') (this as any)[m]();
|
|
231
380
|
});
|
|
232
381
|
}
|
|
233
382
|
|
|
234
383
|
async connectedCallback() {
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
beforeMethods?.forEach(m => {
|
|
384
|
+
const bMethods = getLifecycleMetadata(this, ON_BEFORE_CONNECTED_METADATA_KEY);
|
|
385
|
+
bMethods?.forEach(m => {
|
|
238
386
|
if (typeof (this as any)[m] === 'function') (this as any)[m]();
|
|
239
387
|
});
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
let shadowContent = '';
|
|
248
|
-
let lightContent = '';
|
|
249
|
-
|
|
250
|
-
if (innerHtmlList) {
|
|
251
|
-
for (const meta of innerHtmlList) {
|
|
388
|
+
if (typeof (this as any).initCore === 'function') (this as any).initCore();
|
|
389
|
+
const iHtmlList = getInnerHtmlMetadataList(this);
|
|
390
|
+
let sContent = '';
|
|
391
|
+
let lContent = '';
|
|
392
|
+
if (iHtmlList) {
|
|
393
|
+
for (const meta of iHtmlList) {
|
|
252
394
|
const result = await (this as any)[meta.propertyKey]();
|
|
253
395
|
if (result !== undefined) {
|
|
254
|
-
if (meta.options.useShadow === true)
|
|
255
|
-
|
|
256
|
-
} else {
|
|
257
|
-
lightContent += result;
|
|
258
|
-
}
|
|
396
|
+
if (meta.options.useShadow === true) sContent += result;
|
|
397
|
+
else lContent += result;
|
|
259
398
|
}
|
|
260
399
|
}
|
|
261
400
|
}
|
|
262
|
-
|
|
263
|
-
if (this.
|
|
264
|
-
this.shadowRoot.innerHTML = shadowContent;
|
|
265
|
-
}
|
|
266
|
-
|
|
267
|
-
if (lightContent) {
|
|
268
|
-
this.innerHTML = lightContent;
|
|
269
|
-
}
|
|
270
|
-
|
|
271
|
-
// 초기 동기화
|
|
401
|
+
if (this.shadowRoot) this.shadowRoot.innerHTML = sContent;
|
|
402
|
+
if (lContent) this.innerHTML = lContent;
|
|
272
403
|
(this as any)._syncDecorators();
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
const target = this.shadowRoot || this;
|
|
279
|
-
this._observer.observe(target, { childList: true, subtree: true });
|
|
280
|
-
|
|
281
|
-
if (super.connectedCallback) {
|
|
282
|
-
await super.connectedCallback();
|
|
283
|
-
}
|
|
284
|
-
|
|
285
|
-
// 2. onAfterConnected
|
|
286
|
-
const afterMethods = getLifecycleMetadata(this, ON_AFTER_CONNECTED_METADATA_KEY);
|
|
287
|
-
afterMethods?.forEach(m => {
|
|
404
|
+
this._observer = new MutationObserver(() => (this as any)._syncDecorators());
|
|
405
|
+
this._observer.observe(this.shadowRoot || this, { childList: true, subtree: true });
|
|
406
|
+
if (super.connectedCallback) await super.connectedCallback();
|
|
407
|
+
const aMethods = getLifecycleMetadata(this, ON_AFTER_CONNECTED_METADATA_KEY);
|
|
408
|
+
aMethods?.forEach(m => {
|
|
288
409
|
if (typeof (this as any)[m] === 'function') (this as any)[m]();
|
|
289
410
|
});
|
|
290
411
|
}
|
|
291
412
|
|
|
292
|
-
// 4. Handle attribute changes and route to decorated methods
|
|
293
413
|
attributeChangedCallback(name: string, oldValue: string | null, newValue: string | null) {
|
|
294
|
-
if (super.attributeChangedCallback)
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
if (methodKeys && Array.isArray(methodKeys)) {
|
|
300
|
-
methodKeys.forEach(key => {
|
|
301
|
-
if (typeof (this as any)[key] === 'function') {
|
|
302
|
-
(this as any)[key](newValue, oldValue, name);
|
|
414
|
+
if (super.attributeChangedCallback) super.attributeChangedCallback(name, oldValue, newValue);
|
|
415
|
+
if (attributePropsList) {
|
|
416
|
+
attributePropsList.forEach(meta => {
|
|
417
|
+
if (meta.options.name === name) {
|
|
418
|
+
if (String((this as any)[meta.propertyKey]) !== String(newValue)) (this as any)[meta.propertyKey] = newValue;
|
|
303
419
|
}
|
|
304
420
|
});
|
|
305
421
|
}
|
|
306
|
-
|
|
307
|
-
const
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
}
|
|
422
|
+
if (typeof (this as any)._updateState === 'function') (this as any)._updateState(name);
|
|
423
|
+
const aMethodsMap = getLifecycleMetadata(constructor, ON_ATTRIBUTE_CHANGED_METADATA_KEY) as Map<string, (string | symbol)[]>;
|
|
424
|
+
const mKeys = aMethodsMap?.get(name);
|
|
425
|
+
if (mKeys && Array.isArray(mKeys))
|
|
426
|
+
mKeys.forEach(key => {
|
|
427
|
+
if (typeof (this as any)[key] === 'function') (this as any)[key](newValue, oldValue, name);
|
|
313
428
|
});
|
|
429
|
+
if (emitCustomEventList) {
|
|
430
|
+
const eMeta = emitCustomEventList.find(it => it.options.attributeName === name);
|
|
431
|
+
if (eMeta) {
|
|
432
|
+
const eType = eMeta.options.type;
|
|
433
|
+
const oHandler = this._emitHandlers.get(eType);
|
|
434
|
+
if (oHandler) this.removeEventListener(eType, oHandler);
|
|
435
|
+
if (newValue) {
|
|
436
|
+
const nHandler = (e: Event) => {
|
|
437
|
+
new Function('event', '$data', newValue).call(this, e, (e as CustomEvent).detail);
|
|
438
|
+
};
|
|
439
|
+
this.addEventListener(eType, nHandler);
|
|
440
|
+
this._emitHandlers.set(eType, nHandler);
|
|
441
|
+
}
|
|
442
|
+
}
|
|
314
443
|
}
|
|
444
|
+
const wMethodsKeys = aMethodsMap?.get(ATTRIBUTE_CHANGED_WILDCARD);
|
|
445
|
+
if (wMethodsKeys && Array.isArray(wMethodsKeys))
|
|
446
|
+
wMethodsKeys.forEach(key => {
|
|
447
|
+
if (typeof (this as any)[key] === 'function') (this as any)[key](newValue, oldValue, name);
|
|
448
|
+
});
|
|
315
449
|
}
|
|
316
450
|
};
|
|
317
451
|
|
|
318
|
-
// 5. Register Custom Element using specified or default registry
|
|
319
452
|
const registry = config.customElementRegistry || (typeof customElements !== 'undefined' ? customElements : undefined);
|
|
320
453
|
if (registry && !registry.get(config.name)) {
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
// Safari support check for Customized Built-in Elements
|
|
324
|
-
if (extendsTagName && typeof document !== 'undefined') {
|
|
325
|
-
const isSupported = document.createElement(extendsTagName, { is: 'any' }).outerHTML.indexOf('is=') !== -1;
|
|
326
|
-
if (!isSupported) {
|
|
327
|
-
console.warn(`[SWC] Browser does not support 'is' attribute (Customized Built-in Elements). ` + `If you are on Safari, please include '@ungap/custom-elements' polyfill.`);
|
|
328
|
-
}
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
registry.define(config.name, NewClass as any, options);
|
|
454
|
+
registry.define(config.name, NewClass as any, config.extends ? { extends: config.extends } : undefined);
|
|
332
455
|
}
|
|
333
|
-
|
|
334
|
-
// 6. Save metadata
|
|
335
456
|
ReflectUtils.defineMetadata(ELEMENT_CONFIG_KEY, config, NewClass);
|
|
336
|
-
|
|
337
457
|
return NewClass as any;
|
|
338
458
|
};
|
|
339
459
|
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { ReflectUtils } from '@dooboostore/core/reflect/ReflectUtils';
|
|
2
|
+
|
|
3
|
+
export interface EmitCustomEventOptions {
|
|
4
|
+
type: string;
|
|
5
|
+
attributeName?: string; // Default: on + type
|
|
6
|
+
bubbles?: boolean; // Default: true
|
|
7
|
+
composed?: boolean; // Default: true
|
|
8
|
+
cancelable?: boolean;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export interface EmitCustomEventMetadata {
|
|
12
|
+
propertyKey: string | symbol;
|
|
13
|
+
options: EmitCustomEventOptions;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export const EMIT_CUSTOM_EVENT_METADATA_KEY = Symbol('simple-web-component:emit-custom-event');
|
|
17
|
+
|
|
18
|
+
export function emitCustomEvent(typeOrOptions: string | EmitCustomEventOptions): MethodDecorator {
|
|
19
|
+
return (target: Object, propertyKey: string | symbol, descriptor: PropertyDescriptor) => {
|
|
20
|
+
const constructor = target.constructor;
|
|
21
|
+
const options: EmitCustomEventOptions = typeof typeOrOptions === 'string' ? { type: typeOrOptions } : typeOrOptions;
|
|
22
|
+
|
|
23
|
+
if (!options.attributeName) {
|
|
24
|
+
options.attributeName = `on${options.type}`;
|
|
25
|
+
}
|
|
26
|
+
if (options.bubbles === undefined) options.bubbles = true;
|
|
27
|
+
if (options.composed === undefined) options.composed = true;
|
|
28
|
+
|
|
29
|
+
let list = ReflectUtils.getMetadata<EmitCustomEventMetadata[]>(EMIT_CUSTOM_EVENT_METADATA_KEY, constructor);
|
|
30
|
+
if (!list) {
|
|
31
|
+
list = [];
|
|
32
|
+
ReflectUtils.defineMetadata(EMIT_CUSTOM_EVENT_METADATA_KEY, list, constructor);
|
|
33
|
+
}
|
|
34
|
+
list.push({ propertyKey, options });
|
|
35
|
+
|
|
36
|
+
// Wrap the original method to dispatch event after execution
|
|
37
|
+
const originalMethod = descriptor.value;
|
|
38
|
+
descriptor.value = function (this: HTMLElement, ...args: any[]) {
|
|
39
|
+
const detail = originalMethod.apply(this, args);
|
|
40
|
+
|
|
41
|
+
const event = new CustomEvent(options.type, {
|
|
42
|
+
detail,
|
|
43
|
+
bubbles: options.bubbles,
|
|
44
|
+
composed: options.composed,
|
|
45
|
+
cancelable: options.cancelable
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
this.dispatchEvent(event);
|
|
49
|
+
return detail;
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export const getEmitCustomEventMetadataList = (target: any): EmitCustomEventMetadata[] | undefined => {
|
|
55
|
+
const constructor = target instanceof Function ? target : target.constructor;
|
|
56
|
+
return ReflectUtils.getMetadata(EMIT_CUSTOM_EVENT_METADATA_KEY, constructor);
|
|
57
|
+
};
|