mint-jekyll 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/LICENSE.txt +21 -0
- data/README.md +52 -0
- data/_layouts/default.html +58 -0
- data/assets/css/default.css +191 -0
- data/assets/js/headerbar_collapse.js +15 -0
- data/assets/js/slideshow.js +82 -0
- data/assets/js/slideshow/timer_worker.js +5 -0
- metadata +93 -0
    
        checksums.yaml
    ADDED
    
    | @@ -0,0 +1,7 @@ | |
| 1 | 
            +
            ---
         | 
| 2 | 
            +
            SHA256:
         | 
| 3 | 
            +
              metadata.gz: 88a7b61ee03fa0b363d9408bec7e504665225839cf5794b2d000493f32a40f6c
         | 
| 4 | 
            +
              data.tar.gz: a13c6c75eab39aea3c43f767cae256b0cacb11012d78b56c00ca3d9b3dc6cd2b
         | 
| 5 | 
            +
            SHA512:
         | 
| 6 | 
            +
              metadata.gz: b90569e5674c07a48b77f2650ca019028fe8692977e99c871cf18973c53cf49d755b6be8a3102eff8de81d9589ffdfb041511fe11f6a4c9cd28c4ab9c885c519
         | 
| 7 | 
            +
              data.tar.gz: b90893e29d160032a62592dea62acea9d4cf3905f6dceb26ba3efb0a70311c43c7736ad187c4a14eb53a365cf9fb120d96565ee35d171745f051bd69ff880694
         | 
    
        data/LICENSE.txt
    ADDED
    
    | @@ -0,0 +1,21 @@ | |
| 1 | 
            +
            The MIT License (MIT)
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Copyright (c) 2019 
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            Permission is hereby granted, free of charge, to any person obtaining a copy
         | 
| 6 | 
            +
            of this software and associated documentation files (the "Software"), to deal
         | 
| 7 | 
            +
            in the Software without restriction, including without limitation the rights
         | 
| 8 | 
            +
            to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
         | 
| 9 | 
            +
            copies of the Software, and to permit persons to whom the Software is
         | 
| 10 | 
            +
            furnished to do so, subject to the following conditions:
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            The above copyright notice and this permission notice shall be included in
         | 
| 13 | 
            +
            all copies or substantial portions of the Software.
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
         | 
| 16 | 
            +
            IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
         | 
| 17 | 
            +
            FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
         | 
| 18 | 
            +
            AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
         | 
| 19 | 
            +
            LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
         | 
| 20 | 
            +
            OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
         | 
| 21 | 
            +
            THE SOFTWARE.
         | 
    
        data/README.md
    ADDED
    
    | @@ -0,0 +1,52 @@ | |
| 1 | 
            +
            # mint
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            Welcome to your new Jekyll theme! In this directory, you'll find the files you need to be able to package up your theme into a gem. Put your layouts in `_layouts`, your includes in `_includes`, your sass files in `_sass` and any other assets in `assets`.
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            To experiment with this code, add some sample content and run `bundle exec jekyll serve` – this directory is setup just like a Jekyll site!
         | 
| 6 | 
            +
             | 
| 7 | 
            +
            TODO: Delete this and the text above, and describe your gem
         | 
| 8 | 
            +
             | 
| 9 | 
            +
             | 
| 10 | 
            +
            ## Installation
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            Add this line to your Jekyll site's `Gemfile`:
         | 
| 13 | 
            +
             | 
| 14 | 
            +
            ```ruby
         | 
| 15 | 
            +
            gem "mint"
         | 
| 16 | 
            +
            ```
         | 
| 17 | 
            +
             | 
| 18 | 
            +
            And add this line to your Jekyll site's `_config.yml`:
         | 
| 19 | 
            +
             | 
| 20 | 
            +
            ```yaml
         | 
| 21 | 
            +
            theme: mint
         | 
| 22 | 
            +
            ```
         | 
| 23 | 
            +
             | 
| 24 | 
            +
            And then execute:
         | 
| 25 | 
            +
             | 
| 26 | 
            +
                $ bundle
         | 
| 27 | 
            +
             | 
| 28 | 
            +
            Or install it yourself as:
         | 
| 29 | 
            +
             | 
| 30 | 
            +
                $ gem install mint
         | 
| 31 | 
            +
             | 
| 32 | 
            +
            ## Usage
         | 
| 33 | 
            +
             | 
| 34 | 
            +
            TODO: Write usage instructions here. Describe your available layouts, includes, sass and/or assets.
         | 
| 35 | 
            +
             | 
| 36 | 
            +
            ## Contributing
         | 
| 37 | 
            +
             | 
| 38 | 
            +
            Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/hello. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
         | 
| 39 | 
            +
             | 
| 40 | 
            +
            ## Development
         | 
| 41 | 
            +
             | 
| 42 | 
            +
            To set up your environment to develop this theme, run `bundle install`.
         | 
| 43 | 
            +
             | 
| 44 | 
            +
            Your theme is setup just like a normal Jekyll site! To test your theme, run `bundle exec jekyll serve` and open your browser at `http://localhost:4000`. This starts a Jekyll server using your theme. Add pages, documents, data, etc. like normal to test your theme's contents. As you make modifications to your theme and to your content, your site will regenerate and you should see the changes in the browser after a refresh, just like normal.
         | 
| 45 | 
            +
             | 
| 46 | 
            +
            When your theme is released, only the files in `_layouts`, `_includes`, `_sass` and `assets` tracked with Git will be bundled.
         | 
| 47 | 
            +
            To add a custom directory to your theme-gem, please edit the regexp in `mint.gemspec` accordingly.
         | 
| 48 | 
            +
             | 
| 49 | 
            +
            ## License
         | 
| 50 | 
            +
             | 
| 51 | 
            +
            The theme is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
         | 
| 52 | 
            +
             | 
| @@ -0,0 +1,58 @@ | |
| 1 | 
            +
            <!DOCTYPE html>
         | 
| 2 | 
            +
            <html>
         | 
| 3 | 
            +
                <head>
         | 
| 4 | 
            +
                    <link rel="stylesheet" type="text/css" href="/assets/css/default.css" />
         | 
| 5 | 
            +
             | 
| 6 | 
            +
                    <title>{{page.title}} | {{site.author.name}}</title>
         | 
| 7 | 
            +
             | 
| 8 | 
            +
                    <meta name="viewport" content="width=device-width, initial-scale=1">
         | 
| 9 | 
            +
                </head>
         | 
| 10 | 
            +
                <body>
         | 
| 11 | 
            +
                    <div class="headerbar headerbar-full" id="headerbar">
         | 
| 12 | 
            +
                        <div class="headerbar-level" id="info-level">
         | 
| 13 | 
            +
                            <div class="headerbar-author">
         | 
| 14 | 
            +
                                <img class="headerbar-author-image" src="{{site.author.photo}}" />
         | 
| 15 | 
            +
                                <div class="headerbar-author-text">
         | 
| 16 | 
            +
                                    <span class="headerbar-author-text-name">{{site.author.name}}</span>
         | 
| 17 | 
            +
                                    <span class="headerbar-author-text-description">{{site.author.description}}</span>
         | 
| 18 | 
            +
                                </div>
         | 
| 19 | 
            +
                            </div>
         | 
| 20 | 
            +
                            <div class="headerbar-spacer"></div>
         | 
| 21 | 
            +
                            <div class="headerbar-title">{{page.title | upcase}}</div>
         | 
| 22 | 
            +
                        </div>
         | 
| 23 | 
            +
                        <div class="headerbar-level">
         | 
| 24 | 
            +
                            <div class="headerbar-buttons">
         | 
| 25 | 
            +
                                <div class="headerbar-logo" id="headerbar-logo">{{site.author.name}}</div>
         | 
| 26 | 
            +
                                {% for link in site.data.headerbar.links.left %}
         | 
| 27 | 
            +
                                    <a href="{{link.href}}">{{link.title | upcase}}</a>
         | 
| 28 | 
            +
                                {% endfor %}
         | 
| 29 | 
            +
                            </div>
         | 
| 30 | 
            +
                            <div class="headerbar-spacer"></div>
         | 
| 31 | 
            +
                            <div class="headerbar-buttons">
         | 
| 32 | 
            +
                                {% for link in site.data.headerbar.links.right %}
         | 
| 33 | 
            +
                                    <a href="{{link.href}}">{{link.title | upcase}}</a>
         | 
| 34 | 
            +
                                {% endfor %}
         | 
| 35 | 
            +
                            </div>
         | 
| 36 | 
            +
                        </div>
         | 
| 37 | 
            +
                    </div>
         | 
| 38 | 
            +
             | 
| 39 | 
            +
                    <div class="content content-full" id="content">
         | 
| 40 | 
            +
                        {{page.content}}
         | 
| 41 | 
            +
                    </div>
         | 
| 42 | 
            +
             | 
| 43 | 
            +
                    <div class="footerbar">Copright © {{site.author.full_name}}, 2019</div>
         | 
| 44 | 
            +
                    
         | 
| 45 | 
            +
                    <script type="text/javascript" src="/assets/js/headerbarCollapse.js"></script>
         | 
| 46 | 
            +
                    {% if page.has_slideshow %}
         | 
| 47 | 
            +
                        <script type="text/javascript" src="/assets/js/slideshow.js"></script>
         | 
| 48 | 
            +
                        <script type="text/javascript">
         | 
| 49 | 
            +
                            let slides = [
         | 
| 50 | 
            +
                                {% assign range = page.slides | size | minus: 1 %}
         | 
| 51 | 
            +
                                {% for slide in page.slides limit:range %}"{{slide}}",{% endfor %}"{{page.slides | last}}"
         | 
| 52 | 
            +
                            ];
         | 
| 53 | 
            +
             | 
| 54 | 
            +
                            let slideShow = new SlideShow(slides, true);
         | 
| 55 | 
            +
                        </script>
         | 
| 56 | 
            +
                    {% endif %}
         | 
| 57 | 
            +
                </body>
         | 
| 58 | 
            +
            </html>
         | 
| @@ -0,0 +1,191 @@ | |
| 1 | 
            +
            @import url('https://fonts.googleapis.com/css?family=Roboto:400,900&display=swap');
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            body {
         | 
| 4 | 
            +
                margin: 0px;
         | 
| 5 | 
            +
                padding: 0px;
         | 
| 6 | 
            +
             | 
| 7 | 
            +
                font-size: 16px;
         | 
| 8 | 
            +
                font-family: "Roboto", sans-serif;
         | 
| 9 | 
            +
            }
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            a {
         | 
| 12 | 
            +
                color: white;
         | 
| 13 | 
            +
                text-decoration: none;
         | 
| 14 | 
            +
            }
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            a:hover {
         | 
| 17 | 
            +
                text-decoration: underline;
         | 
| 18 | 
            +
            }
         | 
| 19 | 
            +
             | 
| 20 | 
            +
            .headerbar {
         | 
| 21 | 
            +
                margin: 0px;
         | 
| 22 | 
            +
             | 
| 23 | 
            +
                display: flex;
         | 
| 24 | 
            +
                flex-direction: column;
         | 
| 25 | 
            +
                justify-content: flex-start;
         | 
| 26 | 
            +
             | 
| 27 | 
            +
                box-shadow: 2px 2px 10px darkgrey;
         | 
| 28 | 
            +
             | 
| 29 | 
            +
                color: white;
         | 
| 30 | 
            +
                background-color: rgb(10, 169, 121);
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                position: fixed;
         | 
| 33 | 
            +
                left: 0;
         | 
| 34 | 
            +
                top: 0;
         | 
| 35 | 
            +
                width: 84.5vw;
         | 
| 36 | 
            +
             | 
| 37 | 
            +
                transition: padding 1s;
         | 
| 38 | 
            +
            }
         | 
| 39 | 
            +
             | 
| 40 | 
            +
            .headerbar-full {
         | 
| 41 | 
            +
                padding: 30px 100px 30px 100px;
         | 
| 42 | 
            +
            }
         | 
| 43 | 
            +
             | 
| 44 | 
            +
            .headerbar-compact {
         | 
| 45 | 
            +
                padding: 5px 100px 5px 100px;
         | 
| 46 | 
            +
            }
         | 
| 47 | 
            +
             | 
| 48 | 
            +
            .headerbar-level {
         | 
| 49 | 
            +
                display: flex;
         | 
| 50 | 
            +
                flex-direction: row;
         | 
| 51 | 
            +
                justify-content: flex-start;
         | 
| 52 | 
            +
            }
         | 
| 53 | 
            +
             | 
| 54 | 
            +
            .headerbar-spacer {
         | 
| 55 | 
            +
                flex-grow: 3;
         | 
| 56 | 
            +
            }
         | 
| 57 | 
            +
             | 
| 58 | 
            +
            .headerbar-author {
         | 
| 59 | 
            +
                display: flex;
         | 
| 60 | 
            +
                flex-direction: row;
         | 
| 61 | 
            +
                justify-content: center;
         | 
| 62 | 
            +
            }
         | 
| 63 | 
            +
             | 
| 64 | 
            +
            .headerbar-logo {
         | 
| 65 | 
            +
                border-radius: 7px;
         | 
| 66 | 
            +
                margin: 0px 0px 0px 7px;
         | 
| 67 | 
            +
                padding: 7px 0px 7px 7px;
         | 
| 68 | 
            +
             | 
| 69 | 
            +
                display: none;
         | 
| 70 | 
            +
            }
         | 
| 71 | 
            +
             | 
| 72 | 
            +
            .headerbar-author-image {
         | 
| 73 | 
            +
                border-radius: 7px;
         | 
| 74 | 
            +
                margin: 10px;
         | 
| 75 | 
            +
                height: 75px;
         | 
| 76 | 
            +
            }
         | 
| 77 | 
            +
             | 
| 78 | 
            +
            .headerbar-author-text {
         | 
| 79 | 
            +
                margin: 10px;
         | 
| 80 | 
            +
             | 
| 81 | 
            +
                display: flex;
         | 
| 82 | 
            +
                flex-direction: column;
         | 
| 83 | 
            +
                justify-content: center;
         | 
| 84 | 
            +
            }
         | 
| 85 | 
            +
             | 
| 86 | 
            +
            .headerbar-author-text-name {
         | 
| 87 | 
            +
                font-size: 18px;
         | 
| 88 | 
            +
            }
         | 
| 89 | 
            +
             | 
| 90 | 
            +
            .headerbar-author-text-description {
         | 
| 91 | 
            +
                font-size: 14px;
         | 
| 92 | 
            +
            }
         | 
| 93 | 
            +
             | 
| 94 | 
            +
            .headerbar-title {
         | 
| 95 | 
            +
                padding: 20px;
         | 
| 96 | 
            +
                font-weight: bolder;
         | 
| 97 | 
            +
                font-size: 48px;
         | 
| 98 | 
            +
            }
         | 
| 99 | 
            +
             | 
| 100 | 
            +
            .headerbar-buttons {
         | 
| 101 | 
            +
                margin: 10px 0px 10px 0px;
         | 
| 102 | 
            +
                display: flex;
         | 
| 103 | 
            +
                flex-direction: row;
         | 
| 104 | 
            +
                justify-content: flex-start;
         | 
| 105 | 
            +
            }
         | 
| 106 | 
            +
             | 
| 107 | 
            +
            .headerbar-buttons a {
         | 
| 108 | 
            +
                border-radius: 7px;
         | 
| 109 | 
            +
                margin: 0px 0px 0px 7px;
         | 
| 110 | 
            +
                padding: 7px;
         | 
| 111 | 
            +
             | 
| 112 | 
            +
                background-color: rgb(10, 180, 121);
         | 
| 113 | 
            +
                
         | 
| 114 | 
            +
                transition: box-shadow 1s, text-shadow 1s;
         | 
| 115 | 
            +
            }
         | 
| 116 | 
            +
             | 
| 117 | 
            +
            .headerbar-buttons a:hover {
         | 
| 118 | 
            +
                text-decoration: none;
         | 
| 119 | 
            +
                text-shadow: 0px 0px 7px darkslategrey;
         | 
| 120 | 
            +
                box-shadow: 0px 0px 7px darkslategrey;
         | 
| 121 | 
            +
            }
         | 
| 122 | 
            +
             | 
| 123 | 
            +
            .content {
         | 
| 124 | 
            +
                line-height: 0.4in;
         | 
| 125 | 
            +
                transition: margin 1s;
         | 
| 126 | 
            +
            }
         | 
| 127 | 
            +
             | 
| 128 | 
            +
            .content-full {
         | 
| 129 | 
            +
                margin: 240px 100px 10px 100px;
         | 
| 130 | 
            +
            }
         | 
| 131 | 
            +
             | 
| 132 | 
            +
            .content-compact {
         | 
| 133 | 
            +
                margin: 130px 100px 10px 100px;
         | 
| 134 | 
            +
            }
         | 
| 135 | 
            +
             | 
| 136 | 
            +
            .footerbar {
         | 
| 137 | 
            +
                margin: 0px;
         | 
| 138 | 
            +
                padding: 20px 10px 20px 10px;
         | 
| 139 | 
            +
             | 
| 140 | 
            +
                box-shadow: -2px -2px 10px darkgrey;
         | 
| 141 | 
            +
             | 
| 142 | 
            +
                font-weight: lighter;
         | 
| 143 | 
            +
                font-size: 12px;
         | 
| 144 | 
            +
                text-align: center;
         | 
| 145 | 
            +
             | 
| 146 | 
            +
                color: white;
         | 
| 147 | 
            +
                background-color: rgb(10, 169, 121);
         | 
| 148 | 
            +
            }
         | 
| 149 | 
            +
             | 
| 150 | 
            +
            .parallel-content {
         | 
| 151 | 
            +
                display: flex;
         | 
| 152 | 
            +
                flex-direction: row;
         | 
| 153 | 
            +
                justify-content: flex-start;
         | 
| 154 | 
            +
            }
         | 
| 155 | 
            +
             | 
| 156 | 
            +
            .parallel-item {
         | 
| 157 | 
            +
            }
         | 
| 158 | 
            +
             | 
| 159 | 
            +
            .parallel-spacer {
         | 
| 160 | 
            +
                flex-grow: 3;
         | 
| 161 | 
            +
            }
         | 
| 162 | 
            +
             | 
| 163 | 
            +
            .slideshow {
         | 
| 164 | 
            +
                display: flex;
         | 
| 165 | 
            +
                flex-direction: row;
         | 
| 166 | 
            +
                justify-content: flex-start;
         | 
| 167 | 
            +
            }
         | 
| 168 | 
            +
             | 
| 169 | 
            +
            .slideshow-slide {
         | 
| 170 | 
            +
                text-align: center;
         | 
| 171 | 
            +
                display: none;
         | 
| 172 | 
            +
            }
         | 
| 173 | 
            +
             | 
| 174 | 
            +
            .slideshow-button {
         | 
| 175 | 
            +
                outline: none;
         | 
| 176 | 
            +
                border: none;
         | 
| 177 | 
            +
             | 
| 178 | 
            +
                padding: 7px;
         | 
| 179 | 
            +
             | 
| 180 | 
            +
                border-radius: 7px;
         | 
| 181 | 
            +
                color: white;
         | 
| 182 | 
            +
                background-color: rgb(10, 169, 121);
         | 
| 183 | 
            +
                font-size: 24px;
         | 
| 184 | 
            +
             | 
| 185 | 
            +
                transition: box-shadow 1s;
         | 
| 186 | 
            +
            }
         | 
| 187 | 
            +
             | 
| 188 | 
            +
            .slideshow-button:hover {
         | 
| 189 | 
            +
                box-shadow: 0px 0px 7px darkslategrey;
         | 
| 190 | 
            +
                cursor: pointer;
         | 
| 191 | 
            +
            }
         | 
| @@ -0,0 +1,15 @@ | |
| 1 | 
            +
            window.onscroll = () => scrollFunction();
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            let scrollFunction = () => {
         | 
| 4 | 
            +
                if (document.body.scrollTop > 50 || document.documentElement.scrollTop > 50) {
         | 
| 5 | 
            +
                    document.getElementById("headerbar").classList.replace("headerbar-full", "headerbar-compact");
         | 
| 6 | 
            +
                    document.getElementById("content").classList.replace("content-full", "content-compact");
         | 
| 7 | 
            +
                    document.getElementById("info-level").style.display = "none";
         | 
| 8 | 
            +
                    document.getElementById("headerbar-logo").style.display = "block";
         | 
| 9 | 
            +
                } else {
         | 
| 10 | 
            +
                    document.getElementById("headerbar").classList.replace("headerbar-compact", "headerbar-full");
         | 
| 11 | 
            +
                    document.getElementById("content").classList.replace("content-compact", "content-full");
         | 
| 12 | 
            +
                    document.getElementById("info-level").style.display = "flex";
         | 
| 13 | 
            +
                    document.getElementById("headerbar-logo").style.display = "none";
         | 
| 14 | 
            +
                }
         | 
| 15 | 
            +
            }
         | 
| @@ -0,0 +1,82 @@ | |
| 1 | 
            +
            class SlideShow {
         | 
| 2 | 
            +
                constructor(slides, timeout) {
         | 
| 3 | 
            +
                    if(slides.length < 2) {
         | 
| 4 | 
            +
                        console.error("Aww, Jeeze! You need more slides!");
         | 
| 5 | 
            +
                    }
         | 
| 6 | 
            +
             | 
| 7 | 
            +
                    this._slides = slides;
         | 
| 8 | 
            +
             | 
| 9 | 
            +
                    this._first = 0;
         | 
| 10 | 
            +
                    this._last = this._slides.length - 1;
         | 
| 11 | 
            +
                    this._index = this._first;
         | 
| 12 | 
            +
             | 
| 13 | 
            +
                    this.showSlide(this._index++);
         | 
| 14 | 
            +
             | 
| 15 | 
            +
                    if(timeout) {
         | 
| 16 | 
            +
                        this.spawnTimerWorker();
         | 
| 17 | 
            +
                    }
         | 
| 18 | 
            +
                }
         | 
| 19 | 
            +
             | 
| 20 | 
            +
                spawnTimerWorker() {
         | 
| 21 | 
            +
                    this._timer = new Worker("/assets/js/slideshow/timer_worker.js");
         | 
| 22 | 
            +
                    
         | 
| 23 | 
            +
                    this._timer.postMessage("go");
         | 
| 24 | 
            +
                    
         | 
| 25 | 
            +
                    this._timer.addEventListener("message", _ => {
         | 
| 26 | 
            +
                        this.nextSlide()
         | 
| 27 | 
            +
                    });
         | 
| 28 | 
            +
             | 
| 29 | 
            +
                    this._timer.addEventListener("error", _ => {
         | 
| 30 | 
            +
                        console.error("Woah! Something went wrong there!")
         | 
| 31 | 
            +
                    });
         | 
| 32 | 
            +
                }
         | 
| 33 | 
            +
             | 
| 34 | 
            +
                restartTimerWorker() {
         | 
| 35 | 
            +
                    this._timer.terminate();
         | 
| 36 | 
            +
                    this.spawnTimerWorker();
         | 
| 37 | 
            +
                }
         | 
| 38 | 
            +
             | 
| 39 | 
            +
                assessBounds(direction) {
         | 
| 40 | 
            +
                    if(direction === "forward") {
         | 
| 41 | 
            +
                        if(this._index > this._last) {
         | 
| 42 | 
            +
                            this._index = this._first;
         | 
| 43 | 
            +
                        }
         | 
| 44 | 
            +
                    } else if(direction === "backward") {
         | 
| 45 | 
            +
                        if(this._index < this._first) {
         | 
| 46 | 
            +
                            this._index = this._last;
         | 
| 47 | 
            +
                        }
         | 
| 48 | 
            +
                    }
         | 
| 49 | 
            +
                }
         | 
| 50 | 
            +
             | 
| 51 | 
            +
                showSlide(index) {
         | 
| 52 | 
            +
                    document.getElementById(this._slides[index]).style.display = "block";
         | 
| 53 | 
            +
                }
         | 
| 54 | 
            +
             | 
| 55 | 
            +
                closeSlide(index) {
         | 
| 56 | 
            +
                    document.getElementById(this._slides[index]).style.display = "none";
         | 
| 57 | 
            +
                }
         | 
| 58 | 
            +
             | 
| 59 | 
            +
                closeSlides() {
         | 
| 60 | 
            +
                    for(let i = this._first; i <= this._last; i++) {
         | 
| 61 | 
            +
                        if(i !== this._index) {
         | 
| 62 | 
            +
                            this.closeSlide(i);
         | 
| 63 | 
            +
                        }
         | 
| 64 | 
            +
                    }
         | 
| 65 | 
            +
                }
         | 
| 66 | 
            +
             | 
| 67 | 
            +
                nextSlide() {
         | 
| 68 | 
            +
                    this.restartTimerWorker();
         | 
| 69 | 
            +
             | 
| 70 | 
            +
                    this.closeSlides();
         | 
| 71 | 
            +
                    this.showSlide(this._index++);
         | 
| 72 | 
            +
                    this.assessBounds("forward");
         | 
| 73 | 
            +
                }
         | 
| 74 | 
            +
             | 
| 75 | 
            +
                previousSlide() {
         | 
| 76 | 
            +
                    this.restartTimerWorker();
         | 
| 77 | 
            +
             | 
| 78 | 
            +
                    this.closeSlides();
         | 
| 79 | 
            +
                    this.showSlide(this._index--);
         | 
| 80 | 
            +
                    this.assessBounds("backward");
         | 
| 81 | 
            +
                }
         | 
| 82 | 
            +
            }
         | 
    
        metadata
    ADDED
    
    | @@ -0,0 +1,93 @@ | |
| 1 | 
            +
            --- !ruby/object:Gem::Specification
         | 
| 2 | 
            +
            name: mint-jekyll
         | 
| 3 | 
            +
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            +
              version: 0.1.0
         | 
| 5 | 
            +
            platform: ruby
         | 
| 6 | 
            +
            authors:
         | 
| 7 | 
            +
            - Kove Salter
         | 
| 8 | 
            +
            autorequire: 
         | 
| 9 | 
            +
            bindir: bin
         | 
| 10 | 
            +
            cert_chain: []
         | 
| 11 | 
            +
            date: 2019-06-03 00:00:00.000000000 Z
         | 
| 12 | 
            +
            dependencies:
         | 
| 13 | 
            +
            - !ruby/object:Gem::Dependency
         | 
| 14 | 
            +
              name: jekyll
         | 
| 15 | 
            +
              requirement: !ruby/object:Gem::Requirement
         | 
| 16 | 
            +
                requirements:
         | 
| 17 | 
            +
                - - "~>"
         | 
| 18 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 19 | 
            +
                    version: '3.8'
         | 
| 20 | 
            +
              type: :runtime
         | 
| 21 | 
            +
              prerelease: false
         | 
| 22 | 
            +
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 23 | 
            +
                requirements:
         | 
| 24 | 
            +
                - - "~>"
         | 
| 25 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 26 | 
            +
                    version: '3.8'
         | 
| 27 | 
            +
            - !ruby/object:Gem::Dependency
         | 
| 28 | 
            +
              name: bundler
         | 
| 29 | 
            +
              requirement: !ruby/object:Gem::Requirement
         | 
| 30 | 
            +
                requirements:
         | 
| 31 | 
            +
                - - "~>"
         | 
| 32 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 33 | 
            +
                    version: '1.16'
         | 
| 34 | 
            +
              type: :development
         | 
| 35 | 
            +
              prerelease: false
         | 
| 36 | 
            +
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 37 | 
            +
                requirements:
         | 
| 38 | 
            +
                - - "~>"
         | 
| 39 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 40 | 
            +
                    version: '1.16'
         | 
| 41 | 
            +
            - !ruby/object:Gem::Dependency
         | 
| 42 | 
            +
              name: rake
         | 
| 43 | 
            +
              requirement: !ruby/object:Gem::Requirement
         | 
| 44 | 
            +
                requirements:
         | 
| 45 | 
            +
                - - "~>"
         | 
| 46 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 47 | 
            +
                    version: '12.0'
         | 
| 48 | 
            +
              type: :development
         | 
| 49 | 
            +
              prerelease: false
         | 
| 50 | 
            +
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 51 | 
            +
                requirements:
         | 
| 52 | 
            +
                - - "~>"
         | 
| 53 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 54 | 
            +
                    version: '12.0'
         | 
| 55 | 
            +
            description: 
         | 
| 56 | 
            +
            email:
         | 
| 57 | 
            +
            - kove.w.o.salter@gmail.com
         | 
| 58 | 
            +
            executables: []
         | 
| 59 | 
            +
            extensions: []
         | 
| 60 | 
            +
            extra_rdoc_files: []
         | 
| 61 | 
            +
            files:
         | 
| 62 | 
            +
            - LICENSE.txt
         | 
| 63 | 
            +
            - README.md
         | 
| 64 | 
            +
            - _layouts/default.html
         | 
| 65 | 
            +
            - assets/css/default.css
         | 
| 66 | 
            +
            - assets/js/headerbar_collapse.js
         | 
| 67 | 
            +
            - assets/js/slideshow.js
         | 
| 68 | 
            +
            - assets/js/slideshow/timer_worker.js
         | 
| 69 | 
            +
            homepage: https://github.com/Kove-W-O-Salter/mint
         | 
| 70 | 
            +
            licenses:
         | 
| 71 | 
            +
            - MIT
         | 
| 72 | 
            +
            metadata: {}
         | 
| 73 | 
            +
            post_install_message: 
         | 
| 74 | 
            +
            rdoc_options: []
         | 
| 75 | 
            +
            require_paths:
         | 
| 76 | 
            +
            - lib
         | 
| 77 | 
            +
            required_ruby_version: !ruby/object:Gem::Requirement
         | 
| 78 | 
            +
              requirements:
         | 
| 79 | 
            +
              - - ">="
         | 
| 80 | 
            +
                - !ruby/object:Gem::Version
         | 
| 81 | 
            +
                  version: '0'
         | 
| 82 | 
            +
            required_rubygems_version: !ruby/object:Gem::Requirement
         | 
| 83 | 
            +
              requirements:
         | 
| 84 | 
            +
              - - ">="
         | 
| 85 | 
            +
                - !ruby/object:Gem::Version
         | 
| 86 | 
            +
                  version: '0'
         | 
| 87 | 
            +
            requirements: []
         | 
| 88 | 
            +
            rubyforge_project: 
         | 
| 89 | 
            +
            rubygems_version: 2.7.6
         | 
| 90 | 
            +
            signing_key: 
         | 
| 91 | 
            +
            specification_version: 4
         | 
| 92 | 
            +
            summary: "(PRE RELEASE) A nice mint theme for Jekyll."
         | 
| 93 | 
            +
            test_files: []
         |