dt-app
Version:
The Dynatrace App Toolkit is a tool you can use from your command line to create, develop, and deploy apps on your Dynatrace environment.
147 lines (139 loc) • 20.9 kB
JavaScript
;(()=>{"serviceWorker"in navigator?navigator.serviceWorker.register("dev-sw.js").then(t=>{t.update(),console.log("Live reload connected")}).catch(t=>{console.log(`Failed to register service worker. Live reloading will not be available. Please adapt your browser security settings in order to have live reloading available.
${t}`)}):console.log("Service workers and thus live reloading not available. Please use a browser (version) that supports service workers and make sure your connection is secure.");var r=new WebSocket(window.socketUrl),i=document.createElement("div"),d=document.createElement("div");i.classList.add("dt-app-indicator");d.classList.add("dt-app-spinner-icon");i.appendChild(d);var s=!1;r.addEventListener("open",()=>{document.body.appendChild(i),l()});r.addEventListener("error",t=>{console.error(t)});r.addEventListener("close",()=>{console.info(`The development server has disconnected.
Refresh the page if necessary.`)});r.addEventListener("message",t=>{try{let{message:e,type:n}=JSON.parse(t.data);switch(s&&f(),n){case"reload":{console.log("reloading browser..."),l(),window.location.reload();break}case"error":{let o=JSON.parse(e);o.length!==0&&(console.error("compile error occurred...",o),c(o));break}default:{e&&console.log(e);break}}}catch(e){console.error("Error while receiving message from websocket"),console.error(e)}});function c(t){if(t.length===0)return;let e=document.createElement("div"),n=h("dt-app-lightbox-error");t.forEach(o=>{o.text&&e.append(a(`<div class="dt-app-error-text">${o.text}</div>`)),o.location?.file&&e.append(a(`<div class="dt-app-error-info">Error in file: ${o.location.file}</div>`)),o.prettyError?e.append(a(o.prettyError)):e.append(o.toString())}),n.getElementsByClassName("dt-app-lightbox-content")[0].appendChild(e),document.body.appendChild(n),s=!0}function f(){document.querySelectorAll(".dt-app-lightbox-error").forEach(t=>t.remove()),s=!1}function a(t){let e=document.createElement("div");return e.innerHTML=t,e}function h(t){let e=document.createElement("div"),n=document.createElement("div"),o=document.createElement("div");return t&&e.classList.add(t),e.classList.add("dt-app-lightbox-container"),n.classList.add("dt-app-lightbox"),o.classList.add("dt-app-lightbox-content"),n.appendChild(o),e.appendChild(n),e}function l(){i.classList.add("is-visible"),window.setTimeout(()=>{g()},1e3)}function g(){i.classList.remove("is-visible")}var p=document.createElement("style");document.head.appendChild(p);p.innerHTML=`
.dt-app-codesnippet > span > b {
margin-left: -9px; /* fixes line offset from ansi conversion */
display: block;
background-color: #590513;
}
.dt-app-error-text{
font-size: '1.266rem';
color: #c20b29;
margin-bottom: 16px;
font-family: 500;
}
.dt-app-warning-text {
font-size: '1.266rem';
color: #c20b29;
font-family: 500;
margin-right: 16px;
text-align: justify;
}
.dt-app-error-info{
margin-bottom: 8px;
}
.dt-app-codesnippet{
white-space: pre;
font-family: Consolas,Monaco,'Ubuntu Mono',monospace;
display: flex;
flex-direction: column;
padding: 16px;
overflow-x: auto;
}
.dt-app-lightbox-container{
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 10001;
font-family: Roboto,Helvetica,sans-serif;
display: flex;
justify-content: center;
align-items: center;
}
.dt-app-lightbox-container:after{
content: '';
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
background-color: #6d7488;
opacity: 0.8;
z-index: -1;
}
.dt-app-lightbox{
display: flex;
overflow-y: auto;
max-width: 100%;
width: 1150px;
padding: 16px;
background-color: #fafbfb;
max-height: calc(100vh - 50px)
}
.dt-app-lightbox-content{
width: 100%;
height: 100%;
}
.dt-app-close-button {
cursor: pointer;
height: 20px;
width: 20px;
display: flex;
font-size: 20px;
justify-content: center;
align-items: center;
}
.dt-app-indicator {
position: fixed;
background-color: #fafbfbs;
width: 40px;
height: 40px;
bottom: 50px;
right: 50px;
border-radius: 10px;
box-shadow: 1px 1px 5px rgba(0,0,0,0.4);
display: none;
}
.dt-app-indicator.is-visible {
display: block;
animation: dt-app-slide-in 0.4s ease-out 0s forwards alternate;
}
.dt-app-spinner-icon {
--dt-app-spinner-color: #21242A;
display: flex;
width: 100%;
height: 100%;
align-items: center;
justify-content: center;
}
.dt-app-spinner-icon:after {
content: " ";
display: block;
width: 50%;
height: 50%;
border-radius: 9999px;
border: 2px solid var(--dt-app-spinner-color);
border-color: var(--dt-app-spinner-color) transparent var(--dt-app-spinner-color) transparent;
animation: dt-app-rotate 1.2s linear infinite;
}
@keyframes dt-app-rotate {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
@keyframes dt-app-slide-in {
0% {
transform: translate3d(60%, 0, 0);
opacity: 0;
}
40% { opacity: 1; }
100% { transform: translate3d(0, 0, 0); }
}
`;})();
/**
* @license
* Copyright 2024 Dynatrace LLC
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/dev/client.ts"],
  "sourcesContent": ["// cSpell:ignore IIFE fafbfbs\n/**\n * @license\n * Copyright 2024 Dynatrace LLC\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n// Client side code, runs in the browser\ndeclare const window: Window & { socketUrl: string };\n\nif ('serviceWorker' in navigator) {\n  navigator.serviceWorker\n    .register('dev-sw.js')\n    .then((serviceWorkerRegistration) => {\n      serviceWorkerRegistration.update();\n      console.log('Live reload connected');\n    })\n    .catch((err) => {\n      console.log(\n        `Failed to register service worker. Live reloading will not be available. Please adapt your browser security settings in order to have live reloading available. \\n\n        ${err}`,\n      );\n    });\n} else {\n  console.log(\n    'Service workers and thus live reloading not available. Please use a browser (version) that supports service workers and make sure your connection is secure.',\n  );\n}\n\n/** Live reload script that will be injected as IIFE in the client for development */\nconst socket = new WebSocket(window.socketUrl);\nconst spinner = document.createElement('div');\nconst spinnerIcon = document.createElement('div');\nspinner.classList.add('dt-app-indicator');\nspinnerIcon.classList.add('dt-app-spinner-icon');\nspinner.appendChild(spinnerIcon);\n\nlet errorShown = false;\n\nsocket.addEventListener('open', () => {\n  document.body.appendChild(spinner);\n  showSpinner();\n});\n\nsocket.addEventListener('error', (error) => {\n  console.error(error);\n});\n\nsocket.addEventListener('close', () => {\n  console.info(\n    'The development server has disconnected.\\nRefresh the page if necessary.',\n  );\n});\n\nsocket.addEventListener('message', (result) => {\n  try {\n    const { message, type } = JSON.parse(result.data);\n    if (errorShown) {\n      clearError();\n    }\n    switch (type) {\n      case 'reload': {\n        console.log('reloading browser...');\n        showSpinner();\n        window.location.reload();\n        break;\n      }\n      case 'error': {\n        const errors = JSON.parse(message);\n        if (errors.length !== 0) {\n          console.error('compile error occurred...', errors);\n          showError(errors);\n        }\n        break;\n      }\n      default: {\n        if (message) {\n          console.log(message);\n        }\n        break;\n      }\n    }\n  } catch (error) {\n    console.error('Error while receiving message from websocket');\n    console.error(error);\n  }\n});\n\n/** Show error reporting lightbox with errors */\nfunction showError(\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  errors: any,\n): void {\n  if (errors.length === 0) {\n    return;\n  }\n  const errorsContainer = document.createElement('div');\n  const lightbox = createLightbox('dt-app-lightbox-error');\n  errors.forEach((error) => {\n    if (error.text) {\n      errorsContainer.append(\n        stringToHTML(`<div class=\"dt-app-error-text\">${error.text}</div>`),\n      );\n    }\n    if (error.location?.file) {\n      errorsContainer.append(\n        stringToHTML(\n          `<div class=\"dt-app-error-info\">Error in file: ${error.location.file}</div>`,\n        ),\n      );\n    }\n    if (error.prettyError) {\n      errorsContainer.append(stringToHTML(error.prettyError));\n    } else {\n      errorsContainer.append(error.toString());\n    }\n  });\n\n  lightbox\n    .getElementsByClassName('dt-app-lightbox-content')[0]\n    .appendChild(errorsContainer);\n  document.body.appendChild(lightbox);\n  errorShown = true;\n}\n\n/**\n * Clears the Error lightbox\n */\nfunction clearError(): void {\n  document\n    .querySelectorAll('.dt-app-lightbox-error')\n    .forEach((e) => e.remove());\n  errorShown = false;\n}\n\n/**\n * Convert a template string into HTML DOM nodes\n */\nfunction stringToHTML(str: string): HTMLElement {\n  const dom = document.createElement('div');\n  dom.innerHTML = str;\n  return dom;\n}\n\n/** Creates cli lightbox */\nfunction createLightbox(parentClassName: string | undefined): HTMLElement {\n  const lightboxContainer = document.createElement('div');\n  const lightbox = document.createElement('div');\n  const lightboxContent = document.createElement('div');\n\n  if (parentClassName) {\n    lightboxContainer.classList.add(parentClassName);\n  }\n  lightboxContainer.classList.add('dt-app-lightbox-container');\n  lightbox.classList.add('dt-app-lightbox');\n  lightboxContent.classList.add('dt-app-lightbox-content');\n  lightbox.appendChild(lightboxContent);\n  lightboxContainer.appendChild(lightbox);\n\n  return lightboxContainer;\n}\n\n/** Show the loading spinner */\nfunction showSpinner(): void {\n  spinner.classList.add('is-visible');\n  window.setTimeout(() => {\n    hideSpinner();\n  }, 1000);\n}\n\n/** Hide the loading spinner */\nfunction hideSpinner(): void {\n  spinner.classList.remove('is-visible');\n}\n\nconst styles = document.createElement('style');\ndocument.head.appendChild(styles);\nstyles.innerHTML = `\n.dt-app-codesnippet > span > b {\n  margin-left: -9px; /* fixes line offset from ansi conversion */\n  display: block;\n  background-color: #590513;\n}\n.dt-app-error-text{\n  font-size: '1.266rem';\n  color: #c20b29;\n  margin-bottom: 16px;\n  font-family: 500;\n}\n\n.dt-app-warning-text {\n  font-size: '1.266rem';\n  color: #c20b29;\n  font-family: 500;\n  margin-right: 16px;\n  text-align: justify;\n}\n.dt-app-error-info{\n  margin-bottom: 8px;\n}\n.dt-app-codesnippet{\n  white-space: pre;\n  font-family: Consolas,Monaco,'Ubuntu Mono',monospace;\n  display: flex;\n  flex-direction: column;\n  padding: 16px;\n  overflow-x: auto;\n}\n.dt-app-lightbox-container{\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  z-index: 10001;\n  font-family: Roboto,Helvetica,sans-serif;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n.dt-app-lightbox-container:after{\n  content: '';\n  width: 100%;\n  height: 100%;\n  position: absolute;\n  top: 0;\n  left: 0;\n  background-color: #6d7488;\n  opacity: 0.8;\n  z-index: -1;\n}\n.dt-app-lightbox{\n  display: flex;\n  overflow-y: auto;\n  max-width: 100%;\n  width: 1150px;\n  padding: 16px;\n  background-color: #fafbfb;\n  max-height: calc(100vh - 50px)\n}\n.dt-app-lightbox-content{\n  width: 100%;\n  height: 100%;\n}\n.dt-app-close-button {\n  cursor: pointer;\n  height: 20px;\n  width: 20px;\n  display: flex;\n  font-size: 20px;\n  justify-content: center;\n  align-items: center;\n}\n.dt-app-indicator {\n  position: fixed;\n  background-color: #fafbfbs;\n  width: 40px;\n  height: 40px;\n  bottom: 50px;\n  right: 50px;\n  border-radius: 10px;\n  box-shadow: 1px 1px 5px rgba(0,0,0,0.4);\n  display: none;\n}\n\n.dt-app-indicator.is-visible {\n  display: block;\n  animation: dt-app-slide-in 0.4s ease-out 0s forwards alternate;\n}\n\n.dt-app-spinner-icon {\n  --dt-app-spinner-color: #21242A;\n  display: flex;\n  width: 100%;\n  height: 100%;\n  align-items: center;\n  justify-content: center;\n}\n\n.dt-app-spinner-icon:after {\n  content: \" \";\n  display: block;\n  width: 50%;\n  height: 50%;\n  border-radius: 9999px;\n  border: 2px solid var(--dt-app-spinner-color);\n  border-color: var(--dt-app-spinner-color) transparent var(--dt-app-spinner-color) transparent;\n  animation: dt-app-rotate 1.2s linear infinite;\n}\n\n@keyframes dt-app-rotate {\n  0% { transform: rotate(0deg); }\n  100% { transform: rotate(360deg); }\n}\n\n@keyframes dt-app-slide-in {\n  0% {\n    transform: translate3d(60%, 0, 0);\n    opacity: 0;\n  }\n  40% { opacity: 1; }\n  100% { transform: translate3d(0, 0, 0); }\n}\n`;\n\nexport {};\n"],
  "mappings": "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",
  "names": ["serviceWorkerRegistration", "err", "socket", "spinner", "spinnerIcon", "errorShown", "showSpinner", "error", "result", "message", "type", "clearError", "errors", "showError", "errorsContainer", "lightbox", "createLightbox", "stringToHTML", "e", "str", "dom", "parentClassName", "lightboxContainer", "lightboxContent", "hideSpinner", "styles"]
}
