Convert Email Address to Duckduckgo Anonymous email format

Converts an email to duckgo anonymous email format, now with minimize functionality

当前为 2025-03-01 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Convert Email Address to Duckduckgo Anonymous email format
  3. // @namespace http://tampermonkey.net/
  4. // @author aspen138
  5. // @version 1.1.2
  6. // @description Converts an email to duckgo anonymous email format, now with minimize functionality
  7. // @match https://mail.google.com/*
  8. // @match https://gmail.com/*
  9. // @match https://outlook.live.com/*
  10. // @match https://outlook.com/*
  11. // @match https://mail.yahoo.com/*
  12. // @match https://yahoo.com/mail/*
  13. // @match https://mail.qq.com/*
  14. // @match https://exmail.qq.com/*
  15. // @match https://proton.me/*
  16. // @match https://mail.proton.me/*
  17. // @match https://icloud.com/mail/*
  18. // @match https://mail.apple.com/*
  19. // @match https://zoho.com/mail/*
  20. // @match https://mail.zoho.com/*
  21. // @match https://mail.aol.com/*
  22. // @match https://aol.com/mail/*
  23. // @match https://www.mail.com/*
  24. // @match https://email.mail.com/*
  25. // @match https://mail.yandex.com/*
  26. // @match https://yandex.com/mail/*
  27. // @match https://mail.163.com/*
  28. // @match https://www.163.com/mail/*
  29. // @match https://mail.126.com/*
  30. // @match https://www.126.com/*
  31. // @match https://mail.sina.com/*
  32. // @match https://mail.sina.com.cn/*
  33. // @match https://gmx.com/*
  34. // @match https://mail.gmx.com/*
  35. // @match https://fastmail.com/*
  36. // @match https://mail.fastmail.com/*
  37. // @icon 
  38. // @iconbackup https://ssl.gstatic.com/ui/v1/icons/mail/rfr/gmail.ico
  39. // @license MIT
  40. // @grant GM_getValue
  41. // @grant GM_setValue
  42. // ==/UserScript==
  43.  
  44. (function() {
  45. 'use strict';
  46.  
  47. // Retrieve a stored value for demonstration (not essential for minimizing logic)
  48. const testStoredSendTo = GM_getValue('whatever', '');
  49. console.log("testStoredSendTo", testStoredSendTo);
  50.  
  51. // Create a container for the floating box
  52. const container = document.createElement('div');
  53. container.style.position = 'fixed';
  54. container.style.bottom = '20px';
  55. container.style.left = '20px';
  56. container.style.zIndex = '9999';
  57. container.style.padding = '10px';
  58. container.style.backgroundColor = '#fff';
  59. container.style.border = '1px solid #ccc';
  60. container.style.borderRadius = '5px';
  61. container.style.boxShadow = '0 0 5px rgba(0,0,0,0.3)';
  62. container.style.fontFamily = 'Arial, sans-serif';
  63. container.style.maxWidth = '280px';
  64.  
  65. // Title or heading
  66. const heading = document.createElement('h4');
  67. heading.textContent = 'Email Converter';
  68. heading.style.margin = '0 0 10px 0';
  69. container.appendChild(heading);
  70.  
  71. // Close (minimize) button
  72. const minimizeButton = document.createElement('button');
  73. minimizeButton.textContent = 'X';
  74. minimizeButton.style.position = 'absolute';
  75. minimizeButton.style.top = '5px';
  76. minimizeButton.style.right = '10px';
  77. minimizeButton.style.cursor = 'pointer';
  78. minimizeButton.style.border = 'none';
  79. minimizeButton.style.background = 'none';
  80. minimizeButton.style.fontSize = '16px';
  81. container.appendChild(minimizeButton);
  82.  
  83. // This button will appear when the container is minimized
  84. const restoreButton = document.createElement('button');
  85. restoreButton.textContent = 'Email Converter';
  86. restoreButton.style.position = 'fixed';
  87. restoreButton.style.left = '0';
  88. restoreButton.style.bottom = '20px';
  89. restoreButton.style.zIndex = '9999';
  90. restoreButton.style.padding = '6px 12px';
  91. restoreButton.style.cursor = 'pointer';
  92. restoreButton.style.border = '1px solid #ccc';
  93. restoreButton.style.borderRadius = '5px';
  94. restoreButton.style.fontFamily = 'Arial, sans-serif';
  95. restoreButton.style.backgroundColor = '#fff';
  96. restoreButton.style.boxShadow = '0 0 5px rgba(0,0,0,0.3)';
  97. // Initially hidden
  98. // restoreButton.style.display = 'none';
  99. container.style.display = 'none';
  100. restoreButton.style.display = 'block';
  101. document.body.appendChild(restoreButton);
  102.  
  103. // When the user clicks the "X", hide the container and show the restore button
  104. minimizeButton.addEventListener('click', () => {
  105. container.style.display = 'none';
  106. restoreButton.style.display = 'block';
  107. });
  108.  
  109. // When the user clicks restore, show the container and hide the restore button
  110. restoreButton.addEventListener('click', () => {
  111. container.style.display = 'block';
  112. restoreButton.style.display = 'none';
  113. });
  114.  
  115. // Wrapper to neatly organize form elements
  116. const formWrapper = document.createElement('div');
  117. formWrapper.style.display = 'flex';
  118. formWrapper.style.flexDirection = 'column';
  119. formWrapper.style.gap = '5px';
  120.  
  121. // Retrieve stored values (if any)
  122. const storedSendTo = GM_getValue('converterSendTo', '');
  123. const storedDdgo = GM_getValue('converterDdgo', '');
  124.  
  125. // Label and input for "send email to who?"
  126. const labelSendTo = document.createElement('label');
  127. labelSendTo.textContent = 'Send email to who: ';
  128. labelSendTo.style.marginRight = '10px';
  129.  
  130. const inputSendTo = document.createElement('input');
  131. inputSendTo.type = 'text';
  132. inputSendTo.placeholder = 'e.g. 123@qq.com';
  133. inputSendTo.style.width = '250px';
  134. inputSendTo.value = storedSendTo;
  135.  
  136. const rowSendTo = document.createElement('div');
  137. rowSendTo.appendChild(labelSendTo);
  138. rowSendTo.appendChild(inputSendTo);
  139.  
  140. // Label and input for "your ddgo mail?"
  141. const labelDdgo = document.createElement('label');
  142. labelDdgo.textContent = 'Your DuckduckGo address: ';
  143. labelDdgo.style.marginRight = '10px';
  144.  
  145. const inputDdgo = document.createElement('input');
  146. inputDdgo.type = 'text';
  147. inputDdgo.placeholder = 'e.g. dd@duck.com';
  148. inputDdgo.style.width = '250px';
  149. inputDdgo.value = storedDdgo;
  150.  
  151. const rowDdgo = document.createElement('div');
  152. rowDdgo.appendChild(labelDdgo);
  153. rowDdgo.appendChild(inputDdgo);
  154.  
  155. // Convert button
  156. const buttonConvert = document.createElement('button');
  157. buttonConvert.textContent = 'Convert';
  158. buttonConvert.style.marginRight = '10px';
  159. buttonConvert.style.cursor = 'pointer';
  160. buttonConvert.style.width = '250px';
  161.  
  162. // Output field for converted email
  163. const labelOutput = document.createElement('label');
  164. labelOutput.textContent = 'Converted: ';
  165. labelOutput.style.marginRight = '10px';
  166.  
  167. const outputEmail = document.createElement('input');
  168. outputEmail.type = 'text';
  169. outputEmail.readOnly = true;
  170. outputEmail.style.width = '250px';
  171.  
  172. const rowOutput = document.createElement('div');
  173. rowOutput.appendChild(labelOutput);
  174. rowOutput.appendChild(outputEmail);
  175.  
  176. // Feedback or error message area
  177. const feedback = document.createElement('p');
  178. feedback.style.color = 'red';
  179. feedback.style.fontSize = '14px';
  180. feedback.style.margin = '5px 0 0 0';
  181. feedback.style.minHeight = '18px';
  182. feedback.textContent = '';
  183.  
  184. // Conversion function
  185. buttonConvert.addEventListener('click', () => {
  186. const originalEmail = inputSendTo.value.trim();
  187. const ddgoEmail = inputDdgo.value.trim();
  188. let errorMessage = '';
  189.  
  190. // Simple validations
  191. if (!originalEmail) {
  192. errorMessage = 'Please enter an email address to convert.';
  193. } else if (!ddgoEmail) {
  194. errorMessage = 'Please enter your DDG address.';
  195. }
  196.  
  197. // Handle any errors
  198. if (errorMessage) {
  199. feedback.textContent = errorMessage;
  200. outputEmail.value = '';
  201. return;
  202. }
  203.  
  204. // Replace '@' with '_at_' and append the ddgo email
  205. const converted = originalEmail.replace(/@/g, '_at_') + '_' + ddgoEmail;
  206. outputEmail.value = converted;
  207. feedback.textContent = '';
  208.  
  209. // Save inputs to Tampermonkey storage
  210. GM_setValue('converterSendTo', originalEmail);
  211. GM_setValue('converterDdgo', ddgoEmail);
  212. });
  213.  
  214. // Assemble elements in the container
  215. formWrapper.appendChild(rowSendTo);
  216. formWrapper.appendChild(rowDdgo);
  217. formWrapper.appendChild(buttonConvert);
  218. formWrapper.appendChild(rowOutput);
  219. formWrapper.appendChild(feedback);
  220.  
  221. container.appendChild(formWrapper);
  222.  
  223. // Finally, attach the container to document body
  224. document.body.appendChild(container);
  225. })();