YouTube +

YouTube with more freedom

Pada tanggal 18 Agustus 2015. Lihat %(latest_version_link).

// ==UserScript==
// @version     0.5.1
// @name        YouTube +
// @namespace   https://github.com/ParticleCore
// @description YouTube with more freedom
// @icon        https://raw.githubusercontent.com/ParticleCore/Particle/gh-pages/images/YT%2Bicon.png
// @match       *://www.youtube.com/*
// @exclude     *://www.youtube.com/embed/*
// @run-at      document-start
// @grant       GM_getValue
// @grant       GM_setValue
// @noframes
// ==/UserScript==
(function () {
    "use strict";
    var userscript = typeof GM_info === "object",
        styleSheet = [
        // start| Playlist spacer
            ".part_playlist_spacer:not(.content-snap-width-skinny-mode) #watch-appbar-playlist{\n",
            "    margin-left: 0 !important;\n",
            "}\n",
        //   end| Playlist spacer
        // start| Ads visibility
            ".part_no_ads #header, .part_no_ads #feed-pyv-container, .part_no_ads .video-list-item:not(.related-list-item), .part_no_ads .pyv-afc-ads-container, .part_no_ads .ad-div{\n",
            "    display: none;\n",
            "}\n",
        //   end| Ads visibility
        // start| Hide video details
            ".part_hide_details #action-panel-details{\n",
            "    display: none;\n",
            "}\n",
        //   end| Hide video details
        // start| Disable blue glow
            ".part_dsbl_glow .yt-uix-button:focus, .yt-uix-button:focus:hover{\n",
            "    box-shadow: initial !important;\n",
            "}\n",
        //   end| Disable blue glow
        // start| Hide footer
            ".part_hide_footer #footer-container{\n",
            "    display: none;\n",
            "}\n",
            ".part_hide_footer #body-container{\n",
            "    padding-bottom: initial;\n",
            "}\n",
        //   end| Hide footer
        // start| Compact video title
            ".part_compact_title #watch7-headline #eow-title{\n",
            "    display: block;\n",
            "    overflow: hidden;\n",
            "    text-overflow: ellipsis;\n",
            "    white-space: nowrap;\n",
            "}\n",
        //   end| Compact video title
        // start| Compact thumbnail titles
            ".part_compact_titles .feed-item-container .yt-ui-ellipsis, .part_compact_titles .yt-shelf-grid-item .yt-ui-ellipsis{\n",
            "    white-space: nowrap !important;\n",
            "    display: inherit !important;\n",
            "}\n",
        //   end| Compact thumbnail titles
        // start| Floater player
            "html.floater:not([data-player-size='fullscreen']):not(.content-snap-width-skinny-mode) #player #player-api{\n",
            "    left: initial !important;\n",
            "    margin: 0 auto !important;\n",
            "    transform: none;\n",
            "}\n",
            "html.floater:not([data-player-size='fullscreen']) #player #movie_player:not(.ytp-fullscreen){\n",
            "    box-shadow: 0 0 10px rgb(0, 0, 0);\n",
            "    position: fixed !important;\n",
            "}\n",
            "html.floater:not([data-player-size='fullscreen']):not(.content-snap-width-skinny-mode) #player #movie_player:not(.ytp-fullscreen){\n",
            "    z-index: 10;\n",
            "}\n",
            "html.content-snap-width-skinny-mode.floater:not([data-player-size='fullscreen']) #player #movie_player:not(.ytp-fullscreen){\n",
            "    margin-top: 0 !important;\n",
            "    top: 51px !important;\n",
            "    transform: none;\n",
            "}\n",
            "#part_floaterui{\n",
            "    font-size: 0;\n",
            "    height: 0;\n",
            "    opacity: 0;\n",
            "    pointer-events: none;\n",
            "    position: absolute;\n",
            "    text-align: center;\n",
            "    top: 0;\n",
            "    transition: opacity 0.25s cubic-bezier(0.0, 0.0, 0.2, 1);\n",
            "    width: 100%;\n",
            "    z-index: 1000;\n",
            "}\n",
            ".floater:not([data-player-size='fullscreen']):not(.content-snap-width-skinny-mode) #movie_player:not(.ytp-fullscreen):hover #part_floaterui{\n",
            "    opacity: 1;\n",
            "    pointer-events: initial;\n",
            "}\n",
            "#part_floaterui:after{\n",
            "    box-shadow: inset 0 120px 90px -90px rgba(8, 8, 8, 0.8);\n",
            "    content: '';\n",
            "    height: 120px;\n",
            "    left: 0;\n",
            "    pointer-events: none;\n",
            "    position: absolute;\n",
            "    width: 100%;\n",
            "    z-index: -1;\n",
            "}\n",
            "#part_floaterui > button{\n",
            "    cursor: pointer;\n",
            "    height: 22px;\n",
            "    margin: 5px;\n",
            "    width: 22px;\n",
            "}\n",
            "#part_floaterui_move{\n",
            "    background: url() no-repeat center;\n",
            "}\n",
            "#part_floaterui_reset{\n",
            "    background: url() no-repeat center;\n",
            "}\n",
        //   end| Floater player
        // start| Labelless video buttons
            ".part_labelless_buttons #watch8-secondary-actions{\n",
            "    left: 0 !important;\n",
            "}\n",
            ".part_labelless_buttons #watch8-secondary-actions .yt-uix-button-content{\n",
            "    display: none;\n",
            "}\n",
            ".part_labelless_buttons #watch8-secondary-actions button{\n",
            "    padding: 0;\n",
            "}\n",
        //   end| Labelless video buttons
        // start| Hide comments
            ".part_hide_comments #watch-discussion:not(.show){\n",
            "    height: 0;\n",
            "    margin-bottom: 0;\n",
            "    margin-top: 0;\n",
            "    opacity: 0;\n",
            "    overflow: hidden;\n",
            "    padding-bottom: 0;\n",
            "    padding-top: 0;\n",
            "}\n",
            ".content-snap-width-skinny-mode.part_hide_comments #P-show-comments{\n",
            "    display: none;\n",
            "}\n",
            ".part_hide_comments #P-show-comments button{\n",
            "    border-top: none;\n",
            "    padding-top: 2px;\n",
            "}\n",
        //   end| Hide comments
        // start| Custom styles
            "#body #uploaded-videos{\n",
            "    color: #666;\n",
            "    display: initial;\n",
            "    font-size: 11px;\n",
            "    font-weight: initial;\n",
            "    overflow: initial;\n",
            "    vertical-align: initial;\n",
            "}\n",
            ".yt-user-info > span{\n",
            "    color: #666;\n",
            "    font-size: 11px;\n",
            "}\n",
            ".invisible{\n",
            "    display: none;\n",
            "}\n",
            "#subscription-playlist-icon{\n",
            "    margin-right: -20px;\n",
            "}\n",
            "#subscription-playlist:hover span{\n",
            "    opacity: 1;\n",
            "}\n",
            "#subscription-playlist span{\n",
            "    background: url() no-repeat scroll center;\n",
            "    display: block;\n",
            "    height: 100%;\n",
            "    opacity: 0.4;\n",
            "    width: 20px;\n",
            "}\n",
            "#blacklist-import, #blacklist-export{\n",
            "    margin-top: 10px;\n",
            "}\n",
            "#blacklist a{\n",
            "    font-weight: normal !important;\n",
            "}\n",
            "#blacklist a:not(:hover){\n",
            "    color: #666666;\n",
            "}\n",
            "#watch-appbar-playlist .yt-uix-button-icon-watch-appbar-reverse-video-list{\n",
            "    background: url() no-repeat;\n",
            "    height: 24px;\n",
            "    width: 24px;\n",
            "}\n",
            "#watch-appbar-playlist .yt-uix-button-icon-watch-appbar-autoplay-video-list{\n",
            "    background: url() no-repeat;\n",
            "    height: 24px;\n",
            "    width: 24px;\n",
            "}\n",
        //   end| Custom styles
        // start| Player console
            "#watch-header{\n",
            "    position: relative;\n",
            "}\n",
            ".part_fullbrowser div#movie_player.playing-mode, .part_fullbrowser div#movie_player.paused-mode{\n",
            "    bottom: 0px;\n",
            "    left: 0px;\n",
            "    position: fixed;\n",
            "    right: 0px;\n",
            "    top: 0px;\n",
            "}\n",
            ".part_fullbrowser body{\n",
            "    overflow: hidden;\n",
            "}\n",
            ".part_fullbrowser #masthead-positioner{\n",
            "    z-index: initial;\n",
            "}\n",
            "#advanced-options{\n",
            "    background: inherit;\n",
            "    min-height: 20px;\n",
            "    min-width: 25px;\n",
            "    position: absolute;\n",
            "    right: 0px;\n",
            "    top: 0px;\n",
            "}\n",
            ".part_fullbrowser #advanced-options{\n",
            "    z-index: initial;\n",
            "}\n",
            "#console-button{\n",
            "    background: url() no-repeat center;\n",
            "    cursor: pointer;\n",
            "    height: 20px;\n",
            "    opacity: 0.5;\n",
            "    position: absolute;\n",
            "    top: 0;\n",
            "    right: 0;\n",
            "    width: 25px;\n",
            "    z-index: 1;\n",
            "}\n",
            "#console-button:hover{\n",
            "    opacity: 0.8;\n",
            "}\n",
            "#player-console{\n",
            "    background: inherit;\n",
            "    display: none;\n",
            "    font-size: 0;\n",
            "    position: relative;\n",
            "    right: 2px;\n",
            "    top: 17px;\n",
            "    text-align: center;\n",
            "}\n",
            ".player-console #player-console{\n",
            "    display: block;\n",
            "}\n",
            "#player-console > div{\n",
            "    cursor: pointer;\n",
            "    height: 30px;\n",
            "    opacity: 0.4;\n",
            "    padding: 0 4px;\n",
            "    position: relative;\n",
            "}\n",
            "#player-console:before{\n",
            "    background: inherit;\n",
            "    content: '';\n",
            "    height: 100%;\n",
            "    position: absolute;\n",
            "    width: 100%;\n",
            "}\n",
            "#player-console > div.active{\n",
            "    opacity: 0.8 !important;\n",
            "}\n",
            "#player-console > div:hover{\n",
            "    opacity: 0.6;\n",
            "}\n",
            "#autoplay-button{\n",
            "    background: url() no-repeat center;\n",
            "    width: 16px;\n",
            "}\n",
            "#save-thumbnail-button{\n",
            "    background: url() no-repeat center;\n",
            "    width: 24px;\n",
            "}\n",
            "#seek-map{\n",
            "    background: url() no-repeat center;\n",
            "    width: 18px;\n",
            "}\n",
            "#screenshot-button{\n",
            "    background: url() no-repeat center;\n",
            "    width: 22px;\n",
            "}\n",
            "#sidebar-button{\n",
            "    background: url() no-repeat center;\n",
            "    width: 22px;\n",
            "}\n",
            "#loop-button{\n",
            "    background: url() no-repeat center;\n",
            "    width: 20px;\n",
            "}\n",
            "#fullbrowser-button{\n",
            "    background: url() no-repeat center;\n",
            "    width: 20px;\n",
            "}\n",
            "#cinemamode-button{\n",
            "    background: url() no-repeat center;\n",
            "    width: 20px;\n",
            "}\n",
            "#framestep-button{\n",
            "    background: url() no-repeat center;\n",
            "    width: 20px;\n",
            "}\n",
        //   end| Player console
        // start| Seek thumbs
            "#seek-thumb-map{\n",
            "    font-size: 0;\n",
            "    overflow: auto;\n",
            "    position: absolute;\n",
            "    bottom: 0;\n",
            "    width: 100%;\n",
            "    white-space: nowrap;\n",
            "    z-index: 940;\n",
            "    -moz-user-select: none;\n",
            "    -webkit-user-select: none;\n",
            "}\n",
            "#seek-controls{\n",
            "    background: rgba(0, 0, 0, 0.8);\n",
            "    border-top-left-radius: 5px;\n",
            "    border-top-right-radius: 5px;\n",
            "    bottom: 100%;\n",
            "    display: inline-block;\n",
            "    left: 50%;\n",
            "    padding: 5px 5px 0;\n",
            "    position: relative;\n",
            "    transform: translateX(-50%);\n",
            "}\n",
            "#seek-controls > div{\n",
            "    color: rgba(255,255,255, 0.4);\n",
            "    cursor: pointer;\n",
            "    font-size: 10px;\n",
            "    display: inline;\n",
            "    font-size: 10px;\n",
            "    margin: 5px;\n",
            "}\n",
            ".quality-1 .quality-1, .quality-2 .quality-2, .quality-3 .quality-3{\n",
            "    color: rgba(255,255,255, 0.7) !important;\n",
            "}\n",
            "#seek-controls > div:hover{\n",
            "    color: #F1F1F1 !important;\n",
            "}\n",
            "#seek-thumbs{\n",
            "    background: rgba(0, 0, 0, 0.8);\n",
            "    overflow: auto;\n",
            "}\n",
            "#seek-thumbs span{\n",
            "    display: inline-block;\n",
            "    margin: 10px 5px 20px;\n",
            "    position: relative;\n",
            "}\n",
            "#seek-thumbs .timer{\n",
            "    font-size: 11px;\n",
            "    line-height: 20px;\n",
            "    position: absolute;\n",
            "    text-align: center;\n",
            "    top: 100%;\n",
            "    width: 100%;\n",
            "}\n",
        //   end| Seek thumbs
        // start| Screenshot window
            "#screenshot-result{\n",
            "    bottom: 15px;\n",
            "    box-shadow: 0 0 15px #000000;\n",
            "    font-size: 0;\n",
            "    margin: 5px;\n",
            "    max-height: calc(100% - 90px);\n",
            "    max-width: 420px;\n",
            "    overflow: hidden;\n",
            "    position: fixed;\n",
            "    right: 15px;\n",
            "    width: 30%;\n",
            "    z-index: 1000;\n",
            "}\n",
            "#screenshot-result > canvas{\n",
            "    width: 100%;\n",
            "}\n",
            "#close-screenshot{\n",
            "    background: rgba(0, 0, 0, 0.5);\n",
            "    border-top-left-radius: 5px;\n",
            "    color: #F1F1F1;\n",
            "    cursor: pointer;\n",
            "    font-size: 10px;\n",
            "    padding: 5px;\n",
            "    position: absolute;\n",
            "    right: 0;\n",
            "    text-transform: uppercase;\n",
            "    bottom: 0;\n",
            "}\n",
            "#close-screenshot:hover{\n",
            "    background: rgba(0, 0, 0, 0.8);\n",
            "}\n",
        //   end| Screenshot window
        // start| Sidebar mode
            ".yt-pl-thumb .sidebarmode, .thumb-wrapper .sidebarmode, .yt-lockup-thumbnail .sidebarmode{\n",
            "    background: url() #FFF no-repeat center;\n",
            "    bottom: 0;\n",
            "    color: #666;\n",
            "    cursor: pointer;\n",
            "    display: none;\n",
            "    font-size: 12px;\n",
            "    height: 17px;\n",
            "    left: 0;\n",
            "    line-height: 1;\n",
            "    position: absolute;\n",
            "    width: 17px;\n",
            "}\n",
        //   end| Sidebar mode
        // start| Thumb buttons
            ".yt-pl-thumb .blacklist, .thumb-wrapper .blacklist, .yt-lockup-thumbnail .blacklist{\n",
            "    background: url() #FFF no-repeat center / contain;\n",
            "    color: #666;\n",
            "    cursor: pointer;\n",
            "    display: none;\n",
            "    font-size: 12px;\n",
            "    height: 17px;\n",
            "    line-height: 1;\n",
            "    position: absolute;\n",
            "    right: 0;\n",
            "    top: 0;\n",
            "    width: 17px;\n",
            "}\n",
            ".thumb-wrapper:hover .blacklist, .yt-lockup-thumbnail:hover .blacklist, .yt-pl-thumb:hover .blacklist, .yt-pl-thumb:hover .sidebarmode, .thumb-wrapper:hover .sidebarmode, .yt-lockup-thumbnail:hover .sidebarmode{\n",
            "    display: initial;\n",
            "}\n",
        //   end| Thumb buttons
        // start| Grid layout
            ".part_grid_subs .feed-item-container .branded-page-module-title, .part_grid_subs .feed-item-container .yt-lockup-description, .part_grid_search #results .yt-lockup-description{\n",
            "    display: none !important;\n",
            "    height: 0 !important;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary, .part_grid_search #results {\n",
            "    font-size: 0;\n",
            "    margin-right: -15px;\n",
            "    padding: 15px;\n",
            "    padding-right: 0;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary .section-list > li, .part_grid_search #results .item-section > li{\n",
            "    display: inline-block;\n",
            "    margin-bottom: 20px;\n",
            "    margin-right: 10px;\n",
            "    vertical-align: top;\n",
            "    width: 196px;\n",
            "    word-wrap: break-word;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary .expanded-shelf-content-item{\n",
            "    margin-bottom: initial;\n",
            "    margin-right: initial;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary .item-section .feed-item-container, .part_grid_search #results .item-section > li .yt-lockup{\n",
            "    border: initial;\n",
            "    padding: initial;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary .item-section .feed-item-container .menu-container{\n",
            "    left: initial;\n",
            "    opacity: 0;\n",
            "    position: absolute;\n",
            "    right: -9px !important;\n",
            "    width: 20px;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary .item-section .feed-item-container:hover .menu-container{\n",
            "    opacity: 1;\n",
            "}\n",
            ".part_grid_subs .shelf-item .shelf-title-table{\n",
            "    position: absolute;\n",
            "    top: 110px;\n",
            "    z-index: 1;\n",
            "}\n",
            ".part_grid_subs .shelf-title-table ul, .part_grid_subs .shelf-title-table iframe{\n",
            "    left: initial !important;\n",
            "    right: 20px !important;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary .yt-lockup-thumbnail, .part_grid_search #results .yt-lockup-thumbnail{\n",
            "    float: initial !important;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary .yt-lockup-meta, .part_grid_subs div#browse-items-primary .yt-lockup-byline, .part_grid_search #results .yt-lockup-meta{\n",
            "    font-size: 11px;\n",
            "    max-width: 196px;\n",
            "}\n",
            ".part_grid_subs div#browse-items-primary .yt-lockup-title, .part_grid_subs div#browse-items-primary .feed-item-dismissal, .part_grid_search #results .yt-lockup-title{\n",
            "    font-size: 13px;\n",
            "    margin-top: 4px;\n",
            "    margin-bottom: 1px;\n",
            "    max-width: 176px;\n",
            "}\n",
            ".part_grid_search.part_compact_titles  #results .yt-lockup-title a{\n",
            "    white-space: nowrap;\n",
            "}\n",
            ".part_grid_search #results .yt-lockup-playlist-items, .part_grid_search #results .yt-lockup-badges, .part_grid_subs .yt-lockup-badges, .part_grid_subs .yt-uix-livereminder, .part_grid_search .yt-uix-livereminder, .part_grid_search #results .exploratory-section, .part_grid_search #results .compact-shelf{\n",
            "    display: none;\n",
            "}\n",
            ".part_grid_subs .yt-lockup-meta-info > li, .part_grid_search .yt-lockup-meta-info > li{\n",
            "    display: inline;\n",
            "}\n",
            ".part_grid_search #results .item-section{\n",
            "    float: left;\n",
            "}\n",
            ".part_grid_search .search .branded-page-v2-body{\n",
            "    overflow: hidden;\n",
            "}\n",
            ".part_grid_search .webkit #results .yt-ui-ellipsis{\n",
            "    display: block;\n",
            "}\n",
        //   end| Grid layout
        // start| Enhancements
            ":focus{\n",
            "    outline: none;\n",
            "}\n",
            ":-moz-focus-inner{\n",
            "    border: 0;\n",
            "}\n",
            "input[type='checkbox'], input[type='radio']{\n",
            "    opacity: 0;\n",
            "}\n",
            ".signin-container{\n",
            "    margin-right: 10px;\n",
            "}\n",
            "#body-container{\n",
            "    position: relative;\n",
            "}\n",
            "#logo-container{\n",
            "    height: 33px;\n",
            "}\n",
            ".branded-page-related-channels-item .yt-close{\n",
            "    z-index: 1;\n",
            "}\n",
            ".show-guide #appbar-guide-menu{\n",
            "    border-bottom: 1px solid #E8E8E8;\n",
            "    border-right: 1px solid #E8E8E8;\n",
            "    box-shadow: none;\n",
            "}\n",
            "#movie_player:not(.ended-mode) .html5-progress-bar, #movie_player:not(.ended-mode) video{\n",
            "    left: initial !important;\n",
            "    max-height: 100%;\n",
            "    max-width: 100%;\n",
            "    min-height: 100%;\n",
            "    min-width: 100%;\n",
            "    position: initial;\n",
            "    top: initial !important;\n",
            "}\n",
            ".search #content{\n",
            "    max-width: 1003px;\n",
            "    width: initial;\n",
            "}\n",
            ".ideal-aspect .html5-player-chrome{\n",
            "    background: rgba(27, 27, 27, .9) !important;\n",
            "}\n",
            ".ideal-aspect.light-theme .html5-player-chrome{\n",
            "    background: rgba(204, 204, 204, .9) !important;\n",
            "}\n",
            "#theater-background, #watch7-sidebar, #watch-appbar-playlist{\n",
            "    transition: none !important;\n",
            "}\n",
            "html.content-snap-width-skinny-mode #masthead-positioner-height-offset{\n",
            "    height: 51px;\n",
            "}\n",
            ".part_fit_theater .watch-stage-mode #theater-background, .part_hide_controls.part_fit_theater .watch-stage-mode #theater-background{\n",
            "    bottom: 0;\n",
            "    height: initial !important;\n",
            "    top: 0;\n",
            "}\n",
            "#footer-container{\n",
            "    max-width: initial;\n",
            "}\n",
            ".content-snap-width-skinny-mode #theater-background, .content-snap-width-skinny-mode #footer-container{\n",
            "    display: none;\n",
            "}\n",
            ".content-snap-width-skinny-mode #player-playlist{\n",
            "    margin-top: 10px;\n",
            "}\n",
            ".content-snap-width-skinny-mode #player, .content-snap-width-skinny-mode #content, .content-snap-width-skinny-mode #watch-appbar-playlist{\n",
            "    top: 0 !important;\n",
            "}\n",
            ".content-snap-width-skinny-mode #player-playlist, .content-snap-width-skinny-mode #watch-appbar-playlist{\n",
            "    margin-bottom: 0;\n",
            "}\n",
            "#page.watch .content-alignment, .watch.watch-non-stage-mode #player.content-alignment, .yt-base-gutter, .watch #content.content-alignment, .watch.watch-non-stage-mode #player.content-alignment, .watch.watch-stage-mode #player-playlist.watch-player-playlist{\n",
            "   min-width: 0;\n",
            "}\n",
            ".content-snap-width-skinny-mode .ytp-size-toggle-large, .content-snap-width-skinny-mode .ytp-size-toggle-small{\n",
            "   display: none !important;\n",
            "}\n",
            ".html5-video-container{\n",
            "   height: 100%;\n",
            "}\n",
            ".part_grid_subs #browse-items-primary .item-section > li > .yt-lockup-tile, .part_grid_subs #browse-items-primary .item-section > li > .multirow-shelf, .part_grid_subs .browse-list-item-container.feed-item-container.branded-page-box, .part_grid_subs .compact-shelf.branded-page-box, .part_grid_subs .c4-featured-content.branded-page-box{\n",
            "   width: initial;\n",
            "}\n",
            ".ytp-thumbnail-overlay, .ytp-large-play-button{\n",
            "   transition-delay: initial !important;\n",
            "}\n",
            "#movie_player .video-ads{\n",
            "   position: absolute;\n",
            "   top: 0;\n",
            "}\n",
        //   end| Enhancements
        // start| Improved notification button
            ".part_notif_button #appbar-main-guide-notification-container{\n",
            "    box-shadow: 0 1px 2px #eee inset;\n",
            "    display: inline-block;\n",
            "    top: 1px !important;\n",
            "    left: auto !important;\n",
            "    margin-left: 79px !important;\n",
            "    opacity: 0;\n",
            "    overflow: hidden !important;\n",
            "    position: absolute !important;\n",
            "    visibility: hidden;\n",
            "    width: auto;\n",
            "    z-index: 1;\n",
            "}\n",
            ".part_notif_button #appbar-main-guide-notification-container .appbar-guide-notification{\n",
            "    height: 27px !important;\n",
            "}\n",
            ".part_notif_button .show-guide-button-notification #appbar-main-guide-notification-container{\n",
            "    visibility: visible;\n",
            "    opacity: 1;\n",
            "}\n",
            ".part_notif_button #appbar-main-guide-notification-container{\n",
            "    transition: visibility .3s linear .1s, opacity .3s linear .1s;\n",
            "}\n",
            ".part_notif_button #appbar-guide-button-notification-check{\n",
            "    display: none !important;\n",
            "}\n",
            ".part_notif_button .show-guide-button-notification #appbar-guide-button{\n",
            "    opacity: 1 !important;\n",
            "}\n",
            ".part_notif_button #yt-masthead #logo-container span.content-region{\n",
            "    left: initial;\n",
            "    padding: 1px 0 0 3px;\n",
            "    position: absolute;\n",
            "    top: initial;\n",
            "}\n",
        //   end| Improved notification button
        // start| Static normal mode
            ".part_static_size:not(.content-snap-width-skinny-mode) .watch-non-stage-mode .player-width, .part_static_size:not(.content-snap-width-skinny-mode) .watch-non-stage-mode #watch7-content{\n",
            "    width: 640px;\n",
            "}\n",
            ".part_static_size:not(.content-snap-width-skinny-mode) .watch-non-stage-mode .player-height{\n",
            "    height: 390px;\n",
            "}\n",
            ".part_static_size:not(.content-snap-width-skinny-mode) .watch-non-stage-mode .player-height{\n",
            "    height: 360px;\n",
            "}\n",
            ".part_static_size:not(.content-snap-width-skinny-mode) .watch-non-stage-mode #watch7-sidebar{\n",
            "    margin-left: 650px;\n",
            "    top: 0;\n",
            "}\n",
            ".part_static_size:not(.content-snap-width-skinny-mode) .watch.watch-non-stage-mode #content.content-alignment, .part_static_size:not(.content-snap-width-skinny-mode) .watch.watch-non-stage-mode #player.content-alignment{\n",
            "    max-width: 1066px;\n",
            "}\n",
            ".part_static_size:not(.content-snap-width-skinny-mode) .watch-non-stage-mode #watch-appbar-playlist{\n",
            "    left: 650px;\n",
            "}\n",
        //   end| Static normal mode
        // start| Fit player in theater mode
            ".part_fit_theater .watch-stage-mode #player-api, .content-snap-width-skinny-mode #player-api{\n",
            "    height: auto !important;\n",
            "    left: 0 !important;\n",
            "    margin: 0 auto !important;\n",
            "    max-width: 1280px;\n",
            "    position: relative;\n",
            "    right: 0;\n",
            "    width: 100%;\n",
            "}\n",
            ".part_fit_theater .watch-stage-mode #player-api:before, .content-snap-width-skinny-mode #player-api:before{\n",
            "    content: '';\n",
            "    display: block;\n",
            "    padding-top: calc(56.25%);\n",
            "}\n",
            ".part_fit_theater .watch-stage-mode #movie_player, .content-snap-width-skinny-mode #movie_player{\n",
            "    bottom: 0;\n",
            "    left: 0;\n",
            "    position: absolute;\n",
            "    right: 0;\n",
            "    top: 0;\n",
            "}\n",
            ".part_fit_theater .watch-stage-mode #placeholder-player, .content-snap-width-skinny-mode #placeholder-player{\n",
            "    display: none;\n",
            "}\n",
            ".part_fit_theater .watch-stage-mode #watch-appbar-playlist{\n",
            "    top: 10px;\n",
            "}\n",
            ".part_fit_theater .watch-stage-mode #watch-appbar-playlist, .content-snap-width-skinny-mode #watch-appbar-playlist{\n",
            "    transform: none !important;\n",
            "}\n",
            ".part_fit_theater .watch-stage-mode #content, .content-snap-width-skinny-mode #content{\n",
            "    margin-top: 10px;\n",
            "}\n",
        //   end| Fit player in theater mode
        // start| Cinema mode
            "#movie_player:before, #masthead-positioner:before{\n",
            "    bottom: 0;\n",
            "    content: '';\n",
            "    left: 0;\n",
            "    pointer-events: none;\n",
            "    position: fixed;\n",
            "    right: 0;\n",
            "    top: 0;\n",
            "    transition: background-color 1s;\n",
            "    z-index: 1;\n",
            "}\n",
            ".part_cinema_mode #movie_player:before, .part_cinema_mode #masthead-positioner:before{\n",
            "    background-color: rgba(0, 0, 0, 0.9);\n",
            "}\n",
            ".part_cinema_mode .html5-video-player{\n",
            "    overflow: initial;\n",
            "}\n",
        //   end| Cinema mode
        // start| Particle settings
            "#P-settings{\n",
            "    background: #f1f1f1;\n",
            "    height: 100%;\n",
            "    left: 0;\n",
            "    position: absolute;\n",
            "    right: 0;\n",
            "    z-index: 1000;\n",
            "}\n",
            "#P-container{\n",
            "    margin: 10px auto 0;\n",
            "    max-width: 1262px;\n",
            "}\n",
            ".guide-pinned.show-guide .guide-pinning-enabled #P-container{\n",
            "    padding-left: 230px;\n",
            "}\n",
            "#P-sidebar, #P-content{\n",
            "    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);\n",
            "    box-sizing: border-box;\n",
            "}\n",
            "#P-sidebar{\n",
            "    background: #1e1e1e;\n",
            "    color: grey;\n",
            "    float: left;\n",
            "    width: 195px;\n",
            "    margin-right: 10px;\n",
            "    padding: 10px 0;\n",
            "}\n",
            "#P-sidebar-list > li{\n",
            "    color: grey;\n",
            "    padding: 0 21px;\n",
            "    cursor: pointer;\n",
            "    font-size: 11px;\n",
            "    line-height: 24px;\n",
            "}\n",
            "#P-sidebar-list > li:hover{\n",
            "    color: #1e1e1e;\n",
            "    background: #f6f6f6;\n",
            "}\n",
            "#P-sidebar-list > li.selected{\n",
            "    color: #FFF;\n",
            "    font-weight: 500;\n",
            "    background-color: #CC181E;\n",
            "}\n",
            "#P-content{\n",
            "    background: #FFF;\n",
            "    color: #666;\n",
            "    overflow: hidden;\n",
            "    padding-bottom: 40px;\n",
            "    padding-left: 15px;\n",
            "    position: relative;\n",
            "    margin-bottom: 10px;\n",
            "}\n",
            "#P-content h2{\n",
            "    color: #333;\n",
            "    float: left;\n",
            "    font-size: 18px;\n",
            "    font-weight: 500;\n",
            "}\n",
            "#P-content h3{\n",
            "    color: #555;\n",
            "    font-size: 14px;\n",
            "    font-weight: 500;\n",
            "    margin: 30px 0 16px;\n",
            "}\n",
            "#P-content br{\n",
            "    clear: both;\n",
            "}\n",
            "#P-content div{\n",
            "    display: block;\n",
            "    line-height: 26px;\n",
            "    overflow: hidden;\n",
            "    position: relative;\n",
            "}\n",
            "#P-content div:first-child{\n",
            "    overflow: initial;\n",
            "}\n",
            "#P-content div a{\n",
            "    font-weight: 500;\n",
            "    opacity: 0;\n",
            "}\n",
            "#P-content div:hover a, #P-content div a:not([title]){\n",
            "    opacity: 1;\n",
            "}\n",
            "#P-content label{\n",
            "    line-height: 26px;\n",
            "}\n",
            "#P-content input{\n",
            "    display: none;\n",
            "    margin-left: 25px;\n",
            "}\n",
            "#P-content input + label{\n",
            "    position: relative;\n",
            "    margin-left: 25px;\n",
            "}\n",
            "#P-content input + label:before{\n",
            "    cursor: pointer;\n",
            "    border: 1px solid #c6c6c6;\n",
            "    content: '';\n",
            "    left: -25px;\n",
            "    height: 14px;\n",
            "    position: absolute;\n",
            "    top: 5px;\n",
            "    width: 14px;\n",
            "}\n",
            "#P-content input:checked + label:before{\n",
            "    border: 1px solid #36649c;\n",
            "}\n",
            "#P-content input[type='text']{\n",
            "    position: relative;\n",
            "    display: initial;\n",
            "    margin-left: 5px;\n",
            "}\n",
            "#P-content input[type='text'] + label{\n",
            "    float: left;\n",
            "    margin-left: 0;\n",
            "}\n",
            "#P-content input[type='text'] + label:before{\n",
            "    display: none;\n",
            "}\n",
            "#P-content input[type='radio'] + label{\n",
            "    display: inline-block;\n",
            "}\n",
            "#P-content input[type='radio'] + label:before{\n",
            "    border-radius: 50%;\n",
            "    left: -20px;\n",
            "}\n",
            "#P-content input[type='checkbox'] + label{\n",
            "    display: inline-block;\n",
            "}\n",
            "#P-content input[type='checkbox']:checked + label:before{\n",
            "    background: url() no-repeat 2px 1px;\n",
            "}\n",
            "#P-content input[type='radio']:checked + label:before{\n",
            "    background: url() no-repeat 3px;\n",
            "}\n",
            "#P-content select{\n",
            "    background-image: linear-gradient(#FCFCFC, #F8F8F8);\n",
            "    border: 1px solid #d3d3d3;\n",
            "    color: #333 !important;\n",
            "    cursor: pointer;\n",
            "    font-family: arial,sans-serif;\n",
            "    font-size: 11px;\n",
            "    font-weight: bold;\n",
            "    height: 26px;\n",
            "    margin-left: 5px;\n",
            "    padding: 0 2em 0 1em;\n",
            "    text-shadow: none;\n",
            "    -moz-appearance: none;\n",
            "    -webkit-appearance: none;\n",
            "}\n",
            "#P-content select option{\n",
            "    padding: 0 1em;\n",
            "}\n",
            ".P-header{\n",
            "    height: 20px;\n",
            "    margin: 0;\n",
            "    padding: 24px 0 0;\n",
            "}\n",
            ".P-save, .P-reset, .P-impexp{\n",
            "    background: #167AC6;\n",
            "    border-color: #167AC6;\n",
            "    border-radius: 2px;\n",
            "    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.05);\n",
            "    color: #fff;\n",
            "    cursor: pointer;\n",
            "    display: inline-block;\n",
            "    float: right;\n",
            "    font-size: 11px;\n",
            "    font-weight: 500;\n",
            "    height: 28px;\n",
            "    line-height: normal;\n",
            "    margin-right: 20px;\n",
            "    margin-top: -5px;\n",
            "    outline: 0 none;\n",
            "    padding: 0 20px;\n",
            "    vertical-align: middle;\n",
            "    white-space: nowrap;\n",
            "    word-wrap: normal;\n",
            "}\n",
            ".P-impexp{\n",
            "    background: url() #FFF no-repeat center;\n",
            "    border: 1px solid transparent;\n",
            "    box-shadow: none;\n",
            "    opacity: 0.5;\n",
            "    padding: 0 13px;\n",
            "}\n",
            ".P-reset, .P-impexp:hover{\n",
            "    background-color: #F8F8F8;\n",
            "    border: 1px solid #D3D3D3;\n",
            "    box-shadow: 0 1px 0 rgba(0, 0, 0, 0.05);\n",
            "    opacity: 1;\n",
            "    color: #333;\n",
            "}\n",
            ".P-reset:hover{\n",
            "    background: #F0F0F0;\n",
            "    border-color: #C6C6C6;\n",
            "}\n",
            ".P-reset:active{\n",
            "    background: #E9E9E9;\n",
            "}\n",
            ".P-save:hover{\n",
            "    background: #126DB3;\n",
            "}\n",
            ".P-save:active{\n",
            "    background: #095B99;\n",
            "}\n",
            ".P-horz{\n",
            "    border-bottom: 0 none;\n",
            "    border-top: 1px solid #e2e2e2;\n",
            "    height: 0;\n",
            "    margin: 20px 0 0 -15px;\n",
            "    position: relative;\n",
            "}\n",
            "#P-settings select{\n",
            "    color: transparent !important;\n",
            "    text-shadow: 0 0 0 #333;\n",
            "}\n",
            "#P-settings .P-select{\n",
            "    display: inline;\n",
            "    position: relative;\n",
            "}\n",
            "#P-settings .P-select:after{\n",
            "    content: '';\n",
            "    border: 1px solid transparent;\n",
            "    border-width: 4px 4px 0;\n",
            "    border-top-color: #666;\n",
            "    pointer-events: none;\n",
            "    position: absolute;\n",
            "    right: 10px;\n",
            "    top: 50%;\n",
            "}\n",
            "#P-settings option{\n",
            "    color: #000;\n",
            "    text-shadow: none;\n",
            "}\n",
            "#P::-moz-focus-inner, #P-settings button::-moz-focus-inner{\n",
            "    border: 0;\n",
            "    padding: 0;\n",
            "}\n",
            "#P-sidebar-list a{\n",
            "    color: #808080;\n",
            "    display: block;\n",
            "    padding: 0 21px;\n",
            "    text-decoration: none;\n",
            "}\n",
            "#P-sidebar-list #HLP a:hover{\n",
            "    color: #1E1E1E;\n",
            "}\n",
            "#exp-cont{\n",
            "    background-color: #FFF;\n",
            "    bottom: 0;\n",
            "    position: absolute !important;\n",
            "    top: 80px;\n",
            "    width: calc(100% - 30px);\n",
            "}\n",
            "#DNT, #HLP{\n",
            "    padding: 0 !important;\n",
            "}\n",
            "#DNT{\n",
            "    position: relative;\n",
            "}\n",
            "#DNT:hover a{\n",
            "    color: #F1F1F1;\n",
            "}\n",
            "#DNT:hover:after{\n",
            "    background: url() no-repeat center / contain;\n",
            "    content: '';\n",
            "    height: 18px;\n",
            "    margin-top: -9px;\n",
            "    position: absolute;\n",
            "    right: 10px;\n",
            "    top: 50%;\n",
            "    width: 15px;\n",
            "}\n",
            "#DNT:hover{\n",
            "    background: linear-gradient(to right, #167AC6 50%, #F6F6F6) !important;\n",
            "}\n",
            "#blacklist{\n",
            "    margin: 10px 15px 0 0;\n",
            "}\n",
            "#blacklist-controls{\n",
            "    margin-bottom: 10px;\n",
            "}\n",
            "#blacklist .blacklist{\n",
            "    border: 1px solid #C6C6C6;\n",
            "    cursor: default;\n",
            "    display: inline-block;\n",
            "    overflow: hidden !important;\n",
            "    padding: 0 10px;\n",
            "    position: relative;\n",
            "}\n",
            "#blacklist .blacklist .close{\n",
            "    background: url() #FFF no-repeat center / contain;\n",
            "    border: 1px solid #C6C6C6;\n",
            "    border-left: none;\n",
            "    border-top: none;\n",
            "    color: #666;\n",
            "    cursor: pointer;\n",
            "    display: none;\n",
            "    height: 17px;\n",
            "    font-size: 10px;\n",
            "    font-weight: 500;\n",
            "    position: absolute;\n",
            "    left: 0;\n",
            "    top: 0;\n",
            "    width: 17px;\n",
            "}\n",
            "#blacklist .blacklist:hover .close{\n",
            "    display: initial;\n",
            "}\n",
            "#blacklist-edit span, #blacklist-save span, #blacklist-close span{\n",
            "    pointer-events: none;\n",
            "}\n",
            "#blacklist.edit .blacklist, #blacklist.edit #blacklist-edit, #blacklist:not(.edit) #blacklist-save, #blacklist:not(.edit) #blacklist-close, #blacklist:not(.edit) #blacklist-edit-list{\n",
            "    display: none;\n",
            "}\n",
            "#blacklist-edit-list, #impexp-list{\n",
            "    font-family: Consolas, Lucida Console, monospace;\n",
            "    height: 200px;\n",
            "    width: calc(100% - 10px);\n",
            "}\n",
            "#impexp-save{\n",
            "    margin-bottom: 10px;\n",
            "}\n",
            "#impexp-save span{\n",
            "    pointer-events: none;\n",
            "}\n",
            "#impexp-list{\n",
            "    height: calc(100% - 80px);\n",
            "}\n",
            "#P{\n",
            "    background: url() no-repeat 0 4px;\n",
            "    cursor: pointer;\n",
            "    height: 28px;\n",
            "    margin-right: 10px;\n",
            "    opacity: 0.55;\n",
            "    vertical-align: middle;\n",
            "    width: 19px;\n",
            "}\n",
            ".content-snap-width-skinny-mode #P{\n",
            "    display: none;\n",
            "}\n",
            "#P:hover{\n",
            "    opacity: 0.85;\n",
            "}\n",
            ".P-hide{\n",
            "    display: none;\n",
            "}\n"
        //   end| Particle settings
        ].join('');
    function particle() {
        var api,
            parSets,
            playerInstance,
            events    = [],
            channelId = {},
            isChrome  = typeof window.chrome === "object",
            defSets   = {
                GEN_BTTR_NTF     : true,
                GEN_SUB_LIST     : true,
                GEN_INF_SCRL     : true,
                GEN_YT_LOGO_LINK : true,
                GEN_CMPT_TTLS    : true,
                GEN_BLUE_GLOW    : true,
                GEN_CHN_DFLT_PAGE: "videos",
                GEN_SDBR_ON      : true,
                VID_END_SHRE     : true,
                VID_DFLT_QLTY    : "auto",
                VID_PLST_SEP     : true,
                VID_PLST_ATPL    : true,
                VID_PLST_RVRS    : true,
                VID_PLR_ANTS     : true,
                VID_PLR_ALVIS    : true,
                VID_PLR_ADS      : true,
                VID_PLR_SIZE_MEM : true,
                VID_PLR_DYN_SIZE : true,
                VID_PLR_FIT_WDTH : "1280px",
                VID_HIDE_COMS    : "1",
                VID_POST_TIME    : true,
                VID_VID_CNT      : true,
                VID_DESC_SHRT    : true,
                VID_SDBR_ALGN    : "1",
                VID_TTL_CMPT     : true,
                BLK_ON           : true,
                volLev           : 50,
                plApl            : false,
                plRev            : false,
                advOpts          : true,
                blacklist        : {}
            },
            lang      = {
                ADV_OPTS              : {
                    en     : "Advanced options",
                    "pt-PT": "Opções avançadas"
                },
                SUB_PLST              : {
                    en     : "Play recent uploads",
                    "pt-PT": "Reproduzir vídeos recentes"
                },
                GEN_SDBR_ON           : {
                    en     : "Enable sidebar mode",
                    "pt-PT": "Activar modo barra lateral"
                },
                SDBR_OPEN             : {
                    en     : "Open in sidebar",
                    "pt-PT": "Abrir barra lateral"
                },
                BLCK_ADD              : {
                    en     : "Add to blacklist",
                    "pt-PT": "Adicionar à lista negra"
                },
                BLCK_EDIT             : {
                    en     : "Edit",
                    "pt-PT": "Editar"
                },
                BLCK_SAVE             : {
                    en     : "Save",
                    "pt-PT": "Guardar"
                },
                BLCK_CLSE             : {
                    en     : "Close",
                    "pt-PT": "Fechar"
                },
                CNSL_CNSL             : {
                    en     : "Console",
                    "pt-PT": "Consola"
                },
                CNSL_AP               : {
                    en     : "Autoplay",
                    "pt-PT": "Início automático"
                },
                CNSL_RPT              : {
                    en     : "Repeat video",
                    "pt-PT": "Repetir vídeo"
                },
                CNSL_SKMP             : {
                    en     : "Seek map",
                    "pt-PT": "Mapa de procura"
                },
                CNSL_SKMP_OFF         : {
                    en     : "No thumbs found",
                    "pt-PT": "Não existem imagens"
                },
                CNSL_SKMP_SMAL        : {
                    en     : "SMALL",
                    "pt-PT": "PEQUENO"
                },
                CNSL_SKMP_MED         : {
                    en     : "MEDIUM",
                    "pt-PT": "MÉDIO"
                },
                CNSL_SKMP_LRGE        : {
                    en     : "LARGE",
                    "pt-PT": "GRANDE"
                },
                CNSL_SVTH             : {
                    en     : "Open thumbnail",
                    "pt-PT": "Abrir imagem de fundo"
                },
                CNSL_SS               : {
                    en     : "Take screenshot",
                    "pt-PT": "Capturar imagem"
                },
                CNSL_SS_CLS           : {
                    en     : "CLOSE",
                    "pt-PT": "FECHAR"
                },
                CNSL_SDBR             : {
                    en     : "Sidebar mode",
                    "pt-PT": "Modo barra lateral"
                },
                CNSL_FLBR             : {
                    en     : "Fullbrowser mode",
                    "pt-PT": "Modo navegador inteiro"
                },
                CNSL_CINM_MD          : {
                    en     : "Cinema mode",
                    "pt-PT": "Modo cinema"
                },
                CNSL_FRME             : {
                    en     : "Frame by frame",
                    "pt-PT": "Quadro a quadro"
                },
                PLST_AP               : {
                    en     : "Autoplay",
                    "pt-PT": "Início automático"
                },
                PLST_RVRS             : {
                    en     : "Reverse",
                    "pt-PT": "Inverter"
                },
                SHOW_CMTS             : {
                    en     : "Show comments",
                    "pt-PT": "Mostrar comentários"
                },
                HIDE_CMTS             : {
                    en     : "Hide comments",
                    "pt-PT": "Esconder comentários"
                },
                GLB_IMPR              : {
                    en     : "Import/export settings",
                    "pt-PT": "Importar/exportar definições"
                },
                GLB_IMPR_SAVE         : {
                    en     : "Save and load",
                    "pt-PT": "Guardar e carregar"
                },
                GLB_RSET              : {
                    en     : "Reset",
                    "pt-PT": "Repor"
                },
                GLB_SVE               : {
                    en     : "Save",
                    "pt-PT": "Guardar"
                },
                FTR_DESC              : {
                    en     : "Find out what this does",
                    "pt-PT": "Descubra o que isto faz"
                },
                GEN                   : {
                    en     : "General",
                    "pt-PT": "Geral"
                },
                VID                   : {
                    en     : "Video",
                    "pt-PT": "Vídeo"
                },
                CHN                   : {
                    en     : "Channels",
                    "pt-PT": "Canais"
                },
                BLK                   : {
                    en     : "Blacklist",
                    "pt-PT": "Lista negra"
                },
                ABT                   : {
                    en     : "About",
                    "pt-PT": "Sobre"
                },
                HLP                   : {
                    en     : "Help",
                    "pt-PT": "Ajuda"
                },
                DNT                   : {
                    en     : "Donate",
                    "pt-PT": "Doação"
                },
                GEN_TTL               : {
                    en     : "General settings",
                    "pt-PT": "Definições gerais"
                },
                GEN_GEN               : {
                    en     : "General",
                    "pt-PT": "Geral"
                },
                GEN_LYT               : {
                    en     : "Layout",
                    "pt-PT": "Aparência"
                },
                GEN_DSBL_ADS          : {
                    en     : "Disable advertisements outside the video page",
                    "pt-PT": "Desactivar publicidades fora da página de vídeo"
                },
                GEN_INF_SCRL          : {
                    en     : "Enable infinite scroll in feeds",
                    "pt-PT": "Activar scroll infinito em feeds"
                },
                GEN_YT_LOGO_LINK      : {
                    en     : "YouTube logo redirects to subscriptions",
                    "pt-PT": "Logotipo do Youtube redirecciona para as subscrições"
                },
                GEN_SUB_LIST          : {
                    en     : "Enable subscription playlist",
                    "pt-PT": "Activar lista de reprodução de subscrições"
                },
                GEN_REM_APUN          : {
                    en     : "Remove autoplay up next",
                    "pt-PT": "Remover reprodução automática do vídeo a seguir"
                },
                GEN_SPF_OFF           : {
                    en     : "Disable SPF",
                    "pt-PT": "Desactivar SPF"
                },
                GEN_HIDE_FTR          : {
                    en     : "Hide footer",
                    "pt-PT": "Esconder rodapé"
                },
                GEN_BLUE_GLOW         : {
                    en     : "Remove blue glow around clicked buttons",
                    "pt-PT": "Retirar brilho azul em torno dos botões clicados"
                },
                GEN_HDE_RECM_SDBR     : {
                    en     : "Hide recommended channels sidebar",
                    "pt-PT": "Esconder barra lateral de canais recomendados"
                },
                GEN_HDE_SRCH_SDBR     : {
                    en     : "Hide search results sidebar",
                    "pt-PT": "Esconder barra lateral nos resultados de pesquisa"
                },
                GEN_HDE_CHN_SDBR      : {
                    en     : "Hide channel sidebar",
                    "pt-PT": "Esconder barra lateral dos canais"
                },
                GEN_CMPT_TTLS         : {
                    en     : "Compact titles in feeds",
                    "pt-PT": "Títulos compactos nas listas"
                },
                GEN_DSB_HVRC          : {
                    en     : "Disable hovercards",
                    "pt-PT": "Desactivar hovercards"
                },
                GEN_BTTR_NTF          : {
                    en     : "Improved blue notification box",
                    "pt-PT": "Caixa de notificação azul melhorada"
                },
                GEN_GRID_SUBS         : {
                    en     : "Grid layout in subscriptions",
                    "pt-PT": "Subscrições em formato grelha"
                },
                GEN_GRID_SRCH         : {
                    en     : "Grid layout in search results",
                    "pt-PT": "Resultados de pesquisa em formato grelha"
                },
                VID_TTL               : {
                    en     : "Video settings",
                    "pt-PT": "Definições de vídeo"
                },
                VID_PLR               : {
                    en     : "Player settings",
                    "pt-PT": "Definições do reproductor"
                },
                VID_PLR_LYT           : {
                    en     : "Player layout",
                    "pt-PT": "Aspecto do reproductor"
                },
                VID_DFLT_QLTY         : {
                    en     : "Default video quality:",
                    "pt-PT": "Qualidade de vídeo padrão:"
                },
                VID_DFLT_QLTY_AUTO    : {
                    en     : "Auto",
                    "pt-PT": "Auto"
                },
                VID_DFLT_QLTY_TNY     : {
                    en: "144p"
                },
                VID_DFLT_QLTY_SML     : {
                    en: "240p"
                },
                VID_DFLT_QLTY_MDM     : {
                    en: "360p"
                },
                VID_DFLT_QLTY_LRG     : {
                    en: "480p"
                },
                VID_DFLT_QLTY_720     : {
                    en: "720p"
                },
                VID_DFLT_QLTY_1080    : {
                    en: "1080p"
                },
                VID_DFLT_QLTY_1440    : {
                    en: "1440p"
                },
                VID_DFLT_QLTY_ORIG    : {
                    en: "2160p"
                },
                VID_PLR_ALVIS         : {
                    en     : "Player always visible when reading comments",
                    "pt-PT": "Reproductor sempre visível ao ler os comentários"
                },
                VID_PLR_ALVIS_MOVE    : {
                    en     : "Move",
                    "pt-PT": "Mover"
                },
                VID_PLR_ALVIS_RST     : {
                    en     : "Reset position",
                    "pt-PT": "Repôr posição"
                },
                VID_PLR_ATPL          : {
                    en     : "Autoplay videos",
                    "pt-PT": "Iniciar vídeos automáticamente"
                },
                VID_LAYT              : {
                    en     : "Layout",
                    "pt-PT": "Aparência"
                },
                VID_VID_CNT           : {
                    en     : "Show link with number of uploaded videos",
                    "pt-PT": "Mostrar link com número de vídeos carregados"
                },
                VID_POST_TIME         : {
                    en     : "Show how long the video has been published",
                    "pt-PT": "Mostrar há quanto tempo o vídeo foi publicado"
                },
                VID_HIDE_DETLS        : {
                    en     : "Hide video details",
                    "pt-PT": "Esconder detalhes do vídeo"
                },
                VID_HIDE_COMS         : {
                    en     : "Comment section",
                    "pt-PT": "Secção de comentários"
                },
                VID_HIDE_COMS_SHOW    : {
                    en     : "Show",
                    "pt-PT": "Mostrar"
                },
                VID_HIDE_COMS_HIDE    : {
                    en     : "Hide",
                    "pt-PT": "Esconder"
                },
                VID_HIDE_COMS_REM     : {
                    en     : "Remove",
                    "pt-PT": "Remover"
                },
                VID_END_SHRE          : {
                    en     : "Disable share panel when video ends",
                    "pt-PT": "Desactivar painel de partilha quando o video acaba"
                },
                VID_PLST              : {
                    en     : "Playlists",
                    "pt-PT": "Listas"
                },
                VID_PLST_SEP          : {
                    en     : "Separate playlist from player",
                    "pt-PT": "Separar lista de reprodução do reproductor"
                },
                VID_PLST_ATPL         : {
                    en     : "Enable playlist autoplay control",
                    "pt-PT": "Activar controlo de início automático das listas"
                },
                VID_PLST_RVRS         : {
                    en     : "Enable reverse playlist control",
                    "pt-PT": "Activar controlo de inversão das listas"
                },
                VID_PLR_SIZE_MEM      : {
                    en     : "Memorize player mode",
                    "pt-PT": "Memorizar tamanho do reproductor"
                },
                VID_VOL_WHEEL         : {
                    en     : "Change volume with mouse wheel",
                    "pt-PT": "Alterar nível de som com a roda do rato"
                },
                VID_PLR_VOL_MEM       : {
                    en     : "Memorize audio volume",
                    "pt-PT": "Memorizar volume de audio"
                },
                VID_PLR_ADS           : {
                    en     : "Disable advertisements in the video page",
                    "pt-PT": "Desactivar publicidades na página de vídeo"
                },
                VID_PLR_ALACT           : {
                    en     : "Player shortcuts always active",
                    "pt-PT": "Atalhos do reproductor sempre activos"
                },
                VID_SUB_ADS           : {
                    en     : "Enable advertisements only in videos from subscribed channels",
                    "pt-PT": "Activar publicidades só para vídeos de canais subscritos"
                },
                VID_PLR_ANTS          : {
                    en     : "Disable annotations",
                    "pt-PT": "Desactivar notas"
                },
                VID_PLR_DASH          : {
                    en     : "Disable DASH playback",
                    "pt-PT": "Desactivar reprodução DASH"
                },
                VID_PLR_CC            : {
                    en     : "Disable subtitles and CC",
                    "pt-PT": "Desactivar legendas e CC"
                },
                VID_PLR_INFO          : {
                    en     : "Enable info bar with watch later button",
                    "pt-PT": "ACtivar barra de informação com o botão ver mais tarde"
                },
                VID_PLR_FIT           : {
                    en     : "Fit to page in theater mode",
                    "pt-PT": "Ajustar na página no modo cinema"
                },
                VID_PLR_FIT_WDTH      : {
                    en     : "Fit to page max width:",
                    "pt-PT": "Largura máxima do ajuste na página:"
                },
                VID_PLR_DYN_SIZE      : {
                    en     : "Disable dynamic player size in default view",
                    "pt-PT": "Desactivar tamanho dinâmico do reproductor na vista predefinida"
                },
                VID_DESC_SHRT         : {
                    en     : "Short video description buttons",
                    "pt-PT": "Botões curtos na descrição do vídeo"
                },
                VID_TTL_CMPT          : {
                    en     : "Compact title in video description",
                    "pt-PT": "Título compacto na descrição do vídeo"
                },
                VID_SDBR_ALGN         : {
                    en     : "Sidebar mode alignment",
                    "pt-PT": "Alinhar modo barra lateral"
                },
                VID_SDBR_ALGN_NONE    : {
                    en     : "None",
                    "pt-PT": "Nenhum"
                },
                VID_SDBR_ALGN_LEFT    : {
                    en     : "Left",
                    "pt-PT": "Esquerda"
                },
                VID_SDBR_ALGN_RIGHT   : {
                    en     : "Right",
                    "pt-PT": "Direita"
                },
                VID_LAYT_AUTO_PNL     : {
                    en     : "Auto expand video description",
                    "pt-PT": "Automáticamente mostrar mais na descrição do vídeo"
                },
                GEN_CHN_DFLT_PAGE     : {
                    en     : "Default channel page:",
                    "pt-PT": "Página de canal predefinida:"
                },
                GEN_CHN_DFLT_PAGE_DFLT: {
                    en     : "Default",
                    "pt-PT": "Padrão"
                },
                GEN_CHN_DFLT_PAGE_VID : {
                    en     : "Videos",
                    "pt-PT": "Vídeos"
                },
                GEN_CHN_DFLT_PAGE_PL  : {
                    en     : "Playlists",
                    "pt-PT": "Listas de reprodução"
                },
                GEN_CHN_DFLT_PAGE_CHN : {
                    en     : "Channels",
                    "pt-PT": "Canais"
                },
                GEN_CHN_DFLT_PAGE_DISC: {
                    en     : "Discussion",
                    "pt-PT": "Discussão"
                },
                GEN_CHN_DFLT_PAGE_ABT : {
                    en     : "About",
                    "pt-PT": "Acerca de"
                },
                BLK_TTL               : {
                    en     : "Blacklist settings",
                    "pt-PT": "Definições da lista negra"
                },
                BLK_BLK               : {
                    en     : "Blacklist",
                    "pt-PT": "Lista negra"
                },
                BLK_ON                : {
                    en     : "Enable blacklist",
                    "pt-PT": "Activar lista negra"
                },
                ABT_TTL               : {
                    en     : "Information and useful links",
                    "pt-PT": "Informação e ligações úteis"
                },
                ABT_THKS              : {
                    en     : "Thanks to:",
                    "pt-PT": "Agradecimentos a:"
                },
                ABT_THKS_YEPPHA       : {
                    en     : ", who's work inspired the creation of this project, without whom none of this would exist today.",
                    "pt-PT": ", cujo trabalho inspirou a criação deste projecto, sem ele nada disto existiria hoje."
                },
                ABT_THKS_USERSCRIPT   : {
                    en     : " for making the task of developing and shipping third party software incredibly easier.",
                    "pt-PT": " por tornarem o processo de produção e publicação de software bastante fácil."
                },
                ABT_THKS_STACKOV      : {
                    en     : " for all of its priceless information which greatly contributes for software development.",
                    "pt-PT": " por toda a informação valiosa que contém e que contribui bastante para a criação de software."
                },
                ABT_INFO              : {
                    en     : "Official pages",
                    "pt-PT": "Páginas oficiais"
                },
                ABT_LNK_GHB           : {
                    en: "GitHub"
                },
                ABT_LNK_GRFK          : {
                    en: "Greasy Fork"
                },
                ABT_LNK_OPNU          : {
                    en: "OpenUserJS"
                }
            };
        function string2HTML(string) {
            return new window.DOMParser().parseFromString(string, "text/html");
        }
        function set(setting, newValue) {
            parSets[setting] = newValue;
            window.postMessage({set: parSets}, "*");
        }
        function eventHandler(target, event, call, capture, type) {
            if (target.events && target.events[event] && target.events[event][call.name]) {
                target.removeEventListener(event, target.events[event][call.name], !!capture);
                delete target.events[event][call.name];
                if (JSON.stringify(target.events[event]) === "{}") {
                    delete target.events[event];
                }
            }
            if (!type) {
                target.addEventListener(event, call, !!capture);
                target.events = target.events || {};
                target.events[event] = target.events[event] || {};
                target.events[event][call.name] = call;
                if (events.indexOf(target) < 0 && (String(target)).split("HTML").length > 1) {
                    events.push(target);
                }
            }
        }
        function clearOrphans() {
            var i = events.length;
            while (i) {
                i -= 1;
                if (!document.contains(events[i])) {
                    events[i].remove();
                    events.splice(i, 1);
                }
            }
        }
        function userLang(label) {
            var ytlang = (window.yt && window.yt.config_ && window.yt.config_.FEEDBACK_LOCALE_LANGUAGE) || "en";
            if (lang[label][ytlang]) {
                return lang[label][ytlang];
            }
            return lang[label].en;
        }
        function localXHR(details) {
            var request = new XMLHttpRequest();
            request.addEventListener("load", details.call);
            request.open(details.method, details.url, true);
            request.send();
        }
        function timeConv(time) {
            function zero(trim) {
                return ("0" + Math.floor(trim)).slice(-2);
            }
            time = zero(time / 86400) + ":" + zero(time % 86400 / 3600) + ":" + zero(time % 3600 / 60) + ":" + zero(time % 3600 % 60);
            return time.replace(/^0(0:(0(0:(0)?)?)?)?/, "");
        }
        function removeEmptyLines(string) {
            return (/\S/).test(string);
        }
        function customStyles() {
            var classes,
                plrApi   = document.getElementById("player-api"),
                commSect = document.getElementById("watch-discussion"),
                sidebar  = document.getElementsByClassName("branded-page-v2-secondary-col")[0],
                adverts  = parSets.GEN_DSBL_ADS && (document.getElementById("masthead_child") || document.getElementById("feed-pyv-container") || document.getElementsByClassName("pyv-afc-ads-container")[0] || document.getElementsByClassName("ad-div")[0] || document.querySelector(".video-list-item:not(.related-list-item)")),
                setsList = {
                    "GEN_DSBL_ADS"    : "part_no_ads",
                    "GEN_BLUE_GLOW"   : "part_dsbl_glow",
                    "GEN_HIDE_FTR"    : "part_hide_footer",
                    "GEN_BTTR_NTF"    : "part_notif_button",
                    "GEN_GRID_SUBS"   : "part_grid_subs",
                    "GEN_GRID_SRCH"   : "part_grid_search",
                    "GEN_CMPT_TTLS"   : "part_compact_titles",
                    "VID_PLR_FIT"     : "part_fit_theater",
                    "VID_PLR_DYN_SIZE": "part_static_size",
                    "VID_HIDE_DETLS"  : "part_hide_details",
                    "VID_TTL_CMPT"    : "part_compact_title",
                    "VID_PLST_SEP"    : "part_playlist_spacer",
                    "VID_DESC_SHRT"   : "part_labelless_buttons"
                };
            while (adverts) {
                adverts.remove();
                adverts = document.getElementById("masthead_child") || document.getElementById("feed-pyv-container") || document.getElementsByClassName("pyv-afc-ads-container")[0] || document.getElementsByClassName("ad-div")[0] || document.querySelector(".video-list-item:not(.related-list-item)");
            }
            if ((window.location.pathname === "/results" && sidebar && sidebar.querySelectorAll("*").length < 10) || (sidebar && ((parSets.GEN_HDE_RECM_SDBR && window.location.href.split("/feed/subscriptions").length > 1) || (parSets.GEN_HDE_SRCH_SDBR && window.location.pathname === "/results") || (parSets.GEN_HDE_CHN_SDBR && window.location.href.split(/\/(channel|user|c)\//).length > 1)))) {
                sidebar.remove();
            }
            if (window.location.pathname === "/watch" && parSets.VID_HIDE_COMS > 1 && commSect) {
                commSect.remove();
            }
            if (parSets.VID_HIDE_COMS === "1") {
                document.documentElement.classList.add("part_hide_comments");
            } else if (parSets.VID_HIDE_COMS !== "1") {
                document.documentElement.classList.remove("part_hide_comments");
            }
            if (parSets.VID_PLR_FIT && plrApi && (!!plrApi.style.maxWidth || plrApi.style.maxWidth !== parSets.VID_PLR_FIT_WDTH)) {
                plrApi.style.maxWidth = parSets.VID_PLR_FIT_WDTH || "1280px";
            }
            for (classes in setsList) {
                if (setsList.hasOwnProperty(classes)) {
                    if (parSets[classes]) {
                        document.documentElement.classList.add(setsList[classes]);
                    } else {
                        document.documentElement.classList.remove(setsList[classes]);
                    }
                }
            }
            if (window.location.href.split("/feed/subscriptions").length < 2) {
                document.documentElement.classList.remove("part_grid_subs");
            }
        }
        function updateSettings(event) {
            if (event.data && event.data.updateSettings) {
                delete event.data.updateSettings;
                parSets = event.data;
                customStyles();
            }
        }
        function settingsMenu() {
            var pContent,
                pContainer,
                buttonNotif,
                buttonsSection,
                settingsButton;
            if (document.getElementById("P")) {
                return;
            }
            function template() {
                var blck  = function () {
                        var button = "",
                            list   = parSets && parSets.blacklist;
                        function buildList(ytid) {
                            button += "<div class='blacklist' data-ytid='" + ytid + "''><button class='close'></button><a href='/channel/" + ytid + "' target='_blank'>" + list[ytid] + "</a></div>\n";
                        }
                        if (list && Object.keys(list).length > 0) {
                            Object.keys(list).forEach(buildList);
                        }
                        return button;
                    },
                    htEl  = {
                        info  : function (anchor) {
                            return "<a href='https://github.com/ParticleCore/Particle/wiki/Features#" + anchor + "' title='" + userLang("FTR_DESC") + "' target='_blank'>?</a>";
                        },
                        title : function (content, tag) {
                            return "<" + tag + ">" + userLang(content) + "</" + tag + ">\n";
                        },
                        select: function (id, list, anchor) {
                            var select = "<div><label for='" + id + "'>" + userLang(id) + "</label>\n" +
                                "<div class='P-select'><select id='" + id + "'>\n";
                            function keysIterator(keys) {
                                select += "<option";
                                if (parSets && parSets[id] === list[keys]) {
                                    select += " selected='true'";
                                }
                                select += " value='" + list[keys] + "'>" + userLang(keys) + "</option>\n";
                            }
                            Object.keys(list).forEach(keysIterator);
                            return select + "</select></div>\n" + htEl.info(anchor) + "</div>";
                        },
                        radio : function (name, list, anchor) {
                            var radio = "<div><label>" + userLang(name) + "</label>\n";
                            function keysIterator(keys) {
                                radio += "<input id='" + keys + "' name='" + name + "' value='" + list[keys] + "' type='radio'";
                                if (parSets && parSets[name] === list[keys]) {
                                    radio += " checked='true'";
                                }
                                radio += ">\n<label for='" + keys + "'>" + userLang(keys) + "</label>\n";
                            }
                            Object.keys(list).forEach(keysIterator);
                            return radio + htEl.info(anchor) + '</div>';
                        },
                        input : function (id, type, anchor, placeholder, size) {
                            var input = "<div><input id='" + id + "' type='" + type + "'";
                            if (placeholder) {
                                input += " placeholder='" + placeholder + "' size='" + size + "'";
                                if (parSets && typeof parSets[id] === 'string') {
                                    input += " value='" + (parSets && parSets[id]) + "'";
                                }
                            } else if (parSets && parSets[id] === true) {
                                input += " checked='true'";
                            }
                            return input + ">\n<label for='" + id + "'>" + userLang(id) + "</label>\n" + htEl.info(anchor) + "</div>";
                        }
                    },
                    menus = {
                        setMenu: [
                            "<div id='P-settings'>\n",
                            "    <div id='P-container'>\n",
                            "        <div id='P-sidebar'>\n",
                            "            <ul id='P-sidebar-list'>\n",
                            "                <li id='GEN' class='selected'>" + userLang("GEN") + "</li>\n",
                            "                <li id='VID'>" + userLang("VID") + "</li>\n",
                            "                <li id='BLK'>" + userLang("BLK") + "</li>\n",
                            "                <li id='ABT'>" + userLang("ABT") + "</li>\n",
                            "                <li id='HLP'><a target='_blank' href='https://github.com/ParticleCore/Particle/wiki'>" + userLang("HLP") + "</a></li>\n",
                            "                <li id='DNT'><a title='PayPal' target='_blank' href='https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=UMVQJJFG4BFHW'>" + userLang("DNT") + "</a></li>\n",
                            "            </ul>\n",
                            "        </div>\n",
                            "    </div>\n",
                            "</div>\n"
                        ].join(""),
                        GEN    : [
                            "<div id='P-content'>\n",
                            "    <div class='P-header'>\n",
                            "        <button class='P-save'>" + userLang("GLB_SVE") + "</button>\n",
                            "        <button class='P-reset'>" + userLang("GLB_RSET") + "</button>\n",
                            "        <button class='P-impexp' title='" + userLang("GLB_IMPR") + "'></button>\n",
                            htEl.title("GEN_TTL", "h2"),
                            "    </div>\n",
                            "    <hr class='P-horz'>\n",
                            htEl.title("GEN_GEN", "h3"),
                            htEl.input("GEN_DSBL_ADS", "checkbox", "outside_ads"),
                            htEl.input("GEN_YT_LOGO_LINK", "checkbox", "logo_redirect"),
                            htEl.input("GEN_SUB_LIST", "checkbox", "sub_playlist"),
                            htEl.input("GEN_INF_SCRL", "checkbox", "infinite_scroll"),
                            htEl.input("GEN_SDBR_ON", "checkbox", "sidebar_on"),
                            htEl.input("GEN_REM_APUN", "checkbox", "remove_autoplay"),
                            htEl.input("GEN_SPF_OFF", "checkbox", "spf_off"),
                            htEl.select("GEN_CHN_DFLT_PAGE", {
                                "GEN_CHN_DFLT_PAGE_DFLT": "default",
                                "GEN_CHN_DFLT_PAGE_VID" : "videos",
                                "GEN_CHN_DFLT_PAGE_PL"  : "playlists",
                                "GEN_CHN_DFLT_PAGE_CHN" : "channels",
                                "GEN_CHN_DFLT_PAGE_DISC": "discussion",
                                "GEN_CHN_DFLT_PAGE_ABT" : "about"
                            }, "channel_page"),
                            htEl.title("GEN_LYT", "h3"),
                            htEl.input("GEN_GRID_SUBS", "checkbox", "sub_grid"),
                            htEl.input("GEN_GRID_SRCH", "checkbox", "search_grid"),
                            htEl.input("GEN_BTTR_NTF", "checkbox", "blue_box"),
                            htEl.input("GEN_DSB_HVRC", "checkbox", "hovercards_off"),
                            htEl.input("GEN_CMPT_TTLS", "checkbox", "feed_titles"),
                            htEl.input("GEN_BLUE_GLOW", "checkbox", "blue_glow"),
                            htEl.input("GEN_HIDE_FTR", "checkbox", "hide_footer"),
                            htEl.input("GEN_HDE_RECM_SDBR", "checkbox", "hide_recom_sidebar"),
                            htEl.input("GEN_HDE_SRCH_SDBR", "checkbox", "hide_search_sidebar"),
                            htEl.input("GEN_HDE_CHN_SDBR", "checkbox", "hide_channel_sidebar"),
                            "</div>\n"
                        ].join(""),
                        VID    : [
                            "<div id='P-content'>\n",
                            "    <div class='P-header'>\n",
                            "        <button class='P-save'>" + userLang("GLB_SVE") + "</button>\n",
                            "        <button class='P-reset'>" + userLang("GLB_RSET") + "</button>\n",
                            "        <button class='P-impexp' title='" + userLang("GLB_IMPR") + "'></button>\n",
                            htEl.title("VID_TTL", "h2"),
                            "    </div>\n",
                            "    <hr class='P-horz'>\n",
                            htEl.title("VID_PLR", "h3"),
                            htEl.input("VID_PLR_ADS", "checkbox", "video_ads"),
                            htEl.input("VID_SUB_ADS", "checkbox", "subs_ads_on"),
                            htEl.input("VID_PLR_ALVIS", "checkbox", "floating_player"),
                            htEl.input("VID_PLR_ATPL", "checkbox", "video_autoplay"),
                            htEl.input("VID_PLR_CC", "checkbox", "subtitles_off"),
                            htEl.input("VID_PLR_ANTS", "checkbox", "annotations_off"),
                            htEl.input("VID_END_SHRE", "checkbox", "share_panel_off"),
                            htEl.input("VID_PLR_VOL_MEM", "checkbox", "remember_volume"),
                            htEl.input("VID_PLR_ALACT", "checkbox", "shortcuts_on"),
                            htEl.input("VID_PLR_SIZE_MEM", "checkbox", "remember_mode"),
                            htEl.input("VID_VOL_WHEEL", "checkbox", "wheel_volume"),
                            htEl.input("VID_PLR_DASH", "checkbox", "dash_off"),
                            htEl.select("VID_DFLT_QLTY", {
                                "VID_DFLT_QLTY_AUTO": "auto",
                                "VID_DFLT_QLTY_ORIG": "highres",
                                "VID_DFLT_QLTY_1440": "hd1440",
                                "VID_DFLT_QLTY_1080": "hd1080",
                                "VID_DFLT_QLTY_720" : "hd720",
                                "VID_DFLT_QLTY_LRG" : "large",
                                "VID_DFLT_QLTY_MDM" : "medium",
                                "VID_DFLT_QLTY_SML" : "small",
                                "VID_DFLT_QLTY_TNY" : "tiny"
                            }, "default_quality"),
                            htEl.title("VID_PLR_LYT", "h3"),
                            htEl.input("VID_PLR_INFO", "checkbox", "info_bar"),
                            htEl.input("VID_PLR_DYN_SIZE", "checkbox", "dynamic_size_off"),
                            htEl.input("VID_PLR_FIT", "checkbox", "fit_to_page"),
                            htEl.input("VID_PLR_FIT_WDTH", "text", "fit_max_width", "1280px", 6),
                            htEl.title("VID_PLST", "h3"),
                            htEl.input("VID_PLST_SEP", "checkbox", "separate_playlist"),
                            htEl.input("VID_PLST_ATPL", "checkbox", "playlist_autoplay"),
                            htEl.input("VID_PLST_RVRS", "checkbox", "playlist_reverse"),
                            htEl.title("VID_LAYT", "h3"),
                            htEl.select("VID_HIDE_COMS", {
                                "VID_HIDE_COMS_SHOW": "0",
                                "VID_HIDE_COMS_HIDE": "1",
                                "VID_HIDE_COMS_REM" : "2"
                            }, "comments"),
                            htEl.select("VID_SDBR_ALGN", {
                                "VID_SDBR_ALGN_NONE" : "0",
                                "VID_SDBR_ALGN_LEFT" : "1",
                                "VID_SDBR_ALGN_RIGHT": "2"
                            }, "sidebar_align"),
                            htEl.input("VID_TTL_CMPT", "checkbox", "video_title"),
                            htEl.input("VID_DESC_SHRT", "checkbox", "labelless_buttons"),
                            htEl.input("VID_VID_CNT", "checkbox", "upload_counter"),
                            htEl.input("VID_POST_TIME", "checkbox", "relative_upload_time"),
                            htEl.input("VID_HIDE_DETLS", "checkbox", "hide_video_details"),
                            htEl.input("VID_LAYT_AUTO_PNL", "checkbox", "expand_description"),
                            "</div>\n"
                        ].join(""),
                        BLK    : [
                            "<div id='P-content'>\n",
                            "    <div class='P-header'>\n",
                            "        <button class='P-save'>" + userLang("GLB_SVE") + "</button>\n",
                            "        <button class='P-reset'>" + userLang("GLB_RSET") + "</button>\n",
                            "        <button class='P-impexp' title='" + userLang("GLB_IMPR") + "'></button>\n",
                            htEl.title("BLK_TTL", "h2"),
                            "    </div>\n",
                            "    <hr class='P-horz'>\n",
                            htEl.title("BLK_BLK", "h3"),
                            htEl.input("BLK_ON", "checkbox", "blacklist_on"),
                            "    <div id='blacklist'>\n",
                            "        <div id='blacklist-controls'>\n",
                            "            <button id='blacklist-edit' class='yt-uix-button yt-uix-sessionlink yt-uix-button-default yt-uix-button-size-default'>\n",
                            "                <span class='yt-uix-button-content'>" + userLang("BLCK_EDIT") + "</span>\n",
                            "            </button>\n",
                            "            <button id='blacklist-save' class='yt-uix-button yt-uix-sessionlink yt-uix-button-default yt-uix-button-size-default'>\n",
                            "                <span class='yt-uix-button-content'>" + userLang("BLCK_SAVE") + "</span>\n",
                            "            </button>\n",
                            "            <button id='blacklist-close' class='yt-uix-button yt-uix-sessionlink yt-uix-button-default yt-uix-button-size-default'>\n",
                            "                <span class='yt-uix-button-content'>" + userLang("BLCK_CLSE") + "</span>\n",
                            "            </button>\n",
                            "        </div>\n",
                            "        " + blck() + "\n",
                            "        <textarea id='blacklist-edit-list'></textarea>\n",
                            "    </div>\n",
                            "    <br>\n",
                            "</div>\n"
                        ].join(""),
                        ABT    : [
                            "<div id='P-content'>\n",
                            "    <div class='P-header'>\n",
                            htEl.title("ABT_TTL", "h2"),
                            "    </div>\n",
                            "    <hr class='P-horz'>\n",
                            htEl.title("ABT_THKS", "h3"),
                            "    <div>\n",
                            "        <a target='_blank' href='https://github.com/YePpHa'>Jeppe Rune Mortensen</a>" + userLang("ABT_THKS_YEPPHA") + "\n",
                            "    </div>\n",
                            "    <div>\n",
                            "        <a target='_blank' href='http://www.greasespot.net/'>Greasemonkey</a> + <a href='http://tampermonkey.net/'>Tampermonkey</a>" + userLang("ABT_THKS_USERSCRIPT") + "\n",
                            "    </div>\n",
                            "    <div>\n",
                            "        <a target='_blank' href='http://stackoverflow.com/'>Stack Overflow</a>" + userLang("ABT_THKS_STACKOV") + "\n",
                            "    </div>\n",
                            htEl.title("ABT_INFO", "h3"),
                            "    <div>\n",
                            "        <a target='_blank' href='https://github.com/ParticleCore/Particle/'>GitHub</a>\n",
                            "    </div>\n",
                            "    <div>\n",
                            "        <a target='_blank' href='https://greasyfork.org/en/users/8223-particlecore'>Greasy Fork</a>\n",
                            "    </div>\n",
                            "    <div>\n",
                            "        <a target='_blank' href='http://openuserjs.org/scripts/ParticleCore/'>OpenUserJS</a>\n",
                            "    </div>\n",
                            "</div>\n"
                        ].join("")
                    };
                return menus;
            }
            function navigateSettings(event) {
                function exportSettings(target) {
                    var expCont = document.getElementById("exp-cont");
                    if (target.classList.contains("P-impexp")) {
                        if (expCont) {
                            expCont.remove();
                            return;
                        }
                        expCont = "<div id='exp-cont'>\n" +
                            "   <button id='impexp-save' class='yt-uix-button yt-uix-sessionlink yt-uix-button-default yt-uix-button-size-default'>\n" +
                            "        <span class='yt-uix-button-content'>" + userLang("GLB_IMPR_SAVE") + "</span>\n" +
                            "    </button>\n" +
                            "   <textarea id='impexp-list'></textarea>" +
                            "</div>";
                        expCont = string2HTML(expCont).querySelector('#exp-cont');
                        document.getElementById("P-content").appendChild(expCont);
                        document.getElementById("impexp-list").value = JSON.stringify(parSets, undefined, 2);
                    } else if (target.id === "impexp-save") {
                        parSets = JSON.parse(document.getElementById("impexp-list").value);
                        window.postMessage({set: parSets}, "*");
                        document.getElementById("P").click();
                        document.getElementById("P").click();
                    }
                }
                function manageBlackList(target) {
                    if (target.id === "blacklist-edit") {
                        document.getElementById("blacklist").classList.add("edit");
                        document.getElementById("blacklist-edit-list").value = JSON.stringify(parSets.blacklist).replace(/":"/g, '": "').replace(/","/g, '"\n"').replace('{"', '"').replace('"}', '"').replace("{}", "");
                    } else if (target.id === "blacklist-save") {
                        set("blacklist", JSON.parse("{" + document.getElementById("blacklist-edit-list").value.split("\n").filter(removeEmptyLines).join(",") + "}"));
                    } else if (target.id === "blacklist-close") {
                        document.getElementById("BLK").click();
                    }
                }
                function remBlackList() {
                    var newKey = parSets.blacklist;
                    delete newKey[event.target.parentNode.getAttribute("data-ytid")];
                    event.target.parentNode.remove();
                    set("blacklist", newKey);
                }
                function saveSettings(salt) {
                    var value,
                        notification = document.getElementById("appbar-main-guide-notification-container"),
                        navId        = document.getElementsByClassName("selected")[0].id,
                        userSets     = document.getElementById("P-content").querySelectorAll("[id^='" + navId + "']"),
                        length       = userSets.length,
                        savedSets    = parSets;
                    function hideNotif() {
                        document.body.classList.remove("show-guide-button-notification");
                    }
                    while (length) {
                        length -= 1;
                        value = (userSets[length].checked && (userSets[length].value === "on" || userSets[length].value)) || (userSets[length].length && userSets[length].value) || (userSets[length].getAttribute("type") === "text" && userSets[length].value);
                        if (value) {
                            savedSets[userSets[length].name || userSets[length].id] = value;
                        } else if (!value && userSets[length].type !== "radio") {
                            savedSets[userSets[length].id] = false;
                        }
                    }
                    parSets = savedSets;
                    window.postMessage({set: parSets}, "*");
                    customStyles();
                    if (!salt) {
                        if (notification.childNodes.length < 1) {
                            notification.remove();
                            notification = [
                                "<div id='appbar-main-guide-notification-container'>\n",
                                "    <div class='appbar-guide-notification' role='alert'>\n",
                                "        <span class='appbar-guide-notification-content-wrapper yt-valign'>\n",
                                "            <span class='appbar-guide-notification-icon yt-sprite'></span>\n",
                                "            <span class='appbar-guide-notification-text-content'></span>\n",
                                "        </span>\n",
                                "    </div>\n",
                                "</div>\n"
                            ].join("");
                            notification = string2HTML(notification).querySelector("#appbar-main-guide-notification-container");
                            document.getElementsByClassName("yt-masthead-logo-container")[0].appendChild(notification);
                        }
                        document.getElementsByClassName("appbar-guide-notification-text-content")[0].textContent = "Settings saved";
                        document.body.classList.add("show-guide-button-notification");
                        window.setTimeout(hideNotif, 2000);
                    }
                }
                if (event.target.classList.contains("P-save")) {
                    saveSettings();
                } else if (event.target.classList.contains("P-reset")) {
                    parSets = defSets;
                    window.postMessage({set: defSets}, "*");
                    settingsButton.click();
                    settingsButton.click();
                } else if (event.target.classList.contains("close")) {
                    remBlackList();
                } else if (event.target.classList.contains("P-impexp") || event.target.id === "impexp-save") {
                    exportSettings(event.target);
                } else if (event.target.id === "blacklist-edit" || event.target.id === "blacklist-save" || event.target.id === "blacklist-close") {
                    manageBlackList(event.target);
                } else if (event.target.id === "P-container" || event.target.id === "P-settings") {
                    event = (event.target.id === "P-settings") ? event.target : event.target.parentNode;
                    event.remove();
                } else if (event.target.id !== "DNT" && event.target.tagName !== "A" && event.target.parentNode.id === "P-sidebar-list") {
                    saveSettings("no-notification");
                    document.getElementById("P-content").remove();
                    pContainer = document.getElementById("P-container");
                    pContent = string2HTML(template()[event.target.id]).querySelector("#P-content");
                    pContainer.appendChild(pContent);
                    event.target.parentNode.getElementsByClassName("selected")[0].removeAttribute("class");
                    event.target.className = "selected";
                }
            }
            function settingsTemplate() {
                var bodyContainer,
                    pageContainer,
                    pWrapper = document.getElementById("P-settings");
                if (pWrapper) {
                    pWrapper.remove();
                } else {
                    bodyContainer = document.getElementById("body-container");
                    pageContainer = document.getElementById("page-container");
                    pWrapper = string2HTML(template().setMenu).querySelector("#P-settings");
                    pWrapper.querySelector("#P-container").appendChild(string2HTML(template().GEN).querySelector("#P-content"));
                    bodyContainer.insertBefore(pWrapper, pageContainer);
                    eventHandler(pWrapper, "click", navigateSettings);
                }
                document[isChrome ? "body" : "documentElement"].scrollTop = 0;
            }
            buttonNotif = document.getElementsByClassName("notifications-container")[0];
            buttonsSection = document.getElementById("yt-masthead-user") || document.getElementById("yt-masthead-signin");
            if (buttonsSection && !document.getElementById("P")) {
                settingsButton = document.createElement("button");
                settingsButton.id = "P";
                settingsButton.title = "YouTube+ settings";
                eventHandler(settingsButton, "click", settingsTemplate);
                if (buttonNotif) {
                    buttonsSection.insertBefore(settingsButton, buttonNotif);
                } else {
                    buttonsSection.appendChild(settingsButton);
                }
            }
        }
        function enhancedDetails() {
            function username() {
                var link,
                    span,
                    user,
                    verified,
                    name = document.getElementsByClassName("yt-user-info")[0];
                function videoCounter() {
                    link.href = window.location.origin + "/channel/" + user.getAttribute("data-ytid") + "/videos";
                    span = document.createElement("span");
                    span.textContent = " · ";
                    name.appendChild(span);
                    name.appendChild(link);
                    verified = document.getElementsByClassName("yt-channel-title-icon-verified")[0];
                    if (verified) {
                        user.className += " yt-uix-tooltip";
                        user.setAttribute("data-tooltip-text", verified.getAttribute("data-tooltip-text"));
                        user.style.color = "#167ac6";
                        verified.remove();
                    }
                }
                function getPLInfo(details) {
                    details = details.target.responseText;
                    if (details) {
                        details = JSON.parse(details);
                        details = details.body && details.body.content && (details.body.content.html || details.body.content);
                        details = details && details.match && details.match(/class="pl-header-details">([\w\W]*?)<\/ul>/)[1];
                        details = details && details.match(/<li>([\w\W]*?)<\/li>/g)[1];
                        if (details) {
                            link.className = "spf-link";
                            link.textContent = channelId[user.getAttribute("data-ytid")] = details.replace(/<\/?li>/g, "").replace("&#39;", "'");
                            videoCounter();
                        }
                    }
                }
                if (!document.getElementById("uploaded-videos") && name) {
                    link = document.createElement("a");
                    link.id = "uploaded-videos";
                    name.appendChild(link);
                    user = name.querySelector("a");
                    if (channelId[user.getAttribute("data-ytid")]) {
                        link.textContent = channelId[user.getAttribute("data-ytid")];
                        videoCounter();
                    } else {
                        localXHR({
                            method: "GET",
                            url: "/playlist?spf=navigate&list=" + user.getAttribute("data-ytid").replace("UC", "UU"),
                            call: getPLInfo
                        });
                    }
                }
            }
            function publishedTime() {
                var watchTime = document.getElementsByClassName("watch-time-text")[0];
                function getCHInfo(details) {
                    var isLive;
                    details = details.target.responseText;
                    if (details) {
                        if (watchTime.textContent.split("·").length < 2) {
                            details = JSON.parse(details);
                            details = details.body && details.body.content && (details.body.content.html || details.body.content);
                            isLive = details && details.match && details.match(/yt-badge-live/);
                            details = details && details.match && details.match(/yt-lockup-meta-info">\n<li>([\w\W]*?)<\/ul/);
                            if (details && !isLive) {
                                watchTime.textContent += " · " + details[1].split("</li><li>")[0];
                            }
                        }
                    }
                }
                if (watchTime && window.ytplayer && window.ytplayer.config) {
                    localXHR({
                        method: "GET",
                        url: "/channel/" + window.ytplayer.config.args.ucid + "/search?query='" + window.ytplayer.config.args.video_id + "'&spf=navigate",
                        call: getCHInfo
                    });
                }
            }
            if (window.location.pathname === "/watch") {
                if (parSets.VID_VID_CNT) {
                    username();
                }
                if (parSets.VID_POST_TIME) {
                    publishedTime();
                }
            }
        }
        function commentsButton() {
            var wrapper,
                comments = document.getElementById("watch-discussion");
            function showComments() {
                comments.classList.toggle("show");
                wrapper.querySelector("button").textContent = userLang((comments.classList.contains("show")) ? "HIDE_CMTS" : "SHOW_CMTS");
            }
            if (comments && !document.getElementById("P-show-comments") && parSets.VID_HIDE_COMS === "1") {
                wrapper =
                    "<div id='P-show-comments' class='yt-card'>\n" +
                    "    <button class='yt-uix-button yt-uix-button-expander'>" + userLang("SHOW_CMTS") + "</button>\n" +
                    "</div>\n";
                wrapper = string2HTML(wrapper).querySelector("#P-show-comments");
                eventHandler(wrapper, "click", showComments);
                comments.parentNode.insertBefore(wrapper, comments);
            }
        }
        function playerMode() {
            var pageElement   = document.getElementById("page"),
                playerElement = document.getElementById("player");
            if (parSets.VID_PLR_SIZE_MEM && parSets.theaterMode) {
                if (window.navigator.cookieEnabled && (document.cookie.split("wide=0").length > 1 || document.cookie.split("wide=1").length < 2)) {
                    document.cookie = "wide=1; path=/";
                }
                if (playerElement && window.location.pathname === "/watch") {
                    pageElement.classList.add("watch-wide");
                    pageElement.className = pageElement.className.replace("non-", "");
                    playerElement.className = playerElement.className.replace("small", "large");
                }
            } else if (parSets.VID_PLR_SIZE_MEM && !parSets.theaterMode) {
                if (window.navigator.cookieEnabled && (document.cookie.split("wide=1").length > 1 || document.cookie.split("wide=0").length < 2)) {
                    document.cookie = "wide=0; path=/";
                }
                if (playerElement && window.location.pathname === "/watch") {
                    pageElement.classList.remove("watch-wide");
                    pageElement.className = pageElement.className.replace("watch-stage", "watch-non-stage");
                    playerElement.className = playerElement.className.replace("large", "small").replace("medium", "small");
                }
            }
        }
        function argsCleaner(config) {
            function clearRVS(rvs) {
                rvs = rvs.split(",");
                function blacklistMatch(names) {
                    var i = rvs.length;
                    while (i) {
                        i -= 1;
                        if (decodeURIComponent(rvs[i]).replace(/\+/g, " ").split(parSets.blacklist[names]).length > 1) {
                            rvs.splice(i, 1);
                        }
                    }
                }
                Object.keys(parSets.blacklist).forEach(blacklistMatch);
                return rvs.join(",");
            }
            if (config.args.video_id) {
                config.args.autohide = "2";
                config.args.vq = parSets.VID_DFLT_QLTY;
                config.args.dash = (parSets.VID_PLR_DASH && "0") || config.args.dash;
                if (parSets.VID_PLR_INFO) {
                    config.args.showinfo = "1";
                }
                if (!parSets.VID_PLR_ATPL) {
                    config.args.autoplay = "0";
                }
                if (parSets.VID_PLR_SIZE_MEM) {
                    config.args.player_wide = (parSets.theaterMode && "1") || "0";
                }
                if (config.args.iv_load_policy && parSets.VID_PLR_ANTS) {
                    config.args.iv_load_policy = "3";
                }
                if (config.args.cc_load_policy && parSets.VID_PLR_CC) {
                    config.args.cc_load_policy = "0";
                    if (config.args.ttsurl) {
                        delete config.args.ttsurl;
                        delete config.args.caption_tracks;
                    }
                }
                if ((parSets.VID_PLR_ADS && (!parSets.VID_SUB_ADS || (parSets.VID_SUB_ADS && !config.args.subscribed)))) {
                    delete config.args.ad3_module;
                }
                if (parSets.BLK_ON && window.yt && window.yt.config_ && window.yt.config_.RELATED_PLAYER_ARGS && window.yt.config_.RELATED_PLAYER_ARGS.rvs) {
                    config.args.rvs = window.yt.config_.RELATED_PLAYER_ARGS.rvs = clearRVS(window.yt.config_.RELATED_PLAYER_ARGS.rvs);
                }
                if (window.ytplayer && window.ytplayer.config === null) {
                    window.ytplayer.config = config;
                }
                if (window.ytplayer && window.ytplayer.config) {
                    window.ytplayer.config.args = config.args;
                }
                return config;
            }
        }
        function alwaysVisible() {
            function initFloater() {
                var height,
                    oldPosX,
                    oldPosY,
                    XBounds,
                    YBounds,
                    maxOffsetX,
                    maxOffsetY,
                    minOffsetX,
                    minOffsetY,
                    activeMove,
                    skinny          = document.documentElement.classList.contains("content-snap-width-skinny-mode"),
                    videoPlayer     = document.getElementById("movie_player"),
                    playerContainer = document.getElementById("player-api"),
                    containerSize   = playerContainer && playerContainer.getBoundingClientRect(),
                    sidebar         = document.getElementById("watch7-sidebar"),
                    sidebarSize     = sidebar && sidebar.getBoundingClientRect(),
                    outOfSight      = containerSize.bottom < (((skinny && containerSize.height - 2) || (containerSize.height / 2)) + 51),
                    isFloater       = document.documentElement.classList.contains("floater"),
                    floaterUI       = document.getElementById("part_floaterui");
                function updatePos() {
                    if (!document.documentElement.classList.contains("floater")) {
                        return eventHandler(window, "resize", updatePos, false, "remove");
                    }
                    sidebar = document.getElementById("watch7-sidebar");
                    sidebarSize = sidebar.getBoundingClientRect();
                    height = (skinny && containerSize.height) || (sidebarSize.width / (16 / 9));
                    videoPlayer.style.width = (skinny && containerSize.width) || sidebarSize.width + "px";
                    videoPlayer.style.height = height + "px";
                    XBounds = parSets.floaterX > -1 && (parSets.floaterX + videoPlayer.offsetWidth) < document.documentElement.offsetWidth;
                    YBounds = parSets.floaterY > 50 && (parSets.floaterY + videoPlayer.offsetHeight) < document.documentElement.offsetHeight;
                    if (!parSets.customFloater || skinny) {
                        videoPlayer.style.top = "calc(50% - " + (height / 2) + "px)";
                        videoPlayer.style.left = ((skinny && "0") || sidebarSize.left) + "px";
                    } else {
                        videoPlayer.style.top = ((YBounds && parSets.floaterY) || (parSets.floaterY < 51 && 51) || (document.documentElement.offsetHeight - videoPlayer.offsetHeight)) + "px";
                        videoPlayer.style.left = ((XBounds && parSets.floaterX) || (parSets.floaterX < 1 && "0") || (document.documentElement.offsetWidth - videoPlayer.offsetWidth)) + "px";
                    }
                }
                function customFloaterPosition(event) {
                    var newXval,
                        newYval;
                    if (activeMove) {
                        if (event.type === "mouseup") {
                            set("floaterY", videoPlayer.offsetTop);
                            set("floaterX", videoPlayer.offsetLeft);
                            activeMove = false;
                            return;
                        }
                        if (event.type === "mousemove") {
                            newXval = videoPlayer.offsetLeft + (event.clientX - oldPosX);
                            newYval = videoPlayer.offsetTop + (event.clientY - oldPosY);
                            newXval = (event.clientX < (minOffsetX + 1) && "0") || (event.clientX > (maxOffsetX - 1) && (document.documentElement.offsetWidth - videoPlayer.offsetWidth)) || newXval;
                            newYval = (event.clientY < (minOffsetY + 1) && "51") || (event.clientY > (maxOffsetY - 1) && (document.documentElement.offsetHeight - videoPlayer.offsetHeight)) || newYval;
                            if (newYval !== videoPlayer.style.top) {
                                videoPlayer.style.top = newYval + "px";
                            }
                            if (newXval !== videoPlayer.style.left) {
                                videoPlayer.style.left = newXval + "px";
                            }
                        }
                        oldPosX = event.clientX;
                        oldPosY = event.clientY;
                    } else if (!document.getElementById("part_floaterui")) {
                        eventHandler(document, "mousemove", customFloaterPosition, false, "remove");
                        eventHandler(document, "mouseup", customFloaterPosition, false, "remove");
                    }
                }
                function floaterControl(event) {
                    if (event.target.id === "part_floaterui_reset") {
                        set("customFloater", false);
                        updatePos();
                    } else if (event.target.id === "part_floaterui_move") {
                        set("customFloater", true);
                        activeMove = true;
                        maxOffsetX = document.documentElement.offsetWidth - (videoPlayer.offsetWidth - (event.clientX - videoPlayer.offsetLeft));
                        maxOffsetY = document.documentElement.offsetHeight - (videoPlayer.offsetHeight - (event.clientY - videoPlayer.offsetTop));
                        minOffsetX = Math.abs(event.clientX - videoPlayer.offsetLeft);
                        minOffsetY = Math.abs(event.clientY - videoPlayer.offsetTop) + 51;
                        customFloaterPosition(event);
                    } else if (!document.getElementById("part_floaterui")) {
                        eventHandler(document, "mousedown", floaterControl, false, "remove");
                    }
                }
                if (!sidebar) {
                    eventHandler(window, "scroll", initFloater, false, "remove");
                    return;
                }
                if (videoPlayer) {
                    if (!floaterUI) {
                        floaterUI = [
                            "<div id='part_floaterui'>\n",
                            "    <button id='part_floaterui_move' title='" + userLang("VID_PLR_ALVIS_MOVE") + "'></button>\n",
                            "    <button id='part_floaterui_reset' title='" + userLang("VID_PLR_ALVIS_RST") + "'></button>\n",
                            "</div>\n"
                        ].join("");
                        floaterUI = string2HTML(floaterUI).querySelector("#part_floaterui");
                        eventHandler(document, "mousemove", customFloaterPosition);
                        eventHandler(document, "mouseup", customFloaterPosition);
                        eventHandler(document, "mousedown", floaterControl);
                        videoPlayer.appendChild(floaterUI);
                    }
                    if (outOfSight && !isFloater) {
                        document.documentElement.classList.add("floater");
                        eventHandler(window, "resize", updatePos);
                        updatePos();
                    } else if (!outOfSight && isFloater) {
                        document.documentElement.classList.remove("floater");
                        eventHandler(window, "resize", updatePos, false, "remove");
                        videoPlayer.removeAttribute("style");
                    }
                }
            }
            if (parSets.VID_PLR_ALVIS) {
                if (window.location.pathname === "/watch") {
                    eventHandler(window, "scroll", initFloater);
                } else if (window.location.pathname !== "/watch") {
                    eventHandler(window, "scroll", initFloater, false, "remove");
                }
            }
        }
        function subPlaylist() {
            var i,
                list      = [],
                button    = document.getElementById("subscription-playlist"),
                navMenu   = document.getElementById("channel-navigation-menu"),
                listTitle = document.getElementsByClassName("appbar-nav-menu")[0],
                videoList = document.getElementsByClassName("addto-watch-later-button");
            function initSubPlaylist() {
                i = videoList.length;
                while (i) {
                    i -= 1;
                    if (i > -1) {
                        list.push(videoList[i].getAttribute("data-video-ids"));
                    }
                }
                list.reverse().join("%2C");
                listTitle = listTitle && listTitle.getElementsByClassName("epic-nav-item-heading")[0].textContent.trim();
                button = document.getElementById("subscription-playlist");
                button.href = "/watch_videos?title=" + listTitle + "&video_ids=" + list;
            }
            if (parSets.GEN_SUB_LIST && window.location.href.split("/feed/subscriptions").length > 1 && !button && listTitle && videoList) {
                button =
                    "<li id='subscription-playlist-icon'>\n" +
                    "    <a id='subscription-playlist' title='" + userLang("SUB_PLST") + "' class='yt-uix-button spf-link yt-uix-sessionlink yt-uix-button-epic-nav-item yt-uix-button-size-default'>\n" +
                    "        <span class='yt-uix-button-content'></span>\n" +
                    "    </a>\n" +
                    "</li>";
                button = string2HTML(button).querySelector("li");
                navMenu.insertBefore(button, navMenu.firstChild);
                eventHandler(button, "click", initSubPlaylist);
            }
        }
        function playerReady() {
            function alwaysActive(event) {
                var x,
                    y;
                if (window.location.pathname !== "/watch") {
                    eventHandler(document.documentElement, "focus", alwaysActive, true, "remove");
                    eventHandler(document.documentElement, "click", alwaysActive, true, "remove");
                    return;
                }
                if (event.target.tagName === "IFRAME" || event.target.classList.contains("yt-commentbox-text")) {
                    return;
                }
                if (["EMBED", "INPUT", "OBJECT", "TEXTAREA"].indexOf(document.activeElement.tagName) < 0) {
                    x = window.scrollX;
                    y = window.scrollY;
                    api.focus();
                    window.scrollTo(x, y);
                }
            }
            function playerState(state) {
                if (parSets.fullBrs) {
                    document.documentElement.classList[(state < 5 && state > 0) ? "add" : "remove"]("part_fullbrowser");
                }
                if (parSets.lightsOut) {
                    document.documentElement.classList[(state < 5 && state > 0) ? "add" : "remove"]("part_cinema_mode");
                }
            }
            function volumeChanged(event) {
                set("volLev", event.volume);
            }
            function sizeChanged(event) {
                set("theaterMode", event);
            }
            if (!document.getElementById("c4-player")) {
                api = document.getElementById("movie_player");
                eventHandler(api, "onStateChange", playerState);
                if (parSets.VID_PLR_VOL_MEM) {
                    eventHandler(api, "onVolumeChange", volumeChanged);
                }
                if (parSets.VID_PLR_SIZE_MEM) {
                    eventHandler(api, "SIZE_CLICKED", sizeChanged);
                }
                if (parSets.VID_PLR_VOL_MEM) {
                    api.setVolume(parSets.volLev);
                }
                if (parSets.loopVid) {
                    document.getElementsByTagName("video")[0].loop = parSets.loopVid;
                }
                if (parSets.VID_PLR_ALACT) {
                    eventHandler(document.documentElement, "focus", alwaysActive, true);
                    eventHandler(document.documentElement, "click", alwaysActive, true);
                }
            }
        }
        function scriptExit(event) {
            function baseDetour(originalFunction) {
                return function () {
                    originalFunction.apply(this, arguments);
                    window.yt.config_.SHARE_ON_VIDEO_END = !parSets.VID_END_SHRE;
                    window.yt.config_.UNIVERSAL_HOVERCARDS = !parSets.GEN_DSB_HVRC;
                };
            }
            function embedDetour(originalFunction) {
                return function () {
                    var args = arguments;
                    argsCleaner(args[1]);
                    if (args[0].id === "upsell-video") {
                        return originalFunction.apply(this, args);
                    }
                    originalFunction.apply(this, args);
                    if (api) {
                        if (!parSets.VID_PLR_ATPL) {
                            api.cueVideoByPlayerVars(window.ytplayer.config.args);
                        }
                        api.setPlaybackQuality(parSets.VID_DFLT_QLTY);
                    }
                };
            }
            function autoplayDetour(originalFunction) {
                return function () {
                    var args = arguments;
                    if (!args[1] || parSets.plApl || (!parSets.plApl && args[1].feature && args[1].feature !== "autoplay")) {
                        originalFunction.apply(this, arguments);
                    }
                };
            }
            function autoplayDetourFullScreen(originalFunction) {
                return function () {
                    var nextButton,
                        hasEnded    = api && api.getCurrentTime && !(Math.round(api.getCurrentTime()) < Math.floor(api.getDuration())),
                        nextClicked = document.activeElement.classList.contains("ytp-button-next") || document.activeElement.classList.contains("ytp-next-button");
                    if (!parSets.plApl && !nextClicked && hasEnded) {
                        nextButton = document.getElementsByClassName("ytp-next-button")[0];
                        if (nextButton && nextButton.getAttribute("aria-disabled") === "true") {
                            nextButton.onclick = api.nextVideo;
                            eventHandler(nextButton, "click", api.nextVideo);
                            nextButton.setAttribute("aria-disabled", "false");
                        }
                        return false;
                    }
                    if (parSets.plApl || nextClicked || !hasEnded) {
                        if (nextClicked) {
                            document.getElementById("movie_player").focus();
                        }
                        return originalFunction.apply(this, arguments);
                    }
                };
            }
            function fullscreenVideoChange(originalFunction) {
                return function () {
                    var key,
                        patch  = [{}],
                        config = {args: {}},
                        args   = arguments;
                    function buildConfig(conf) {
                        config.args[conf.split("=")[0]] = decodeURIComponent(conf.split("=")[1]).replace(/\+/g, " ");
                    }
                    function revertConfig(conf) {
                        patch[0].response.push(conf + "=" + encodeURIComponent(config.args[conf]).replace(/\%20/g, "+"));
                    }
                    for (key in args[0]) {
                        if (args[0][key] !== undefined) {
                            patch[0][key] = args[0][key];
                        }
                    }
                    patch[0].response.split("&").forEach(buildConfig);
                    config = argsCleaner(config);
                    patch[0].response = [];
                    Object.keys(config.args).forEach(revertConfig);
                    patch[0].response = patch[0].response.join("&");
                    patch[0].responseText = patch[0].response;
                    api.setPlaybackQuality(parSets.VID_DFLT_QLTY);
                    originalFunction.apply(this, patch);
                };
            }
            function fsPointerDetour(originalFunction) {
                return function () {
                    var self = this;
                    function firstLevel(fl) {
                        function secondLevel(sl) {
                            if (typeof self[fl][sl] === "function" && String(self[fl][sl]).split("onStatusFail").length > 1) {
                                self[fl][sl] = fullscreenVideoChange(self[fl][sl]);
                            }
                        }
                        if (typeof self[fl] === "object" && self[fl]) {
                            Object.keys(Object.getPrototypeOf(self[fl])).forEach(secondLevel);
                        }
                    }
                    Object.keys(self).some(firstLevel);
                    return originalFunction.apply(this, arguments);
                };
            }
            function html5Detour(originalFunction) {
                return function () {
                    var moviePlayer,
                        args = arguments;
                    function playerInstanceIterator(keys) {
                        function firstLevel(fl) {
                            if (typeof playerInstance[keys][fl] === "function" && String(playerInstance[keys][fl]).split("get_video_info").length > 1 && playerInstance[keys][fl] !== fsPointerDetour) {
                                playerInstance[keys][fl] = fsPointerDetour(playerInstance[keys][fl]);
                            }
                        }
                        if (typeof playerInstance[keys] === "object") {
                            if (playerInstance[keys] && playerInstance[keys].hasNext) {
                                playerInstance[keys].hasNext = autoplayDetourFullScreen(playerInstance[keys].hasNext);
                            } else if (playerInstance[keys]) {
                                Object.keys(Object.getPrototypeOf(playerInstance[keys])).some(firstLevel);
                            }
                        }
                    }
                    args[1] = argsCleaner(args[1]);
                    if (args[0].id === "upsell-video") {
                        originalFunction.apply(this, args);
                    } else if (typeof args[0] === "object") {
                        playerInstance = originalFunction.apply(this, args);
                        Object.keys(playerInstance).some(playerInstanceIterator);
                        moviePlayer = document.getElementById("movie_player");
                        if (moviePlayer && !parSets.VID_PLR_ATPL) {
                            moviePlayer.cueVideoByPlayerVars(window.ytplayer.config.args);
                        }
                    }
                };
            }
            function ytIterator(keys) {
                var str;
                if (typeof window._yt_www[keys] === "function") {
                    str = String(window._yt_www[keys]);
                    if (str.split("player-added").length > 1) {
                        window._yt_www[keys] = embedDetour(window._yt_www[keys]);
                    } else if (str.split("window.spf.navigate").length > 1) {
                        window._yt_www[keys] = autoplayDetour(window._yt_www[keys]);
                    }
                }
            }
            if (event && event.target && event.target.getAttribute("name") === "www/base") {
                window.yt.setConfig = baseDetour(window.yt.setConfig);
                Object.keys(window._yt_www).some(ytIterator);
            }
            if ((event && event.target && event.target.getAttribute("name") === "html5player/html5player") || (!window.html5Patched && window.yt && window.yt.player && window.yt.player.Application && window.yt.player.Application.create)) {
                window.html5Patched = true;
                window.yt.player.Application.create = html5Detour(window.yt.player.Application.create);
            }
        }
        function thumbMod() {
            var userId,
                userName,
                loadMore,
                videoLink,
                infoField,
                titleField,
                thumbField,
                clickTitle,
                masterList,
                trashList  = [],
                detailList = [];
            function initThumbMod(event) {
                var observer;
                function initSidebarMode() {
                    var sidebarAlign = (parSets.VID_SDBR_ALGN > 1) ? ",left=" + (window.screen.availWidth - 467) : (parSets.VID_SDBR_ALGN < 1) ? "" : ",left=0",
                        newSidebar   = window.open(event.getAttribute("data-link"), "sidebarMode", "width=467,height=" + window.screen.availHeight + ",scrollbars=1" + sidebarAlign);
                    function snapFit() {
                        newSidebar.resizeTo(newSidebar.outerWidth, window.screen.availHeight);
                    }
                    newSidebar.addEventListener("readystatechange", snapFit, true);
                    newSidebar.focus();
                }
                function initBlackList() {
                    parSets.blacklist[event.getAttribute("data-ytid")] = event.getAttribute("data-user");
                    set("blacklist", parSets.blacklist);
                    thumbMod();
                }
                loadMore = document.getElementsByClassName("load-more-button")[0] || document.getElementById("watch-more-related");
                clickTitle = document.getElementsByClassName("yt-uix-tile")[0];
                while (clickTitle) {
                    clickTitle.classList.remove("yt-uix-tile");
                    clickTitle = document.getElementsByClassName("yt-uix-tile")[0];
                }
                if (loadMore && !loadMore.classList.contains("thumbMod")) {
                    loadMore.classList.add("thumbMod");
                    observer = new window.MutationObserver(thumbMod);
                    observer.observe(loadMore, {
                        childList: true,
                        attributes: true,
                        attributeOldValue: true
                    });
                }
                if (event) {
                    event.preventDefault();
                    event = event.target;
                    if (event.className === "sidebarmode yt-uix-tooltip") {
                        initSidebarMode();
                    } else if (event.className === "blacklist yt-uix-tooltip") {
                        initBlackList();
                    }
                }
            }
            function insertButtons(i) {
                var button;
                function createButton(type, details) {
                    if (type === "sidebarmode") {
                        button = "<div title='" + userLang("SDBR_OPEN") + "' data-link='" + details.videolink + "' data-tooltip-text='" + userLang("SDBR_OPEN") + "' class='" + type + " yt-uix-tooltip'></div>";
                    } else {
                        button = "<div title='" + userLang("BLCK_ADD") + "' data-user='" + details.username + "' data-ytid='" + details.youtubeid + "' data-tooltip-text='" + userLang("BLCK_ADD") + "' class='" + type + " yt-uix-tooltip'></div>";
                    }
                    return string2HTML(button).querySelector("div");
                }
                if (detailList[i]) {
                    if (parSets.GEN_SDBR_ON && !window.opener && !detailList[i].thumbfield.getElementsByClassName("sidebarmode")[0]) {
                        button = createButton("sidebarmode", detailList[i]);
                        eventHandler(button, "click", initThumbMod);
                        detailList[i].thumbfield.appendChild(button);
                    }
                    if (parSets.BLK_ON && window.location.href.split("/feed/subscriptions").length < 2 && !detailList[i].thumbfield.getElementsByClassName("blacklist")[0]) {
                        button = createButton("blacklist", detailList[i]);
                        eventHandler(button, "click", initThumbMod);
                        detailList[i].thumbfield.appendChild(button);
                    }
                }
            }
            function buildDetailList(i) {
                var upNext;
                if (i > -1 && masterList[i]) {
                    infoField = masterList[i].getElementsByClassName("g-hovercard")[1] || masterList[i].getElementsByClassName("g-hovercard")[0];
                    titleField = masterList[i].getElementsByClassName("yt-uix-tile-link")[0] || masterList[i].getElementsByClassName("yt-ui-ellipsis")[0] || masterList[i].getElementsByClassName("content-link")[0] || masterList[i].getElementsByTagName("a")[0];
                    thumbField = masterList[i].getElementsByClassName("yt-lockup-thumbnail")[0] || masterList[i].getElementsByClassName("thumb-wrapper")[0] || masterList[i].getElementsByClassName("yt-pl-thumb")[0];
                    userId = infoField && infoField.getAttribute("data-ytid");
                    userName = infoField && infoField.textContent;
                    videoLink = titleField && titleField.href;
                    detailList[i] = undefined;
                    if (userId && userId.split("UC").length < 2) {
                        infoField = masterList[i].getElementsByClassName("g-hovercard")[0];
                        userId = infoField && infoField.getAttribute("data-ytid");
                        userName = infoField && infoField.textContent;
                    }
                    if (userId && parSets.blacklist[userId]) {
                        upNext = document.getElementsByClassName("watch-sidebar-head")[0] && document.getElementsByClassName("watch-sidebar-section")[0];
                        if (upNext && upNext.contains(thumbField)) {
                            upNext.remove();
                            document.getElementsByClassName("watch-sidebar-separation-line")[0].remove();
                        } else {
                            while (thumbField) {
                                thumbField = thumbField.parentNode;
                                if (thumbField.tagName === "LI") {
                                    trashList.push(thumbField);
                                    break;
                                }
                            }
                        }
                    } else if (userName && userId && videoLink && thumbField) {
                        detailList[i] = {
                            username: userName,
                            youtubeid: userId,
                            videolink: videoLink,
                            thumbfield: thumbField
                        };
                    }
                }
            }
            function cleanList(trash) {
                var i,
                    emptyShelves = document.getElementsByClassName("feed-item-container");
                trashList[trash].remove();
                if (emptyShelves.length > 0) {
                    i = emptyShelves.length;
                    while (i) {
                        i -= 1;
                        if (emptyShelves[i].getElementsByTagName("li").length < 2) {
                            emptyShelves[i].remove();
                        }
                    }
                }
            }
            function getList(list) {
                list = document.getElementsByClassName(list);
                if (list.length > 0) {
                    masterList = list;
                }
            }
            if ((parSets.BLK_ON || parSets.GEN_SDBR_ON) && (window.location.pathname === "/" || window.location.pathname === "/results" || window.location.pathname === "/watch" || window.location.pathname === "/feed/music" || window.location.href.split("/feed/subscriptions").length > 1)) {
                ["yt-lockup-tile", "video-list-item", "yt-shelf-grid-item"].forEach(getList);
                if (masterList) {
                    Object.keys(masterList).forEach(buildDetailList);
                    Object.keys(trashList).forEach(cleanList);
                    Object.keys(detailList).forEach(insertButtons);
                    initThumbMod();
                }
            }
        }
        function volumeWheel(event) {
            var playerApi  = document.getElementById("player-api"),
                direction  = event && (event.deltaY || event.wheelDeltaY),
                currentVol = api && api.getVolume && api.getVolume(),
                playlistFS = document.getElementsByClassName("ytp-playlist-tray-tray")[0] || document.getElementsByClassName("ytp-playlist-menu")[0];
            if (event && api && playerApi && (!playlistFS || (playlistFS && !playlistFS.contains(event.target))) && (event.target.id === "player-api" || playerApi.contains(event.target))) {
                event.preventDefault();
                if (direction > 0 && currentVol > 0) {
                    api.setVolume(currentVol - 5);
                } else if (direction < 0 && currentVol < 100) {
                    api.setVolume(currentVol + 5);
                }
            }
            if (!event && parSets.VID_VOL_WHEEL) {
                eventHandler(window, "wheel", volumeWheel);
            } else if (window.location.pathname !== "/watch") {
                eventHandler(window, "wheel", volumeWheel, false, "remove");
            }
        }
        function playlistControls() {
            var href  = window.location.href,
                plBar = document.getElementById("watch-appbar-playlist");
            function reverseControl() {
                var temp,
                    prev   = document.getElementsByClassName("prev-playlist-list-item")[0],
                    next   = document.getElementsByClassName("next-playlist-list-item")[0],
                    list   = document.getElementById("playlist-autoscroll-list"),
                    videos = list.getElementsByTagName("li"),
                    length = videos.length;
                while (length) {
                    length -= 1;
                    list.appendChild(videos[length]);
                }
                temp = prev.href;
                prev.href = next.href;
                next.href = temp;
                list.scrollTop = document.getElementsByClassName("currently-playing")[0].offsetTop;
                if (api) {
                    api.updatePlaylist();
                }
            }
            function reverseButton(event) {
                event = isChrome ? event.target.parentNode : event.target;
                event.classList.toggle("yt-uix-button-toggled");
                set("plRev", (event.classList.contains("yt-uix-button-toggled")) ? window.yt.config_.LIST_ID : false);
                reverseControl();
            }
            function autoplayButton(event) {
                event = isChrome ? event.target.parentNode : event.target;
                event.classList.toggle("yt-uix-button-toggled");
                set("plApl", event.classList.contains("yt-uix-button-toggled"));
            }
            function createButton(type, label, bool, call) {
                var navCtrls = document.getElementsByClassName("playlist-nav-controls")[0],
                    button   = [
                        "<button data-tooltip-text='" + label + "' class='yt-uix-button yt-uix-button-player-controls yt-uix-button-opacity yt-uix-tooltip" + (((bool === true || href.split(bool).length > 1) && " yt-uix-button-toggled") || '') + "'' type='button' title='" + label + "' id='" + type + "'>\n",
                        "    <span class='yt-uix-button-icon yt-uix-button-icon-watch-appbar-" + type + "-video-list'></span>\n",
                        "</button>\n"
                    ].join("");
                plBar.className = plBar.className.replace("radio-playlist", "");
                button = string2HTML(button).querySelector("button");
                eventHandler(button, "click", call);
                navCtrls.appendChild(button);
            }
            if (plBar) {
                if (document.readyState === "complete" && href.split(parSets.plRev).length > 1) {
                    reverseControl();
                }
                if (parSets.VID_PLST_RVRS && !document.getElementById("reverse")) {
                    createButton("reverse", userLang("PLST_RVRS"), parSets.plRev, reverseButton);
                }
                if (parSets.VID_PLST_ATPL && !document.getElementById("autoplay")) {
                    createButton("autoplay", userLang("PLST_AP"), parSets.plApl, autoplayButton);
                }
            }
        }
        function advancedOptions() {
            var header      = document.getElementById("watch-header"),
                cnslBtn     = document.getElementById("console-button"),
                cnslCont    = document.getElementById("advanced-options"),
                controls    = document.getElementById("player-console"),
                videoPlayer = document.getElementsByTagName("video")[0],
                storyBoard  = window.ytplayer && window.ytplayer.config && window.ytplayer.config.args && window.ytplayer.config.args.storyboard_spec;
            function hookButtons() {
                var loopButton  = controls.querySelector("#loop-button"),
                    fullBrowser = controls.querySelector("#fullbrowser-button"),
                    cinemaMode  = controls.querySelector("#cinemamode-button"),
                    frameStep   = controls.querySelector("#framestep-button");
                function togglePlay() {
                    var autoPlay = document.getElementById("autoplay-button");
                    set("VID_PLR_ATPL", !parSets.VID_PLR_ATPL);
                    autoPlay.classList[(parSets.VID_PLR_ATPL) ? "add" : "remove"]("active");
                }
                function toggleLoop(event) {
                    videoPlayer = document.getElementsByTagName("video")[0];
                    if (videoPlayer) {
                        videoPlayer.loop = event ? !parSets.loopVid : parSets.loopVid;
                        if (event) {
                            loopButton.classList[(!parSets.loopVid) ? "add" : "remove"]("active");
                        }
                    }
                    set("loopVid", loopButton.classList.contains("active"));
                }
                function toggleMap() {
                    var seekMap   = document.getElementById("seek-map"),
                        container = document.getElementById("seek-thumb-map") || false,
                        thumbs    = [],
                        thumbControls,
                        thumbsContainer,
                        matrix,
                        base;
                    storyBoard = window.ytplayer && window.ytplayer.config && window.ytplayer.config.args && window.ytplayer.config.args.storyboard_spec;
                    function centerThumb() {
                        var thumbJump;
                        videoPlayer = document.getElementsByTagName("video")[0];
                        thumbsContainer = document.getElementById("seek-thumbs");
                        thumbJump = thumbsContainer.getElementsByTagName("span")[1];
                        if (videoPlayer && videoPlayer.currentTime > 0 && !container.classList.contains("invisible")) {
                            thumbsContainer.scrollLeft = (thumbJump.offsetWidth + 10) * (videoPlayer.currentTime / thumbJump.getAttribute("data-time-jump")) - (thumbsContainer.offsetWidth / 2) + ((thumbJump.offsetWidth + 10) / 2);
                        } else {
                            thumbsContainer.scrollLeft = 0;
                        }
                    }
                    function clickManager(event) {
                        var timeJump = event.target.getAttribute("data-time-jump"),
                            quality  = event.target.className.split("quality").length;
                        if (timeJump) {
                            if (videoPlayer.src !== "") {
                                videoPlayer.currentTime = timeJump;
                            } else {
                                window.yt.www.watch.player.seekTo(timeJump);
                            }
                        }
                        if (quality > 1 && event.target.tagName === "DIV") {
                            container.className = event.target.className;
                            thumbsContainer.remove();
                            thumbsContainer = "<div id='seek-thumbs'>" + thumbs[event.target.className.replace("quality-", "")] + "</div>\n";
                            thumbsContainer = string2HTML(thumbsContainer).querySelector("#seek-thumbs");
                            container.appendChild(thumbsContainer);
                            centerThumb();
                        }
                    }
                    function removeOld() {
                        if (container) {
                            container.remove();
                            seekMap.classList.remove("active");
                        }
                        eventHandler(container, "click", clickManager);
                        eventHandler(window, "spfdone", removeOld, false, "remove");
                    }
                    function parseThumbs() {
                        thumbControls = "<div id='seek-controls'>\n";
                        function matrixIterator(qualities, level) {
                            var i,
                                currentBase,
                                details,
                                thumbAmount,
                                frameAmount = 0,
                                gridX       = 0,
                                gridY       = 0;
                            level -= 1;
                            if (qualities.split("storyboard").length < 2 && qualities.split("default").length < 2) {
                                details = qualities.split("#");
                                currentBase = base.replace("$L", level).replace("$N", details[6]);
                                thumbAmount = details[2] - 1;
                                for (i = 0; i < thumbAmount; i += 1) {
                                    if (!thumbs[level]) {
                                        thumbs[level] = "";
                                    }
                                    thumbs[level] += [
                                        "<span class='quality-" + level + "'",
                                        " data-time-jump='" + ((i * details[5]) / 1000) + "'",
                                        " style='background-image: url(" + currentBase.replace('$M', frameAmount) + "?sigh=" + details[7] + ");",
                                        " background-position: -" + (gridX * details[0]) + "px -" + (gridY * details[1]) + "px;",
                                        " width: " + (details[0] - 2) + "px; height: " + ((details[1] % 2 === 0) ? details[1] : details[1] - 1) + "px;'>\n",
                                        "    <div class='timer'>" + timeConv((i * details[5]) / 1000) + "</div>\n",
                                        "</span>\n"
                                    ].join('');
                                    if (gridX === details[3] - 1 && gridY === details[4] - 1) {
                                        frameAmount += 1;
                                        gridY = gridX = 0;
                                    } else {
                                        gridY = (gridX === details[3] - 1) ? gridY + 1 : gridY;
                                        gridX = (gridX === details[3] - 1) ? 0 : gridX + 1;
                                    }
                                }
                            }
                            level += 1;
                            if (level > 1) {
                                thumbControls += "<div class='quality-" + (level - 1) + "'>" + ((level < 3 && userLang("CNSL_SKMP_SMAL")) || (level < 4 && userLang("CNSL_SKMP_MED")) || (level < 5 && userLang("CNSL_SKMP_LRGE"))) + "</div>\n";
                            }
                        }
                        matrix.forEach(matrixIterator);
                        thumbControls += "</div>\n";
                    }
                    if (storyBoard) {
                        matrix = storyBoard && storyBoard.split("|");
                        base = matrix[0];
                        if (!container) {
                            seekMap.classList.toggle("active");
                            parseThumbs();
                            container +=
                                "<div id='seek-thumb-map' class='" + ((thumbs[2] && "quality-2") || (thumbs[1] && "quality-1")) + "''>\n" +
                                thumbControls +
                                "    <div id='seek-thumbs'>" + (thumbs[2] || thumbs[1]) + "</div>\n" +
                                "</div>";
                            container = string2HTML(container).querySelector("#seek-thumb-map");
                            document.getElementById("movie_player").appendChild(container);
                            centerThumb();
                            eventHandler(container, "click", clickManager);
                            eventHandler(window, "spfdone", removeOld);
                        } else if (container.id) {
                            seekMap.classList.toggle("active");
                            container.classList.toggle("invisible");
                            centerThumb();
                        }
                    }
                }
                function dlThumb() {
                    var args     = window.ytplayer.config.args,
                        base     = (args.iurl_webp) ? "_webp" : "",
                        thumbURL = args["iurlmaxres" + base] || args["iurlsd" + base] || args["iurl" + base];
                    window.open(thumbURL);
                }
                function saveSS() {
                    var width,
                        height,
                        aspectRatio,
                        video     = document.getElementsByTagName("video")[0],
                        container = document.getElementById("screenshot-result") || document.createElement("div"),
                        canvas    = container.querySelector("canvas") || document.createElement("canvas"),
                        close     = document.createElement("div"),
                        context   = canvas.getContext("2d");
                    function hideContainer() {
                        container.classList.toggle("invisible");
                    }
                    aspectRatio = video.videoWidth / video.videoHeight;
                    width = video.videoWidth;
                    height = parseInt(width / aspectRatio, 10);
                    canvas.width = width;
                    canvas.height = height;
                    context.drawImage(video, 0, 0, width, height);
                    if (!container.id) {
                        container.id = "screenshot-result";
                        container.appendChild(canvas);
                        close.id = "close-screenshot";
                        close.textContent = userLang("CNSL_SS_CLS");
                        eventHandler(close, "click", hideContainer);
                        container.appendChild(close);
                        document.body.appendChild(container);
                    } else if (container.id && container.classList.contains("invisible")) {
                        container.classList.toggle("invisible");
                    }
                }
                function openSidebar() {
                    var sidebarAlign = (parSets.VID_SDBR_ALGN > 1) ? ",left=" + (window.screen.availWidth - 467) : (parSets.VID_SDBR_ALGN < 1) ? "" : ",left=0",
                        newSidebar   = window.open(window.location.href, "sidebarMode", "width=467,height=" + window.screen.availHeight + ",scrollbars=1" + sidebarAlign);
                    function snapFit() {
                        newSidebar.resizeTo(newSidebar.outerWidth, window.screen.availHeight);
                    }
                    newSidebar.addEventListener("readystatechange", snapFit, true);
                    newSidebar.focus();
                }
                function toggleFullBrowser(event) {
                    var plrState = api && api.getPlayerState && api.getPlayerState() < 5 && api.getPlayerState() > 0;
                    function exitFullBrowser(key) {
                        if (document.documentElement.classList.contains("part_fullbrowser") && (key.keyCode === 27 || key.key === "Escape" || key.target.className.split("ytp-size").length > 1)) {
                            toggleFullBrowser(key);
                            if (key.type === "click") {
                                eventHandler(document, "keydown", exitFullBrowser, false, "remove");
                                eventHandler(document, "click", exitFullBrowser, false, "remove");
                                key.target.click();
                            }
                        }
                    }
                    eventHandler(document, "keydown", exitFullBrowser);
                    eventHandler(document, "click", exitFullBrowser);
                    set("fullBrs", event ? !parSets.fullBrs : true);
                    fullBrowser.classList[(parSets.fullBrs) ? "add" : "remove"]("active");
                    if (event && (plrState || event.keyCode === 27 || event.key === "Escape")) {
                        document.documentElement.classList[(parSets.fullBrs) ? "add" : "remove"]("part_fullbrowser");
                    }
                }
                function toggleCinemaMode(event) {
                    var plrState = api && api.getPlayerState && api.getPlayerState() < 5 && api.getPlayerState() > 0;
                    set("lightsOut", event ? !parSets.lightsOut : true);
                    cinemaMode.classList[(parSets.lightsOut) ? "add" : "remove"]("active");
                    if (event && plrState) {
                        document.documentElement.classList[(parSets.lightsOut) ? "add" : "remove"]("part_cinema_mode");
                    }
                }
                function toggleFrames(event) {
                    var pi,
                        fps;
                    frameStep = document.getElementById("framestep-button");
                    function currentFps(keys) {
                        if (typeof pi[keys] === "object" && pi[keys] && pi[keys].video && pi[keys].video.fps) {
                            fps = pi[keys].video.fps;
                        }
                    }
                    if (event) {
                        if (event.shiftKey) {
                            event.target.blur();
                            document.getSelection().removeAllRanges();
                            if (event.keyCode === 37 || event.keyCode === 39) {
                                pi = playerInstance.getVideoData();
                                Object.keys(pi).forEach(currentFps);
                                fps = fps && ((event.keyCode < 39 && -1) || 1) * ((fps < 2 && 30) || fps);
                                if (fps && api) {
                                    api.pauseVideo();
                                    api.seekBy(1 / fps);
                                }
                            }
                        } else if (event.type === "click" && event.target.id === "framestep-button") {
                            set("frameStep", !parSets.frameStep);
                            frameStep.classList[(parSets.frameStep) ? "add" : "remove"]("active");
                        }
                    }
                    if (frameStep && frameStep.classList.contains("active")) {
                        eventHandler(document, "keydown", toggleFrames);
                    } else if (!frameStep || !frameStep.classList.contains("active")) {
                        eventHandler(document, "keydown", toggleFrames, false, "remove");
                    }
                }
                function handleToggles(event) {
                    switch (event.target.id) {
                    case "autoplay-button":
                        togglePlay();
                        break;
                    case "loop-button":
                        toggleLoop(event);
                        break;
                    case "seek-map":
                        toggleMap();
                        break;
                    case "save-thumbnail-button":
                        dlThumb();
                        break;
                    case "screenshot-button":
                        saveSS();
                        break;
                    case "sidebar-button":
                        openSidebar();
                        break;
                    case "fullbrowser-button":
                        toggleFullBrowser(event);
                        break;
                    case "cinemamode-button":
                        toggleCinemaMode(event);
                        break;
                    case "framestep-button":
                        toggleFrames(event);
                        break;
                    }
                }
                eventHandler(cnslCont, "click", handleToggles);
                if (parSets.loopVid && !loopButton.classList.contains("active")) {
                    loopButton.classList.add("active");
                    toggleLoop();
                }
                if (parSets.fullBrs && !fullBrowser.classList.contains("active")) {
                    fullBrowser.classList.add("active");
                    toggleFullBrowser();
                }
                if (parSets.lightsOut && !cinemaMode.classList.contains("active")) {
                    cinemaMode.classList.add("active");
                    toggleCinemaMode();
                }
                if (parSets.frameStep && !frameStep.classList.contains("active")) {
                    frameStep.classList.add("active");
                    toggleFrames();
                }
            }
            function toggleConsole() {
                document.documentElement.classList.toggle("player-console");
                set("advOpts", document.documentElement.classList.contains("player-console"));
            }
            if (window.location.pathname === "/watch" && header && !cnslBtn) {
                cnslBtn = "<button id='console-button' title='" + userLang("ADV_OPTS") + "'></button>";
                cnslBtn = string2HTML(cnslBtn).querySelector("#console-button");
                eventHandler(cnslBtn, "click", toggleConsole);
                cnslCont = "<div id='advanced-options'></div>";
                cnslCont = string2HTML(cnslCont).querySelector("#advanced-options");
                cnslCont.appendChild(cnslBtn);
                header.appendChild(cnslCont);
                if (controls) {
                    controls.remove();
                }
                controls = [
                    "<div id='player-console'>\n",
                    "    <div id='autoplay-button' class='yt-uix-tooltip" + ((parSets.VID_PLR_ATPL) ? " active" : "") + "' data-tooltip-text='" + userLang("CNSL_AP") + "''></div>\n",
                    "    <div id='loop-button' class='yt-uix-tooltip' data-tooltip-text='" + userLang("CNSL_RPT") + "'></div>\n",
                    "    <div id='seek-map' class='yt-uix-tooltip' data-tooltip-text='" + (storyBoard ? userLang("CNSL_SKMP") : userLang("CNSL_SKMP_OFF")) + "'" + ((!storyBoard) ? "style='opacity:0.2;'" : "") + "></div>\n",
                    "    <div id='save-thumbnail-button' class='yt-uix-tooltip' data-tooltip-text='" + userLang("CNSL_SVTH") + "'></div>\n",
                    "    <div id='screenshot-button' class='yt-uix-tooltip' data-tooltip-text='" + userLang("CNSL_SS") + "''></div>\n",
                    "    <div id='sidebar-button' class='yt-uix-tooltip' data-tooltip-text='" + userLang("CNSL_SDBR") + "'" + ((window.opener) ? " style='display:none'" : "") + "></div>\n",
                    "    <div id='fullbrowser-button' class='yt-uix-tooltip' data-tooltip-text='" + userLang("CNSL_FLBR") + "'></div>\n",
                    "    <div id='cinemamode-button' class='yt-uix-tooltip' data-tooltip-text='" + userLang("CNSL_CINM_MD") + "'></div>\n",
                    "    <div id='framestep-button' class='yt-uix-tooltip' data-tooltip-text='" + userLang("CNSL_FRME") + "'></div>\n",
                    "</div>\n"
                ].join("");
                controls = string2HTML(controls).querySelector("div");
                cnslCont.appendChild(controls);
                hookButtons();
                if (parSets.advOpts) {
                    document.documentElement.classList.add("player-console");
                }
            }
        }
        function defaultChannelPage(event) {
            var observer,
                channelLink,
                loadMore = document.getElementsByClassName("load-more-button")[0];
            function linkIterator(link) {
                if (link !== "length" && channelLink[link].href.split("/").length < 6 && parSets.GEN_CHN_DFLT_PAGE !== "default") {
                    channelLink[link].href += "/" + parSets.GEN_CHN_DFLT_PAGE;
                }
            }
            if (parSets.GEN_CHN_DFLT_PAGE !== "default") {
                if (loadMore && !loadMore.classList.contains("defaultChannel")) {
                    loadMore.classList.add("defaultChannel");
                    observer = new window.MutationObserver(defaultChannelPage);
                    observer.observe(loadMore, {attributes: true});
                }
                if (event && event.target && event.target.tagName === "A" && !event.target.classList.contains("spf-link") && event.target.href.split(parSets.GEN_CHN_DFLT_PAGE).length < 2 && (event.target.href.split("/channel/").length > 1 || event.target.href.split("/user/").length > 1)) {
                    event.target.href += "/" + parSets.GEN_CHN_DFLT_PAGE;
                } else if (!event || (event && event[0])) {
                    if (window.location.href.split(/\/(channel|user|c)\//).length < 2) {
                        channelLink = document.querySelectorAll("[href*='/channel/']");
                        Object.keys(channelLink).forEach(linkIterator);
                        channelLink = document.querySelectorAll("[href*='/user/']");
                        Object.keys(channelLink).forEach(linkIterator);
                    }
                    eventHandler(document, "click", defaultChannelPage);
                }
            }
        }
        function generalChanges() {
            var logo,
                autoplaybar = document.getElementsByClassName("autoplay-bar")[0],
                description = document.getElementById("action-panel-details");
            if (parSets.GEN_YT_LOGO_LINK && window.yt && window.yt.config_ && window.yt.config_.LOGGED_IN) {
                logo = document.getElementById("logo-container");
                if (logo && logo.href === window.location.origin + "/") {
                    logo.href = "/feed/subscriptions";
                }
            }
            if (parSets.GEN_REM_APUN && window.location.pathname === "/watch" && autoplaybar) {
                autoplaybar.removeAttribute("class");
                document.getElementsByClassName("checkbox-on-off")[0].remove();
            }
            if (parSets.VID_LAYT_AUTO_PNL && window.location.pathname === "/watch" && description) {
                description.classList.remove("yt-uix-expander-collapsed");
            }
            if (parSets.GEN_SPF_OFF && window.spf && window.spf.dispose) {
                window.spf.dispose();
            }
            if (window.location.href.split("/channel/").length > 1 && document.body && document.documentElement.scrollTop + document.body.scrollTop > 266) {
                document.documentElement.scrollTop = document.body.scrollTop = 0;
            }
        }
        function infiniteScroll() {
            var observer,
                loadMore = document.getElementsByClassName("load-more-button")[0];
            if (loadMore && parSets.GEN_INF_SCRL) {
                if (!loadMore.classList.contains("infiniteScroll")) {
                    loadMore.classList.add("infiniteScroll");
                    observer = new window.MutationObserver(infiniteScroll);
                    observer.observe(loadMore, {attributes: true});
                } else if (!loadMore.classList.contains("scrolldetect")) {
                    loadMore.classList.add("scrolldetect");
                    loadMore.setAttribute("data-scrolldetect-callback", "load-more-auto");
                }
            }
        }
        function initFunctions() {
            customStyles();
            settingsMenu();
            infiniteScroll();
            playlistControls();
            playerMode();
            advancedOptions();
            volumeWheel();
            subPlaylist();
            alwaysVisible();
            thumbMod();
            enhancedDetails();
            commentsButton();
            defaultChannelPage();
            generalChanges();
            clearOrphans();
        }
        function request(event) {
            var listAfter   = event.detail.url.split("list=").length > 1,
                videoAfter  = event.detail.url.split("/watch?").length > 1,
                listBefore  = event.detail.previous.split("list=").length > 1,
                videoBefore = event.detail.previous.split("/watch?").length > 1,
                videoPlayer = document.getElementById("movie_player"),
                videoLoaded = window.ytplayer && window.ytplayer.config && window.ytplayer.config.loaded;
            document.documentElement.classList.remove("floater");
            if (videoPlayer) {
                videoPlayer.removeAttribute("style");
                if ((videoBefore && !videoAfter) || (videoAfter && (listAfter !== listBefore || !videoBefore))) {
                    if (videoLoaded) {
                        delete window.ytplayer.config.loaded;
                    }
                    videoPlayer.remove();
                }
            }
        }
        function shareApi(originalFunction) {
            return function (ytApi) {
                playerReady(ytApi);
                if (originalFunction) {
                    return originalFunction.apply(this, arguments);
                }
            };
        }
        function checkNewFeatures() {
            var keys = Object.keys(defSets),
                i    = keys.length;
            while (i) {
                i -= 1;
                if (!parSets.hasOwnProperty(keys[i])) {
                    set(keys[i], defSets[keys[i]]);
                }
            }
        }
        if (!parSets || Object.keys(parSets).length < 1) {
            parSets = defSets;
        } else {
            checkNewFeatures();
        }
        if (isChrome) {
            eventHandler(document.documentElement, "load", scriptExit, true);
        } else {
            eventHandler(window, "afterscriptexecute", scriptExit);
        }
        eventHandler(window, "message", updateSettings);
        eventHandler(window, "spfdone", initFunctions);
        eventHandler(window, "spfrequest", request);
        eventHandler(window, "readystatechange", initFunctions, true);
        window.onYouTubePlayerReady = shareApi(window.onYouTubePlayerReady);
        window.matchMedia = false;
        initFunctions();
    }
    function updateSettings(event) {
        event = (event && event.particleSettings) || event || {};
        event.updateSettings = true;
        window.postMessage(event, "*");
    }
    function initParticle(event) {
        var inject;
        function filterChromeStorage(keys) {
            if (keys.particleSettings && keys.particleSettings.newValue) {
                updateSettings(keys.particleSettings.newValue);
            }
        }
        if (!event && userscript) {
            event = JSON.parse(window.GM_getValue("particleSettings", "{}"));
        }
        if (event) {
            event = JSON.stringify(event.particleSettings || event);
            inject = document.createElement("style");
            inject.textContent = styleSheet;
            document.documentElement.appendChild(inject);
            inject = document.createElement("script");
            inject.textContent = "(" + String(particle).replace("parSets,", "parSets = " + event + ",") + "())";
            document.documentElement.appendChild(inject);
            if (!userscript) {
                if (window.chrome) {
                    window.chrome.storage.onChanged.addListener(filterChromeStorage);
                } else {
                    window.self.port.on("particleSettings", updateSettings);
                }
            }
        }
    }
    function internalXHR(details) {
        details = details.data;
        if (typeof details === "object" && details.set) {
            if (userscript) {
                window.GM_setValue("particleSettings", JSON.stringify(details.set));
                updateSettings(JSON.parse(window.GM_getValue("particleSettings", "{}")));
            } else if (window.chrome) {
                window.chrome.storage.local.set({"particleSettings": details.set});
            } else {
                window.self.port.emit("particleSettings", details);
            }
        }
    }
    if (userscript) {
        window.GM_getValue = GM_getValue;
        window.GM_setValue = GM_setValue;
        initParticle();
    } else if (window.chrome) {
        window.chrome.storage.local.get("particleSettings", initParticle);
    } else {
        window.self.port.once("particleSettings", initParticle);
    }
    window.addEventListener("message", internalXHR);
}());