/webcomponents

Universal popup library

Primary LanguageSvelte

Quickstart

index.html

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <style>
      body {
        background: black;
      }
    </style>
    <!-- <script src="bundle.js"></script> -->
  </head>

  <body style="background: black; color: white; display: flex; align-items: center; flex-direction: column">
    <h1>Set number</h1>
    <p></p>
    <button id="alert">alert</button>
    <button id="prompt">prompt</button>
    <button id="prompttime">prompt time</button>
    <button id="adopt">adopt</button>
    <button id="promptnumber">prompt number</button>
    <button id="promptregex">prompt mail</button>
    <button id="confirm">confirm</button>
    <button id="choose">Choose Language</button>
    <button id="contact">Contact</button>

    <script type="module" src="example.js"></script>
  </body>
</html>

example.js

import { TangleMsgBox } from "./dialog-component.js";

// You can edit styles with calling .setStyles function
// TangleMsgBox.setStyles(`
// :root {
//   --body-bg:#C3B9D2;
// }
// .tangle-msg-box-dialog-header {
//   // color:red !important
// }
// .tangle-msg-box-dialog {
//   background: #C3B9D2 !important;
// }
// .tangle-msg-box-dialog-button:last-of-type {
//       background: #451CEC !important;
//     color: white !important;

// }
//  .tangle-msg-box-dialog-button:last-of-type:hover {
//     background: #451CEC !important;

//  }
//  .tangle-msg-box-dialog-header {
//        color: #451CEC !important;
//  }
//  .tangle-msg-box-dialog-textbox {
//   color: #451CEC !important;
//   background:white;
//   outline:none;
//  }
// `);

console.log(TangleMsgBox);

document.getElementById("alert").onclick = async () => {
  // TangleMsgBox.* se může zavolat kdekoliv v kódu, jen bacha na to že je asynchronní (takže vraci promise)
  await TangleMsgBox.alert("Tlačítko zčervená, koukej", "Pozoor");
  document.getElementById("alert").style.color = "red";
};

document.getElementById("confirm").onclick = async () => {
  const ano = await TangleMsgBox.confirm("Opravdu chcete uvést aplikaci do továrního nastavení? Tímto krokem odstraníte všechna uložená data.", "Tovární nastavení aplikace");
  if (ano) {
    document.body.style.background = "aqua";
  }
};

document.getElementById("adopt").onclick = async () => {
  const ano = await TangleMsgBox.confirm("Zkuste to, prosím, později.", "Přidání se nezdařilo", { confirm: "Zkusit znovu", secondary: "Zpět" });
  if (ano) {
    document.body.style.background = "aqua";
  }
};

document.getElementById("prompt").onclick = async () => {
  const jmeno = await TangleMsgBox.prompt("Jestli nechceš být debil tak se přejmenuj", "debil", "Tvoje úžasné jméno", "text");
  TangleMsgBox.alert(`Nazdárek ${jmeno}`);
};

document.getElementById("prompttime").onclick = async () => {
  const jmeno = await TangleMsgBox.prompt("Zadej čas:", "", "Prej chceš vypnout NARU", "time");
};

document.getElementById("promptnumber").onclick = async () => {
  const cislo = await TangleMsgBox.prompt("Kolik máš diod", 141, "Led pásek", "number", { min: 0, max: 300 });
  TangleMsgBox.alert(`Tolik jo wow: ${cislo} ${typeof cislo}`);
};

document.getElementById("promptregex").onclick = async () => {
  const mail = await TangleMsgBox.prompt("Tvuj mail ?", "", "Potřebuji o tebe něco vědět", "text", { placeholder: "lkov@post.cz", regex: /[^@ \t\r\n]+@[^@ \t\r\n]+\.[^@ \t\r\n]+/ });
  TangleMsgBox.alert(`Email: ${mail} ${typeof mail}`);
};

document.getElementById("choose").onclick = async () => {
  const vybrano = await TangleMsgBox.choose(
    "",
    {
      defaultValue: "cs",
      options: [
        {
          label: "Čeština",
          value: "cs",
          icon: "url('')",
        },
        {
          label: "English",
          value: "en",
          icon: "url('')",
        },
      ],
    },
    "Jazyk / Language",
    { confirm: "Uložit", secondary: "null", cancel: "null" },
  );
  TangleMsgBox.alert(`Vybral jsi: ${vybrano}`);
};

const telIcon =
  "url('')";

document.getElementById("contact").onclick = async () => {
  const vybrano = await TangleMsgBox.choose(
    "",
    {
      defaultValue: "",
      options: [
        { label: "Technická podpora", value: "techtel", icon: telIcon },
        { label: "Obchodní konzultant", value: "obchtel", icon: telIcon },
      ],
    },
    "Jazyk / Language",
    { confirm: "null", secondary: "null", cancel: "null" },
  );

  switch (vybrano) {
    case "techtel":
      window.open("tel:+420606060606");
    case "obchtel":
      window.open("tel:+420880880880");
  }
};

Iframe version

  • Some webapps have problems with handling event globally, if you have this issue use iframe branch version.