Initial Commit
This commit is contained in:
parent
a8f6e3a14f
commit
dc48c259e3
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
.DS_Store
|
||||||
|
node_modules/*
|
41
README.md
41
README.md
@ -1,2 +1,39 @@
|
|||||||
# wc-upgrader
|
# WC-Upgrader
|
||||||
A JS Module to track HTML elements and change them to custom web components when they are registered.
|
|
||||||
|
WC-Upgrader is a JS Utility that 'upgrades' elements to the specified custom element when they are defined.
|
||||||
|
|
||||||
|

|
||||||
|
1. **Basic Header:** This is just an h1 element
|
||||||
|
2. **Flash Header:** This is using the custom element directly. There is just a text node until the custom element is defined so it renders with no styles or semantic meaning.
|
||||||
|
3. **Basic Header Upgraded (Delay):** This is an h1 element that gets upgraded to the custom element when it is defined in the browser. In the demo there is a setTimeout to demonstrate how it is less disruptive to upgrade an element rather than have a text node to start.
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
```
|
||||||
|
npm install wc-upgrader
|
||||||
|
```
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
import wcUpgrader from 'node_modules/wc-upgrader/wc-upgrader.mjs'
|
||||||
|
|
||||||
|
const Upgrader = new wcUpgrader();
|
||||||
|
|
||||||
|
Upgrader.upgradeOnDefined('custom-element', 'CSSSelector');
|
||||||
|
```
|
||||||
|
*Technically speaking, this just makes a new element and moves the children from the old tree under it. You could use this to change an arbitrary element into another one and retain it's children.
|
||||||
|
|
||||||
|
\**The custom element does not need to be defined immediately but it will need to be at some point or there will just be a hanging async task
|
||||||
|
|
||||||
|
## Demo
|
||||||
|
To try the demo file yourself do the following steps.
|
||||||
|
1. Clone the Repo
|
||||||
|
2. Run ```npm install``` to get the sample web component *Flashy-Header*
|
||||||
|
3. Use something like [Live Server](https://marketplace.visualstudio.com/items?itemName=ritwickdey.LiveServer) to view demo.html (wc-upgrader is a module so you'll get a CORS error if you don't)
|
||||||
|
|
||||||
|
## Contributing
|
||||||
|
Feedback and pull requests are welcome! Please open issues so we can discuss any feature ideas or bugs found.
|
||||||
|
|
||||||
|
## License
|
||||||
|
[MIT](https://choosealicense.com/licenses/mit/)
|
23
demo.html
Normal file
23
demo.html
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>Test Upgrader</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<h1>Basic Header</h1>
|
||||||
|
<flashy-header>Flashy Header</flashy-header>
|
||||||
|
<h1 id="upgrade">Basic Header Upgrdaed (Delay)</h1>
|
||||||
|
</body>
|
||||||
|
|
||||||
|
<script src="node_modules/flashy-header/flashy-header.js"></script>
|
||||||
|
|
||||||
|
<script type="module">
|
||||||
|
import wcUpgrader from './wc-upgrader.mjs'
|
||||||
|
|
||||||
|
const Upgrader = new wcUpgrader();
|
||||||
|
|
||||||
|
setTimeout(() => {
|
||||||
|
Upgrader.upgradeOnDefined('flashy-header', '#upgrade');
|
||||||
|
}, 1500);
|
||||||
|
</script>
|
||||||
|
</html>
|
BIN
example.gif
Normal file
BIN
example.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 910 KiB |
14
package-lock.json
generated
Normal file
14
package-lock.json
generated
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
{
|
||||||
|
"name": "wc-upgrader",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"lockfileVersion": 1,
|
||||||
|
"requires": true,
|
||||||
|
"dependencies": {
|
||||||
|
"flashy-header": {
|
||||||
|
"version": "1.0.0",
|
||||||
|
"resolved": "https://registry.npmjs.org/flashy-header/-/flashy-header-1.0.0.tgz",
|
||||||
|
"integrity": "sha512-0CdMzfpc7xUAbXu+yh97uaQCQ9sGp88YZPbqVqYRdCFwJs5eijPlRUBq1G3KI/WFg8xNl+PguSXzQ1Vp4A1SiQ==",
|
||||||
|
"dev": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
33
package.json
Normal file
33
package.json
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
{
|
||||||
|
"name": "wc-upgrader",
|
||||||
|
"version": "1.0.0",
|
||||||
|
"description": "WC-Upgrader is a JS Utility that 'upgrades' elements to the specified custom element when they are defined. ",
|
||||||
|
"main": "wc-upgrader.js",
|
||||||
|
"scripts": {
|
||||||
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
|
},
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/CalebBraaten/wc-upgrader.git"
|
||||||
|
},
|
||||||
|
"keywords": [
|
||||||
|
"Web",
|
||||||
|
"Components",
|
||||||
|
"Custom",
|
||||||
|
"Elements",
|
||||||
|
"Client",
|
||||||
|
"Side",
|
||||||
|
"Vanilla",
|
||||||
|
"JS"
|
||||||
|
],
|
||||||
|
"author": "Caleb Braaten",
|
||||||
|
"license": "MIT",
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/CalebBraaten/wc-upgrader/issues"
|
||||||
|
},
|
||||||
|
"homepage": "https://github.com/CalebBraaten/wc-upgrader#readme",
|
||||||
|
"dependencies": {},
|
||||||
|
"devDependencies": {
|
||||||
|
"flashy-header": "^1.0.0"
|
||||||
|
}
|
||||||
|
}
|
35
wc-upgrader.mjs
Normal file
35
wc-upgrader.mjs
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
class wcUpgrader {
|
||||||
|
upgradeOnDefined(elemDef, target){
|
||||||
|
customElements.whenDefined(elemDef)
|
||||||
|
.then( () => {
|
||||||
|
let oldElements = document.querySelectorAll(target);
|
||||||
|
for(let i = 0; i < oldElements.length; i++){
|
||||||
|
this._appendToDOM(elemDef, oldElements[i])
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
_appendToDOM(elemDef, targetElement){
|
||||||
|
// Works but elements are added to the DOM multiple times if nested
|
||||||
|
// within other elements that get upgraded - constructors are ran each time
|
||||||
|
// let newElem = document.createElement(elemDef);
|
||||||
|
// newElem.innerHTML = targetElem.innerHTML;
|
||||||
|
// targetElem.parentNode.replaceChild(newElem, targetElem);
|
||||||
|
|
||||||
|
let newElement = document.createElement(elemDef);
|
||||||
|
const parentNode = targetElement.parentNode;
|
||||||
|
|
||||||
|
for(let i=0; i < parentNode.childNodes.length; i++){
|
||||||
|
if(targetElement.isSameNode(parentNode.childNodes[i])){
|
||||||
|
parentNode.insertBefore(newElement, parentNode.childNodes[i]);
|
||||||
|
while(targetElement.firstChild){
|
||||||
|
newElement.appendChild(targetElement.firstChild);
|
||||||
|
}
|
||||||
|
targetElement.parentNode.removeChild(targetElement);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default wcUpgrader;
|
Loading…
Reference in New Issue
Block a user