Google Search Various Ranges

增加Google搜索中指定期间的选项。

当前为 2020-09-07 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Google Search Various Ranges
  3. // @name:ja Google Search Various Ranges
  4. // @name:zh-CN Google Search Various Ranges
  5. // @description Add more time ranges on Google search.
  6. // @description:ja Google検索の期間指定の選択肢を増やします。
  7. // @description:zh-CN 增加Google搜索中指定期间的选项。
  8. // @namespace knoa.jp
  9. // @include https://www.google.*/search?*
  10. // @version 2.0.2
  11. // @grant none
  12. // ==/UserScript==
  13.  
  14. (function(){
  15. const SCRIPTNAME = 'GoogleSearchVariousRanges';
  16. const DEBUG = false;/*
  17. [update] 2.0.2
  18. fixed the layout bug.
  19. */
  20. if(window === top) console.time(SCRIPTNAME);
  21. const LANGS = ['en', 'ja', 'fr', 'ru', 'zh', 'es', 'ar'];
  22. const RANGES = {
  23. qdr_h: {
  24. h: ["Past hour", "1 時間以内", "Moins d'une heure", "За час", "过去 1 小时内", "Última hora", "آخر ساعة"],
  25. h2: ["Past 2 hours", "2 時間以内", "Moins de 2 heures", "За 2 часа", "过去 2 小时内", "Últimas 2 horas", "آخر ساعتين"],
  26. h12:["Past 12 hours", "12 時間以内", "Moins de 12 heures", "За 12 часов", "过去 12 小时内", "Últimas 12 horas", "آخر ١٢ ساعة"],
  27. },
  28. qdr_d: {
  29. d: ["Past day", "1 日以内", "Moins d'un jour", "За 1 дня", "过去 1 天内", "Último 1 día", "آخر 24 ساعة"],
  30. d2: ["Past 2 days", "2 日以内", "Moins de 2 jours", "За 2 дня", "过去 2 天内", "Últimos 2 días", "آخر يومين"],
  31. d3: ["Past 3 days", "3 日以内", "Moins de 3 jours", "За 3 дня", "过去 3 天内", "Últimos 3 días", "آخر ٣ أيام"],
  32. },
  33. qdr_w: {
  34. w: ["Past week", "1 週間以内", "Moins d'une semaine", "За неделю", "过去 1 周内", "Última semana", "آخر أسبوع"],
  35. w2: ["Past 2 weeks", "2 週間以内", "Moins de 2 semaines", "За 2 недели", "过去 2 周内", "Últimas 2 semanas", "آخر أسبوعين"],
  36. },
  37. qdr_m: {
  38. m: ["Past month", "1 か月以内", "Moins d'un mois", "За месяц", "过去 1 个月内", "Último mes", "آخر شهر"],
  39. m2: ["Past 2 months", "2 か月以内", "Moins de 2 mois", "За 2 месяца", "过去 2 个月内", "Últimos 2 meses", "آخر شهرين"],
  40. m6: ["Past 6 months", "6 か月以内", "Moins de 6 mois", "За 6 месяца", "过去 6 个月内", "Últimos 6 meses", "آخر ٦ شهور"],
  41. },
  42. qdr_y: {
  43. y: ["Past year", "1 年以内", "Moins d'une an", "За год", "过去 1 年内", "Último año", "آخر سنة"],
  44. y2: ["Past 2 years", "2 年以内", "Moins de 2 ans", "За 2 года", "过去 2 年内", "Últimos 2 años", "آخر سنتين"],
  45. y5: ["Past 5 years", "5 年以内", "Moins de 5 ans", "За 5 года", "过去 5 年内", "Últimos 5 años", "آخر ٥ سنوات"],
  46. },
  47. };
  48. const PERIODS = [
  49. // You can edit or add below.
  50. //{
  51. // "in '90s": ['1/1/1990', '12/31/1999'],
  52. // "in '00s": ['1/1/2000', '12/31/2009'],
  53. // "in '10s": ['1/1/2010', '12/31/2019'],
  54. //},
  55. //{
  56. // "Before 2000": ['', '12/31/1999'],
  57. // "After 2000" : ['1/1/2000', ''],
  58. //},
  59. ];
  60. const PADDING = 30 + 44;/*default left+right padding size of each range items*/
  61. let elements = {}, sizes = {};
  62. let core = {
  63. initialize: function(){
  64. core.ready();
  65. },
  66. ready: function(){
  67. let qdr = document.querySelector('#qdr_'), a = document.querySelector('li[id^="qdr_"] a[href*="qdr:"]');
  68. if(qdr === null || a === null) return setTimeout(core.ready, 250);
  69. elements.ul = qdr.parentNode;
  70. elements.a = a;
  71. /* DOM operations */
  72. core.rebuildRanges();
  73. core.addCustomPeriods();
  74. core.replaceSelectedCheckmark();
  75. core.calculateWidth();
  76. },
  77. rebuildRanges: function(){
  78. let lang = document.documentElement.lang.split('-')[0];
  79. let lindex = (LANGS.includes(lang)) ? LANGS.indexOf(lang) : 0;
  80. let lis = elements.ul.querySelectorAll('li[id^="qdr_"]');
  81. for(let i = 1; lis[i]; i++){
  82. if(RANGES[lis[i].id]){
  83. for(let range in RANGES[lis[i].id]){
  84. let a = elements.a.cloneNode(true);
  85. a.href = a.href.replace(/(qdr:)[a-z][0-9]*/, '$1' + range);
  86. a.textContent = RANGES[lis[i].id][range][lindex];
  87. lis[i].appendChild(a);
  88. }
  89. lis[i].removeChild(lis[i].firstChild);
  90. }else{
  91. lis[i].style.display = 'none';
  92. }
  93. }
  94. },
  95. addCustomPeriods: function(){
  96. let cdr = elements.ul.querySelector('#cdrlnk');/*Custom range...*/
  97. for(let i = 0; PERIODS[i]; i++){
  98. let line = document.createElement('div');
  99. for(let key in PERIODS[i]){
  100. let a = elements.a.cloneNode(true);
  101. a.href = a.href.replace(/(qdr:)[a-z][0-9]*/, `cdr:1,cd_min:${PERIODS[i][key][0]},cd_max:${PERIODS[i][key][1]}`);
  102. a.textContent = key;
  103. line.appendChild(a);
  104. }
  105. cdr.parentNode.appendChild(line);
  106. }
  107. },
  108. replaceSelectedCheckmark: function(){
  109. let sel = elements.ul.querySelector('li[id*="dr_"].hdtbSel');
  110. if(sel && sel.id !== 'qdr_'/*Any time*/){
  111. let a, cdruri = location.href.match(/cdr:1,cd_min:[0-9\/]*,cd_max:[0-9\/]*/);
  112. if(cdruri){/*has period*/
  113. a = elements.ul.querySelector(`li[id^="cdr_"] a[href*="${cdruri[0]}"]`);
  114. }else{
  115. let qdr = sel.id.split('_')[1];
  116. a = elements.ul.querySelector(`li[id^="qdr_"] a[href*="qdr:${qdr}&"]`);
  117. }
  118. if(a){
  119. a.classList.add('hdtbSel');
  120. sel.classList.remove('hdtbSel');
  121. }
  122. }
  123. },
  124. calculateWidth: function(){
  125. /* for calculating width */
  126. elements.ul.style.visibility = 'visible';
  127. elements.ul.style.visibility = 'hidden';
  128. elements.ul.style.display = 'block';
  129. sizes.maxwidth = 0;
  130. /* calculate */
  131. let as = elements.ul.querySelectorAll('li[id^="qdr_"] a[href*="qdr:"]');
  132. for(let i = 0, a; a = as[i]; i++){
  133. if(sizes.maxwidth < a.offsetWidth) sizes.maxwidth = a.offsetWidth;
  134. }
  135. if(sizes.maxwidth === 0) return setTimeout(core.calculateWidth, 250);
  136. /* restore */
  137. elements.ul.style.visibility = '';
  138. elements.ul.style.display = '';
  139. core.addStyle();
  140. },
  141. addStyle: function(){
  142. (function(css){
  143. let head = document.querySelector('head');
  144. let style = document.createElement('style');
  145. style.type = 'text/css';
  146. style.textContent = css;
  147. head.appendChild(style);
  148. })(`
  149. #hdtb li[id^="qdr_"].hdtbItm a,
  150. #hdtb li[id^="cdr_"].hdtbItm a{
  151. display: inline-block !important;
  152. width: ${sizes.maxwidth - PADDING}px !important;
  153. padding-right: 20px !important;
  154. }
  155. `);
  156. },
  157. };
  158. let log = (DEBUG) ? console.log.bind(null, SCRIPTNAME + ':') : function(){};
  159. core.initialize();
  160. if(window === top) console.timeEnd(SCRIPTNAME);
  161. })();