aboutsummaryrefslogblamecommitdiffhomepage
path: root/index.html
blob: d427002693e385cf11e86c96346824ef989e7e0e (plain) (tree)
1
2
3
4
5
6
7
8
9
               
 




                                                                      
                                                                   
                                        
 
      
                                                                                                           
                                  
                                       



                                                           
                                                               

                
                                                               
                                                                           









                                                                         
                                        
                                                                                                           


                                                                                        
                                         

                                                 
                                       
                                                  



                                                                                   

                                                                                
                        
                      

                    
              
          
 
                                               













                                                                                                  
 
                                                                     
 





                                                                                                                        
                                                                








                                                                                                                 
                                                                
                        
                  
 
              
              
                               
                                                                                             

                
        
 
                                            
                                                
       
       
<!DOCTYPE html>
<html>

<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <meta name="robots" content="noindex">
  <link rel="icon" type="image/png" href="assets/favicon.png">
  <title>Homer</title>
  <link defer rel="stylesheet" href="vendors/font-awesone.min.css">
  <link defer rel="stylesheet" href="vendors/bulma.min.css">
  <link rel="stylesheet" href="app.css">
</head>

<body>
  <div id="app" v-if="config" :class="[isDark ? 'is-dark' : 'is-light', !config.footer ? 'no-footer': '']">
    <div id="bighead">
      <section class="first-line">
        <div v-cloak class="container">
          <div class="logo">
            <img v-if="config.logo" :src="config.logo" />
            <i v-if="config.icon" :class="config.icon"></i>
          </div>
          <div class="dashboard-title">
            <span class="headline">{{ config.subtitle }}</span>
            <h1>{{ config.title }}</h1>
          </div>
        </div>
      </section>
      <div v-cloak v-if="config.links" class="container-fluid">
        <nav class="navbar" role="navigation" aria-label="main navigation">
          <div class="container">
            <div class="navbar-brand">
              <a role="button" 
                class="navbar-burger" :class="{ 'is-active': showMenu }" 
                aria-label="menu" aria-expanded="false"
                v-on:click="toggleMenu()">
                <span aria-hidden="true"></span>
                <span aria-hidden="true"></span>
                <span aria-hidden="true"></span>
              </a>
            </div>
            <div class="navbar-menu" :class="{ 'is-active': showMenu }">
              <div class="navbar-start">
                <a v-for="link in config.links" class="navbar-item" :href="link.url" :target="link.target">
                  <i v-if="link.icon" style="margin-right: 6px;" :class="link.icon"></i>
                  {{ link.name }}
                </a>
              </div>
              <div class="navbar-end">
                <div class="navbar-item">
                  <a
                    v-on:click="toggleTheme()"
                    aria-label="Toggle dark mode"
                    class="icon-button"
                    ><i class="fas fa-adjust"></i>
                  </a>
                  <a v-on:click="toggleLayout()" class="icon-button"><i
                      :class="['fas', vlayout ? 'fa-list' : 'fa-columns']"></i></a>
                  <div class="search-bar">
                    <label for="search" class="search-label"></label>
                    <input type="text" id="search" ref="search" v-model="filter"
                      v-on:keyup.enter.exact="navigateToFirstService()"
                      v-on:keyup.alt.enter="navigateToFirstService('_blank')" />
                  </div>
                </div>
              </div>
            </div>
          </div>
        </nav>
      </div>
    </div>

    <section id="main-section" class="section">
      <div v-cloak class="container">
        <div v-if="offline" class="offline-message">
          <i class="far fa-dizzy"></i>
          <h1>You're offline bro. <i class="fas fa-redo-alt" v-on:click="checkOffline()"></i></h1>
        </div>
        <div v-else>
          <!-- Optional messages -->
          <article v-if="config && config.message" class="message" :class="config.message.style">
            <div v-if="config.message.title" class="message-header">
              <p>{{ config.message.title }}</p>
            </div>
            <div v-if="config.message.content" class="message-body">
              {{ config.message.content }}
            </div>
          </article>

          <h2 v-if="filter"><i class="fas fa-search"></i> Search</h2>

          <!-- Horizontal layout -->
          <div v-if="!vlayout || filter" class="columns is-multiline">
            <template v-for="(group, index) in config.services">
              <h2 v-if="!filter && group.name" class="column is-full"><i v-if="group.icon" :class="group.icon"></i><span
                  v-else>#</span>
                {{ group.name }}</h2>
              <service v-for="item in group.items" v-bind:item="item" class="column is-one-third-widescreen"
                v-if="!filter || (item && matchesFilter(item))">
              </service>
            </template>
          </div>

          <!-- Vertical layout -->
          <div v-if="!filter && vlayout" class="columns is-multiline layout-vertical">
            <div class="column is-one-third-widescreen" v-for="(group, index) in config.services">
              <h2 v-if="!filter && group.name"><i v-if="group.icon" :class="group.icon"></i><span v-else>#</span>
                {{ group.name }}</h2>
              <service v-for="item in group.items" v-bind:item="item"
                v-if="!filter || (item && matchesFilter(item))">
              </service>
            </div>
          </div>


        </div>
      </div>
    </section>
    <footer class="footer">
        <div class="container">
          <div class="content has-text-centered" v-if="config.footer" v-html="config.footer">
            
          </div>
        </div>
      </footer>
  </div>

  <script src="vendors/vue.min.js"></script>
  <script src="vendors/js-yaml.min.js"></script>
  <script src="app.js"></script>
</body>

</html>