mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-11-04 00:55:11 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			437 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			437 lines
		
	
	
		
			9.3 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
<!DOCTYPE html>
 | 
						|
<html lang="en">
 | 
						|
<head>
 | 
						|
  <meta charset="utf-8">
 | 
						|
  <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0">
 | 
						|
  <title>Hello from Tailscale</title>
 | 
						|
  <style>
 | 
						|
    html,
 | 
						|
    body {
 | 
						|
      margin: 0;
 | 
						|
      padding: 0;
 | 
						|
    }
 | 
						|
 | 
						|
    body {
 | 
						|
      font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
 | 
						|
      font-size: 100%;
 | 
						|
      -webkit-font-smoothing: antialiased;
 | 
						|
      -moz-osx-font-smoothing: grayscale;
 | 
						|
    }
 | 
						|
 | 
						|
    html,
 | 
						|
    body,
 | 
						|
    main {
 | 
						|
      height: 100%;
 | 
						|
    }
 | 
						|
 | 
						|
    *,
 | 
						|
    ::before,
 | 
						|
    ::after {
 | 
						|
      box-sizing: border-box;
 | 
						|
      border-width: 0;
 | 
						|
      border-style: solid;
 | 
						|
      border-color: #dad6d5;
 | 
						|
    }
 | 
						|
 | 
						|
    h1,
 | 
						|
    h2,
 | 
						|
    h3,
 | 
						|
    h4,
 | 
						|
    h5,
 | 
						|
    h6 {
 | 
						|
      margin: 0;
 | 
						|
      font-size: 1rem;
 | 
						|
      font-weight: inherit;
 | 
						|
    }
 | 
						|
 | 
						|
    a {
 | 
						|
      color: inherit;
 | 
						|
    }
 | 
						|
 | 
						|
    p {
 | 
						|
      margin: 0;
 | 
						|
    }
 | 
						|
 | 
						|
    main {
 | 
						|
      display: flex;
 | 
						|
      flex-direction: column;
 | 
						|
      justify-content: center;
 | 
						|
      align-items: center;
 | 
						|
      max-width: 24rem;
 | 
						|
      width: 95%;
 | 
						|
      margin-left: auto;
 | 
						|
      margin-right: auto;
 | 
						|
    }
 | 
						|
 | 
						|
    .p-2 {
 | 
						|
      padding: 0.5rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .p-4 {
 | 
						|
      padding: 1rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .px-2 {
 | 
						|
      padding-left: 0.5rem;
 | 
						|
      padding-right: 0.5rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .pl-3 {
 | 
						|
      padding-left: 0.75rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .pr-3 {
 | 
						|
      padding-right: 0.75rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .pt-4 {
 | 
						|
      padding-top: 1rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .mr-2 {
 | 
						|
      margin-right: 0.5rem;
 | 
						|
      ;
 | 
						|
    }
 | 
						|
 | 
						|
    .mb-1 {
 | 
						|
      margin-bottom: 0.25rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .mb-2 {
 | 
						|
      margin-bottom: 0.5rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .mb-4 {
 | 
						|
      margin-bottom: 1rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .mb-6 {
 | 
						|
      margin-bottom: 1.5rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .mb-8 {
 | 
						|
      margin-bottom: 2rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .mb-12 {
 | 
						|
      margin-bottom: 3rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .width-full {
 | 
						|
      width: 100%;
 | 
						|
    }
 | 
						|
 | 
						|
    .min-width-0 {
 | 
						|
      min-width: 0;
 | 
						|
    }
 | 
						|
 | 
						|
    .rounded-lg {
 | 
						|
      border-radius: 0.5rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .relative {
 | 
						|
      position: relative;
 | 
						|
    }
 | 
						|
 | 
						|
    .flex {
 | 
						|
      display: flex;
 | 
						|
    }
 | 
						|
 | 
						|
    .justify-between {
 | 
						|
      justify-content: space-between;
 | 
						|
    }
 | 
						|
 | 
						|
    .items-center {
 | 
						|
      align-items: center;
 | 
						|
    }
 | 
						|
 | 
						|
    .border {
 | 
						|
      border-width: 1px;
 | 
						|
    }
 | 
						|
 | 
						|
    .border-t-1 {
 | 
						|
      border-top-width: 1px;
 | 
						|
    }
 | 
						|
 | 
						|
    .border-gray-100 {
 | 
						|
      border-color: #f7f5f4;
 | 
						|
    }
 | 
						|
 | 
						|
    .border-gray-200 {
 | 
						|
      border-color: #eeebea;
 | 
						|
    }
 | 
						|
 | 
						|
    .border-gray-300 {
 | 
						|
      border-color: #dad6d5;
 | 
						|
    }
 | 
						|
 | 
						|
    .bg-white {
 | 
						|
      background-color: white;
 | 
						|
    }
 | 
						|
 | 
						|
    .bg-gray-0 {
 | 
						|
      background-color: #faf9f8;
 | 
						|
    }
 | 
						|
 | 
						|
    .bg-gray-100 {
 | 
						|
      background-color: #f7f5f4;
 | 
						|
    }
 | 
						|
 | 
						|
    .text-green-600 {
 | 
						|
      color: #0d4b3b;
 | 
						|
    }
 | 
						|
 | 
						|
    .text-blue-600 {
 | 
						|
      color: #3f5db3;
 | 
						|
    }
 | 
						|
 | 
						|
    .hover\:text-blue-800:hover {
 | 
						|
      color: #253570;
 | 
						|
    }
 | 
						|
 | 
						|
    .text-gray-600 {
 | 
						|
      color: #444342;
 | 
						|
    }
 | 
						|
 | 
						|
    .text-gray-700 {
 | 
						|
      color: #2e2d2d;
 | 
						|
    }
 | 
						|
 | 
						|
    .text-gray-800 {
 | 
						|
      color: #232222;
 | 
						|
    }
 | 
						|
 | 
						|
    .text-center {
 | 
						|
      text-align: center;
 | 
						|
    }
 | 
						|
 | 
						|
    .text-sm {
 | 
						|
      font-size: 0.875rem;
 | 
						|
    }
 | 
						|
 | 
						|
    .font-title {
 | 
						|
      font-size: 1.25rem;
 | 
						|
      letter-spacing: -0.025em;
 | 
						|
    }
 | 
						|
 | 
						|
    .font-semibold {
 | 
						|
      font-weight: 600;
 | 
						|
    }
 | 
						|
 | 
						|
    .font-medium {
 | 
						|
      font-weight: 500;
 | 
						|
    }
 | 
						|
 | 
						|
    .font-regular {
 | 
						|
      font-weight: 400;
 | 
						|
    }
 | 
						|
 | 
						|
    .truncate {
 | 
						|
      overflow: hidden;
 | 
						|
      text-overflow: ellipsis;
 | 
						|
      white-space: nowrap;
 | 
						|
    }
 | 
						|
 | 
						|
    .overflow-hidden {
 | 
						|
      overflow: hidden;
 | 
						|
    }
 | 
						|
 | 
						|
    .profile-pic {
 | 
						|
      width: 2.5rem;
 | 
						|
      height: 2.5rem;
 | 
						|
      border-radius: 9999px;
 | 
						|
      background-size: cover;
 | 
						|
      margin-right: 0.5rem;
 | 
						|
      flex-shrink: 0;
 | 
						|
    }
 | 
						|
 | 
						|
    .panel {
 | 
						|
      box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
 | 
						|
    }
 | 
						|
 | 
						|
    .animate .panel {
 | 
						|
      transform: translateY(10%);
 | 
						|
      box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.0), 0 10px 10px -5px rgba(0, 0, 0, 0.0);
 | 
						|
      transition: transform 1200ms ease, opacity 1200ms ease, box-shadow 1200ms ease;
 | 
						|
    }
 | 
						|
 | 
						|
    .animate .panel-interior {
 | 
						|
      opacity: 0.0;
 | 
						|
      transition: opacity 1200ms ease;
 | 
						|
    }
 | 
						|
 | 
						|
    .animate .logo {
 | 
						|
      transform: translateY(2rem);
 | 
						|
      opacity: 0.0;
 | 
						|
      transition: transform 1200ms ease, opacity 1200ms ease;
 | 
						|
    }
 | 
						|
 | 
						|
    .animate .header-title {
 | 
						|
      transform: translateY(1.6rem);
 | 
						|
      opacity: 0.0;
 | 
						|
      transition: transform 1200ms ease, opacity 1200ms ease;
 | 
						|
    }
 | 
						|
 | 
						|
    .animate .header-text {
 | 
						|
      transform: translateY(1.2rem);
 | 
						|
      opacity: 0.0;
 | 
						|
      transition: transform 1200ms ease, opacity 1200ms ease;
 | 
						|
    }
 | 
						|
 | 
						|
    .animate .footer {
 | 
						|
      transform: translateY(-0.5rem);
 | 
						|
      opacity: 0.0;
 | 
						|
      transition: transform 1200ms ease, opacity 1200ms ease;
 | 
						|
    }
 | 
						|
 | 
						|
    .animating .panel {
 | 
						|
      transform: translateY(0);
 | 
						|
      opacity: 1.0;
 | 
						|
      box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
 | 
						|
    }
 | 
						|
 | 
						|
    .animating .panel-interior {
 | 
						|
      opacity: 1.0;
 | 
						|
    }
 | 
						|
 | 
						|
    .animating .spinner {
 | 
						|
      opacity: 0.0;
 | 
						|
    }
 | 
						|
 | 
						|
    .animating .logo,
 | 
						|
    .animating .header-title,
 | 
						|
    .animating .header-text,
 | 
						|
    .animating .footer {
 | 
						|
      transform: translateY(0);
 | 
						|
      opacity: 1.0;
 | 
						|
    }
 | 
						|
 | 
						|
    .spinner {
 | 
						|
      display: inline-flex;
 | 
						|
      position: absolute;
 | 
						|
      top: 50%;
 | 
						|
      left: 50%;
 | 
						|
      transform: translate(-50%, -50%);
 | 
						|
      align-items: center;
 | 
						|
      transition: opacity 200ms ease;
 | 
						|
    }
 | 
						|
 | 
						|
    .spinner span {
 | 
						|
      display: inline-block;
 | 
						|
      background-color: currentColor;
 | 
						|
      border-radius: 9999px;
 | 
						|
      animation-name: loading-dots-blink;
 | 
						|
      animation-duration: 1.4s;
 | 
						|
      animation-iteration-count: infinite;
 | 
						|
      animation-fill-mode: both;
 | 
						|
      width: 0.35em;
 | 
						|
      height: 0.35em;
 | 
						|
      margin: 0 0.15em;
 | 
						|
    }
 | 
						|
 | 
						|
    .spinner span:nth-child(2) {
 | 
						|
      animation-delay: 200ms;
 | 
						|
    }
 | 
						|
 | 
						|
    .spinner span:nth-child(3) {
 | 
						|
      animation-delay: 400ms;
 | 
						|
    }
 | 
						|
 | 
						|
    .spinner {
 | 
						|
      display: none;
 | 
						|
    }
 | 
						|
 | 
						|
    .animate .spinner {
 | 
						|
      display: inline-flex;
 | 
						|
    }
 | 
						|
 | 
						|
    @keyframes loading-dots-blink {
 | 
						|
      0% {
 | 
						|
        opacity: 0.2;
 | 
						|
      }
 | 
						|
      20% {
 | 
						|
        opacity: 1;
 | 
						|
      }
 | 
						|
      100% {
 | 
						|
        opacity: 0.2;
 | 
						|
      }
 | 
						|
    }
 | 
						|
 | 
						|
    @media (prefers-reduced-motion) {
 | 
						|
      * {
 | 
						|
        animation-duration: 0ms !important;
 | 
						|
        transition-duration: 0ms !important;
 | 
						|
        transition-delay: 0ms !important;
 | 
						|
      }
 | 
						|
    }
 | 
						|
  </style>
 | 
						|
</head>
 | 
						|
<body class="bg-gray-100">
 | 
						|
  <script>
 | 
						|
    (function() {
 | 
						|
      var lastSeen = localStorage.getItem("lastSeen");
 | 
						|
      if (!lastSeen) {
 | 
						|
        document.body.classList.add("animate");
 | 
						|
        window.addEventListener("load", function () {
 | 
						|
          setTimeout(function () {
 | 
						|
            document.body.classList.add("animating");
 | 
						|
            localStorage.setItem("lastSeen", Date.now());
 | 
						|
          }, 100);
 | 
						|
        });
 | 
						|
      }
 | 
						|
    })();
 | 
						|
  </script>
 | 
						|
  <main class="text-gray-800">
 | 
						|
    <svg class="logo mb-6" width="28" height="28" viewBox="0 0 22 22" fill="none" xmlns="http://www.w3.org/2000/svg">
 | 
						|
      <circle opacity="0.2" cx="3.4" cy="3.25" r="2.7" fill="currentColor" />
 | 
						|
      <circle cx="3.4" cy="11.3" r="2.7" fill="currentColor" />
 | 
						|
      <circle opacity="0.2" cx="3.4" cy="19.5" r="2.7" fill="currentColor" />
 | 
						|
      <circle cx="11.5" cy="11.3" r="2.7" fill="currentColor" />
 | 
						|
      <circle cx="11.5" cy="19.5" r="2.7" fill="currentColor" />
 | 
						|
      <circle opacity="0.2" cx="11.5" cy="3.25" r="2.7" fill="currentColor" />
 | 
						|
      <circle opacity="0.2" cx="19.5" cy="3.25" r="2.7" fill="currentColor" />
 | 
						|
      <circle cx="19.5" cy="11.3" r="2.7" fill="currentColor" />
 | 
						|
      <circle opacity="0.2" cx="19.5" cy="19.5" r="2.7" fill="currentColor" />
 | 
						|
    </svg>
 | 
						|
    <header class="mb-8 text-center">
 | 
						|
      <h1 class="header-title font-title font-semibold mb-2">You're connected over Tailscale!</h1>
 | 
						|
      <p class="header-text">This device is signed in as…</p>
 | 
						|
    </header>
 | 
						|
    <div class="panel relative bg-white rounded-lg width-full shadow-xl mb-8 p-4">
 | 
						|
      <div class="spinner text-gray-600">
 | 
						|
        <span></span>
 | 
						|
        <span></span>
 | 
						|
        <span></span>
 | 
						|
      </div>
 | 
						|
      <div class="panel-interior flex items-center width-full min-width-0 p-2 mb-4">
 | 
						|
        <div class="profile-pic bg-gray-100" style="background-image: url({{.ProfilePicURL}});"></div>
 | 
						|
        <div class="overflow-hidden">
 | 
						|
          {{ with .DisplayName }}
 | 
						|
          <h4 class="font-semibold truncate">{{.}}</h4>
 | 
						|
          {{ end }}
 | 
						|
          <h5 class="text-gray-600 truncate">{{.LoginName}}</h5>
 | 
						|
        </div>
 | 
						|
      </div>
 | 
						|
      <div
 | 
						|
        class="panel-interior border border-gray-200 bg-gray-0 rounded-lg p-2 pl-3 pr-3 mb-2 width-full flex justify-between items-center">
 | 
						|
        <div class="flex items-center min-width-0">
 | 
						|
          <svg class="text-gray-600 mr-2" xmlns="http://www.w3.org/2000/svg" width="18" height="18" viewBox="0 0 24 24" fill="none"
 | 
						|
            stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
 | 
						|
            <rect x="2" y="2" width="20" height="8" rx="2" ry="2"></rect>
 | 
						|
            <rect x="2" y="14" width="20" height="8" rx="2" ry="2"></rect>
 | 
						|
            <line x1="6" y1="6" x2="6.01" y2="6"></line>
 | 
						|
            <line x1="6" y1="18" x2="6.01" y2="18"></line>
 | 
						|
          </svg>
 | 
						|
          <h4 class="font-semibold truncate mr-2">{{.MachineName}}</h4>
 | 
						|
        </div>
 | 
						|
        <h5>{{.IP}}</h5>
 | 
						|
      </div>
 | 
						|
    </div>
 | 
						|
    <footer class="footer text-gray-600 text-center mb-12">
 | 
						|
      <p>Read about <a href="https://tailscale.com/kb/1017/install#advanced-features" class="text-blue-600 hover:text-blue-800"
 | 
						|
          target="_blank">what you can do next →</a></p>
 | 
						|
    </footer>
 | 
						|
  </main>
 | 
						|
</body>
 | 
						|
</html>
 |