mirror of
				https://github.com/Alamantus/Lexiconga.git
				synced 2025-10-26 05:56:43 +01:00 
			
		
		
		
	Update public link when changing dictionaries
This commit is contained in:
		
							parent
							
								
									a533ccbeba
								
							
						
					
					
						commit
						3d94a7c5ec
					
				
					 5 changed files with 32 additions and 9 deletions
				
			
		|  | @ -1,4 +1,5 @@ | ||||||
| import { setupLoginModal, setupChangeDictionary, setupCreateNewDictionary, setupDeletedDictionaryChangeModal, setupMakePublic } from "./setupListeners"; | import { setupLoginModal, setupChangeDictionary, setupCreateNewDictionary, setupDeletedDictionaryChangeModal, setupMakePublic } from "./setupListeners"; | ||||||
|  | import { getPublicLink } from "./utilities"; | ||||||
| import { request } from "./helpers"; | import { request } from "./helpers"; | ||||||
| 
 | 
 | ||||||
| export function renderLoginForm() { | export function renderLoginForm() { | ||||||
|  | @ -59,14 +60,13 @@ export function renderMakePublic() { | ||||||
|   let waitForSync = setInterval(() => { |   let waitForSync = setInterval(() => { | ||||||
|     if (window.currentDictionary.hasOwnProperty('externalID') && !isNaN(window.currentDictionary.externalID)) { |     if (window.currentDictionary.hasOwnProperty('externalID') && !isNaN(window.currentDictionary.externalID)) { | ||||||
|       clearInterval(waitForSync); |       clearInterval(waitForSync); | ||||||
|       const { externalID } = window.currentDictionary; |  | ||||||
|       const editSettingsTabHTML = `<label>Make Public
 |       const editSettingsTabHTML = `<label>Make Public
 | ||||||
|         <input type="checkbox" id="editIsPublic"${isPublic ? ' checked' : ''}><br> |         <input type="checkbox" id="editIsPublic"${isPublic ? ' checked' : ''}><br> | ||||||
|         <small>Checking this box will make this public via a link you can share with others.</small> |         <small>Checking this box will make this public via a link you can share with others.</small> | ||||||
|       </label> |       </label> | ||||||
|       <p id="publicLinkDisplay" style="${!isPublic ? 'display:none;': ''}margin-left:20px;"> |       <p id="publicLinkDisplay" style="${!isPublic ? 'display:none;': ''}margin-left:20px;"> | ||||||
|         <strong>Public Link:</strong><br> |         <strong>Public Link:</strong><br> | ||||||
|         <input readonly id="publicLink" value="${document.domain + window.location.pathname + (externalID ? externalID.toString() : '')}"> |         <input readonly id="publicLink" value="${getPublicLink()}"> | ||||||
|         <a class="small button" id="publicLinkCopy">Copy</a> |         <a class="small button" id="publicLinkCopy">Copy</a> | ||||||
|       </p> |       </p> | ||||||
|       `;
 |       `;
 | ||||||
|  |  | ||||||
|  | @ -1,7 +1,7 @@ | ||||||
| import { addMessage } from "../utilities"; | import { addMessage } from "../utilities"; | ||||||
| import { saveDictionary, clearDictionary } from "../dictionaryManagement"; | import { saveDictionary, clearDictionary } from "../dictionaryManagement"; | ||||||
| import { request } from "./helpers"; | import { request } from "./helpers"; | ||||||
| import { saveToken, dictionaryIsDefault } from "./utilities"; | import { saveToken, dictionaryIsDefault, getPublicLink } from "./utilities"; | ||||||
| import { renderAll } from "../render"; | import { renderAll } from "../render"; | ||||||
| import { sortWords } from "../wordManagement"; | import { sortWords } from "../wordManagement"; | ||||||
| import { getLocalDeletedWords, clearLocalDeletedWords, saveDeletedWordsLocally } from "./utilities"; | import { getLocalDeletedWords, clearLocalDeletedWords, saveDeletedWordsLocally } from "./utilities"; | ||||||
|  | @ -37,8 +37,14 @@ export function performSync(remoteDictionary) { | ||||||
|         syncWords(remoteDictionary.words, remoteDictionary.deletedWords).then(success => { |         syncWords(remoteDictionary.words, remoteDictionary.deletedWords).then(success => { | ||||||
|           if (success) { |           if (success) { | ||||||
|             renderAll(); |             renderAll(); | ||||||
|  |              | ||||||
|             document.getElementById('accountSettingsChangeDictionary').value = window.currentDictionary.externalID; |             document.getElementById('accountSettingsChangeDictionary').value = window.currentDictionary.externalID; | ||||||
|  |             if (document.getElementById('publicLink')) { | ||||||
|  |               document.getElementById('publicLink').value = getPublicLink(); | ||||||
|  |             } | ||||||
|  |             if (document.getElementById('publicLinkDisplay')) { | ||||||
|               document.getElementById('publicLinkDisplay').style.display = window.currentDictionary.settings.isPublic ? '' : 'none'; |               document.getElementById('publicLinkDisplay').style.display = window.currentDictionary.settings.isPublic ? '' : 'none'; | ||||||
|  |             } | ||||||
|           } else { |           } else { | ||||||
|             console.error('word sync failed'); |             console.error('word sync failed'); | ||||||
|           } |           } | ||||||
|  |  | ||||||
|  | @ -21,6 +21,22 @@ export function dictionaryIsDefault() { | ||||||
|   return JSON.stringify(defaultDictionary) === JSON.stringify(currentDictionary); |   return JSON.stringify(defaultDictionary) === JSON.stringify(currentDictionary); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | export function getPublicLink() { | ||||||
|  |   const { externalID } = window.currentDictionary; | ||||||
|  |   let path; | ||||||
|  |   if (externalID) { | ||||||
|  |     path = window.location.pathname.match(new RegExp(externalID + '$')) | ||||||
|  |       ? window.location.pathname | ||||||
|  |       : (window.location.pathname.indexOf(externalID) > -1 | ||||||
|  |         ? window.location.pathname.substring(0, window.location.pathname.indexOf(externalID)) + externalID | ||||||
|  |         : window.location.pathname + externalID | ||||||
|  |       ); | ||||||
|  |   } else { | ||||||
|  |     path = ''; | ||||||
|  |   } | ||||||
|  |   return 'https://' + document.domain + path; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| export function saveDeletedWordsLocally(wordIds) { | export function saveDeletedWordsLocally(wordIds) { | ||||||
|   let storedDeletedWords = getLocalDeletedWords(); |   let storedDeletedWords = getLocalDeletedWords(); | ||||||
|   wordIds.forEach(wordId => { |   wordIds.forEach(wordId => { | ||||||
|  |  | ||||||
|  | @ -18,6 +18,7 @@ import { getPaginationData } from './pagination'; | ||||||
| import { getOpenEditForms, parseReferences } from './wordManagement'; | import { getOpenEditForms, parseReferences } from './wordManagement'; | ||||||
| import { renderAd } from './ads'; | import { renderAd } from './ads'; | ||||||
| import ipaTableFile from './KeyboardFire/phondue/ipa-table.html'; | import ipaTableFile from './KeyboardFire/phondue/ipa-table.html'; | ||||||
|  | import { getPublicLink } from './account/utilities'; | ||||||
| 
 | 
 | ||||||
| export function renderAll() { | export function renderAll() { | ||||||
|   renderTheme(); |   renderTheme(); | ||||||
|  | @ -54,12 +55,13 @@ export function renderName() { | ||||||
|     shareLink.id = 'dictionaryShare'; |     shareLink.id = 'dictionaryShare'; | ||||||
|     shareLink.classList.add('button'); |     shareLink.classList.add('button'); | ||||||
|     shareLink.style.float = 'right'; |     shareLink.style.float = 'right'; | ||||||
|     shareLink.href = window.location.pathname.match(new RegExp(window.currentDictionary.externalID + '$')) ? window.location.pathname |     shareLink.href = getPublicLink(); | ||||||
|       : window.location.pathname.substring(0, window.location.pathname.indexOf(window.currentDictionary.externalID)) + window.currentDictionary.externalID; |  | ||||||
|     shareLink.target = '_blank'; |     shareLink.target = '_blank'; | ||||||
|     shareLink.title = 'Public Link to Dictionary'; |     shareLink.title = 'Public Link to Dictionary'; | ||||||
|     shareLink.innerHTML = '➦'; |     shareLink.innerHTML = '➦'; | ||||||
|     name.parentElement.insertBefore(shareLink, name); |     name.parentElement.insertBefore(shareLink, name); | ||||||
|  |   } else if (isPublic && shareLinkElement) { | ||||||
|  |     shareLinkElement.href = getPublicLink(); | ||||||
|   } else if (!isPublic && shareLinkElement) { |   } else if (!isPublic && shareLinkElement) { | ||||||
|     shareLinkElement.parentElement.removeChild(shareLinkElement); |     shareLinkElement.parentElement.removeChild(shareLinkElement); | ||||||
|   } |   } | ||||||
|  | @ -193,8 +195,7 @@ export function renderWords() { | ||||||
|         wordId: originalWord.wordId, |         wordId: originalWord.wordId, | ||||||
|       }); |       }); | ||||||
|       const homonymnNumber = getHomonymnNumber(originalWord); |       const homonymnNumber = getHomonymnNumber(originalWord); | ||||||
|       const shareLink = window.currentDictionary.hasOwnProperty('externalID') |       const shareLink = window.currentDictionary.hasOwnProperty('externalID') ? getPublicLink() + '/' + word.wordId : ''; | ||||||
|         ? window.location.pathname + window.currentDictionary.externalID + '/' + word.wordId : ''; |  | ||||||
| 
 | 
 | ||||||
|       wordsHTML += renderAd(displayIndex); |       wordsHTML += renderAd(displayIndex); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -119,7 +119,7 @@ switch ($view) { | ||||||
|       oldLoad && oldLoad(); |       oldLoad && oldLoad(); | ||||||
|       if (UpUp) { |       if (UpUp) { | ||||||
|         UpUp.start({ |         UpUp.start({ | ||||||
|           'cache-version': '2.0.0', |           'cache-version': '2.0.2', | ||||||
|           'content-url': 'offline.html', |           'content-url': 'offline.html', | ||||||
|           'assets': [ |           'assets': [ | ||||||
|             \"" . implode('","', $files) . "\" |             \"" . implode('","', $files) . "\" | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue