Start adding components

This commit is contained in:
Savanni D'Gerinel 2023-03-14 00:34:39 -04:00
parent ecc213306c
commit 2482a32f8e
7 changed files with 95 additions and 14 deletions

View File

@ -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>

View File

@ -0,0 +1,9 @@
export class DataCard extends HTMLElement {
constructor() {
super();
}
connectedCallback() {
this.classList.add("card");
}
}

View File

@ -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);
}
}

View File

@ -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)
}

18
glimmer/web/src/index.ts Normal file
View File

@ -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 };

View File

@ -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);
}

View File

@ -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