Start adding components
This commit is contained in:
parent
ecc213306c
commit
2482a32f8e
|
@ -4,7 +4,7 @@
|
|||
<meta charset="UTF-8" />
|
||||
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<title>Vite + TS</title>
|
||||
<title>Glimmer</title>
|
||||
</head>
|
||||
<body>
|
||||
<div id="app"></div>
|
||||
|
|
|
@ -0,0 +1,9 @@
|
|||
export class DataCard extends HTMLElement {
|
||||
constructor() {
|
||||
super();
|
||||
}
|
||||
|
||||
connectedCallback() {
|
||||
this.classList.add("card");
|
||||
}
|
||||
}
|
|
@ -0,0 +1,43 @@
|
|||
export class TextField extends HTMLElement {
|
||||
field: HTMLInputElement;
|
||||
|
||||
static get observedAttributes() {
|
||||
return ["placeholder", "text"];
|
||||
}
|
||||
|
||||
constructor() {
|
||||
super();
|
||||
|
||||
this.field = document.createElement("input");
|
||||
}
|
||||
|
||||
get placeholder(): string | null {
|
||||
return this.getAttribute("placeholder");
|
||||
}
|
||||
|
||||
set placeholder(text: string | null) {
|
||||
if (text) {
|
||||
this.setAttribute("placeholder", text);
|
||||
} else {
|
||||
this.removeAttribute("placeholder");
|
||||
}
|
||||
this.field.placeholder = text || "";
|
||||
}
|
||||
|
||||
get text(): string | null {
|
||||
return this.getAttribute("text");
|
||||
}
|
||||
|
||||
set text(text: string | null) {
|
||||
if (text) {
|
||||
this.setAttribute("text", text);
|
||||
} else {
|
||||
this.removeAttribute("text");
|
||||
}
|
||||
this.field.placeholder = text || "";
|
||||
}
|
||||
|
||||
connectedCallback() {
|
||||
this.appendChild(this.field);
|
||||
}
|
||||
}
|
|
@ -1,9 +0,0 @@
|
|||
export function setupCounter(element: HTMLButtonElement) {
|
||||
let counter = 0
|
||||
const setCounter = (count: number) => {
|
||||
counter = count
|
||||
element.innerHTML = `count is ${counter}`
|
||||
}
|
||||
element.addEventListener('click', () => setCounter(counter + 1))
|
||||
setCounter(0)
|
||||
}
|
|
@ -0,0 +1,18 @@
|
|||
import { DataCard } from "./components/DataCard";
|
||||
import { TextField } from "./components/TextField";
|
||||
|
||||
declare global {
|
||||
interface HTMLElementTagNameMap {
|
||||
"data-card": DataCard;
|
||||
"text-field": TextField;
|
||||
}
|
||||
}
|
||||
|
||||
console.log("components initialized");
|
||||
|
||||
const init = () => {
|
||||
window.customElements.define("data-card", DataCard);
|
||||
window.customElements.define("text-field", TextField);
|
||||
};
|
||||
|
||||
export { init, DataCard, TextField };
|
|
@ -1,8 +1,10 @@
|
|||
import "./style.css";
|
||||
import typescriptLogo from "./typescript.svg";
|
||||
import { setupCounter } from "./counter";
|
||||
|
||||
import * as glimmer from "./index";
|
||||
import { DataCard, TextField } from "./index";
|
||||
|
||||
document.querySelector<HTMLDivElement>("#app")!.innerHTML = `
|
||||
<h1> Color Swatches </h1>
|
||||
<div class="colorset">
|
||||
<div class="swatch swatch-grey-900"></div>
|
||||
<div class="swatch swatch-grey-800"></div>
|
||||
|
@ -51,6 +53,8 @@ document.querySelector<HTMLDivElement>("#app")!.innerHTML = `
|
|||
<div class="swatch swatch-red-100"></div>
|
||||
</div>
|
||||
|
||||
<h1> Cards and Shadows </h1>
|
||||
|
||||
<div class="flex">
|
||||
<div class="card card--recessed">
|
||||
</div>
|
||||
|
@ -64,6 +68,23 @@ document.querySelector<HTMLDivElement>("#app")!.innerHTML = `
|
|||
<div class="card card--high">
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<h1> Components </h1>
|
||||
|
||||
<div id="components"></div>
|
||||
`;
|
||||
|
||||
setupCounter(document.querySelector<HTMLButtonElement>("#counter")!);
|
||||
glimmer.init();
|
||||
|
||||
const components = document.querySelector("#components");
|
||||
|
||||
if (components) {
|
||||
const card: DataCard = document.createElement("data-card");
|
||||
card.classList.add("card--high");
|
||||
components.appendChild(card);
|
||||
|
||||
const textField: TextField = document.createElement("text-field");
|
||||
textField.placeholder = "Placeholder text";
|
||||
textField.text = "Blank Text";
|
||||
components.appendChild(textField);
|
||||
}
|
||||
|
|
|
@ -1 +0,0 @@
|
|||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="32" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 256"><path fill="#007ACC" d="M0 128v128h256V0H0z"></path><path fill="#FFF" d="m56.612 128.85l-.081 10.483h33.32v94.68h23.568v-94.68h33.321v-10.28c0-5.69-.122-10.444-.284-10.566c-.122-.162-20.4-.244-44.983-.203l-44.74.122l-.121 10.443Zm149.955-10.742c6.501 1.625 11.459 4.51 16.01 9.224c2.357 2.52 5.851 7.111 6.136 8.208c.08.325-11.053 7.802-17.798 11.988c-.244.162-1.22-.894-2.317-2.52c-3.291-4.795-6.745-6.867-12.028-7.233c-7.76-.528-12.759 3.535-12.718 10.321c0 1.992.284 3.17 1.097 4.795c1.707 3.536 4.876 5.649 14.832 9.956c18.326 7.883 26.168 13.084 31.045 20.48c5.445 8.249 6.664 21.415 2.966 31.208c-4.063 10.646-14.14 17.879-28.323 20.276c-4.388.772-14.79.65-19.504-.203c-10.28-1.828-20.033-6.908-26.047-13.572c-2.357-2.6-6.949-9.387-6.664-9.874c.122-.163 1.178-.813 2.356-1.504c1.138-.65 5.446-3.129 9.509-5.485l7.355-4.267l1.544 2.276c2.154 3.29 6.867 7.801 9.712 9.305c8.167 4.307 19.383 3.698 24.909-1.26c2.357-2.153 3.332-4.388 3.332-7.68c0-2.966-.366-4.266-1.91-6.501c-1.99-2.845-6.054-5.242-17.595-10.24c-13.206-5.69-18.895-9.224-24.096-14.832c-3.007-3.25-5.852-8.452-7.03-12.8c-.975-3.617-1.22-12.678-.447-16.335c2.723-12.76 12.353-21.659 26.25-24.3c4.51-.853 14.994-.528 19.424.569Z"></path></svg>
|
Before Width: | Height: | Size: 1.4 KiB |
Loading…
Reference in New Issue