diff options
| author | Stephen Blott | 2014-12-21 11:10:40 +0000 | 
|---|---|---|
| committer | Stephen Blott | 2014-12-21 11:10:40 +0000 | 
| commit | eb5750642c54e4c6ad6e12d348f0ce3d40bac0e1 (patch) | |
| tree | da47f63ff57f2e132d6296916926bf3ba41c1c0f | |
| parent | 1602338bbde44f1e38a6bf09c57cef51b7939a59 (diff) | |
| download | vimium-eb5750642c54e4c6ad6e12d348f0ce3d40bac0e1.tar.bz2 | |
Exclusion; highlight mismatched patterns.
| -rw-r--r-- | pages/options.coffee | 21 | ||||
| -rw-r--r-- | pages/popup.html | 11 | 
2 files changed, 27 insertions, 5 deletions
diff --git a/pages/options.coffee b/pages/options.coffee index 460f2789..cd932ed8 100644 --- a/pages/options.coffee +++ b/pages/options.coffee @@ -98,7 +98,9 @@ class ExclusionRulesOption extends Option        # On the options page, focus the pattern; on the page popup (where we already have a pattern), focus the        # passKeys.        focus = if @url then 1 else 0 -      @element.children[@element.children.length-1].children[focus].children[0].focus() +      element = @element.children[@element.children.length-1] +      element.children[focus].children[0].focus() +      @activatePatternWatcher element if @url        # Scroll the new rule into view.        exclusionScrollBox = $("exclusionScrollBox")        exclusionScrollBox.scrollTop = exclusionScrollBox.scrollHeight @@ -108,11 +110,14 @@ class ExclusionRulesOption extends Option      for rule in rules        @appendRule rule +    elements = @element.getElementsByClassName "exclusionRuleTemplateInstance" +    @activatePatternWatcher element for element in elements if @url +      # If this is the popup page (@url is truthy), then hide rules which do not match @url.  If no rules      # match, then add a default rule.  Focus the passKeys field in the last (most recent) rule.      if @url        haveMatch = false -      for element in @element.getElementsByClassName "exclusionRuleTemplateInstance" +      for element in elements          pattern = element.children[0].firstChild.value.trim()          if @url.match bgExclusions.RegexpCache.get pattern            haveMatch = true @@ -122,6 +127,18 @@ class ExclusionRulesOption extends Option        unless haveMatch          @addRule() +  # On the popup page, provide visual feedback when a pattern does not match the current page.  This assumes +  # that @url is not empty. +  activatePatternWatcher: (element) -> +    computedStyle = window.getComputedStyle(element) +    originalColor = computedStyle.getPropertyValue("color") +    patternElement = element.children[0].firstChild +    patternElement.addEventListener "keyup", => +      if @url.match bgExclusions.RegexpCache.get patternElement.value +        patternElement.style.color = originalColor +      else +        patternElement.style.color = "red" +    # Append a row for a new rule.    appendRule: (rule) ->      content = document.querySelector('#exclusionRuleTemplate').content diff --git a/pages/popup.html b/pages/popup.html index 2e59d471..0b4de131 100644 --- a/pages/popup.html +++ b/pages/popup.html @@ -25,9 +25,14 @@        #endSpace, #footerWrapper { width: 450px; }        #footerWrapper { margin-left: 0px; } +        /* Make exclusionScrollBox smaller than on the options page, because there are likely to be fewer -         matching rules, and the popup obscures the underlying page. */ -      #exclusionScrollBox { max-height: 124px; } +         matching rules, and the popup obscures the underlying page. +       */ +      #exclusionScrollBox { +        max-height: 124px; +        min-height: 124px; +      }        #endSpace { /* Leave space for the fixed footer. */          min-height: 46px; @@ -70,7 +75,7 @@                  <button id="saveOptions" disabled="true">No Changes</button>                  <button id="exclusionAddButton">Add Rule</button>                  <br/> -                <span> <a id="optionsLink" target="_blank">Vimium Options</a>.</span> +                <span> <a id="optionsLink" target="_blank">Vimium Options</a></span>                </span>              </td>            </tr>  | 
