diff --git a/img/Altus-Multiple-Tabs.png b/img/Altus-Multiple-Tabs.png new file mode 100644 index 00000000..ab2f17a6 Binary files /dev/null and b/img/Altus-Multiple-Tabs.png differ diff --git a/src/package.json b/src/package.json index 04bb3961..483ec1c4 100644 --- a/src/package.json +++ b/src/package.json @@ -1,6 +1,6 @@ { "name": "altus", - "version": "2.0.0", + "version": "2.0.1", "description": "Electron-based desktop wrapper for Whatsapp Web", "homepage": "https://github.com/ShadyThGod/altus", "repository": { diff --git a/src/windows/assets/js/elementCodes.js b/src/windows/assets/js/elementCodes.js new file mode 100644 index 00000000..dde40046 --- /dev/null +++ b/src/windows/assets/js/elementCodes.js @@ -0,0 +1,57 @@ +function tabElement(tab) { + return ` + ${tab.name} + `; +} + +function instanceElement(tab) { + return `
+ +
`; +} + +function settingsModalElement(tab) { + return ``; +} + +module.exports = { + tabElement, + instanceElement, + settingsModalElement +} \ No newline at end of file diff --git a/src/windows/main/js/main.js b/src/windows/main/js/main.js index 6154d33b..9996db47 100644 --- a/src/windows/main/js/main.js +++ b/src/windows/main/js/main.js @@ -8,6 +8,7 @@ const { } = require('electron'); const Store = require('electron-store'); const generateId = require('uuid/v4'); +const HTML = require('../assets/js/elementCodes.js'); // Create main window titlebar const mainTitlebar = new customTitlebar.Titlebar({ @@ -28,100 +29,13 @@ let themes = new Store({ }); function loadTabsFromStorage() { + let storedTabs = tabs.get('instances'); if (storedTabs.length == 0) { document.querySelector('.no-tabs').style.display = 'flex'; } else { storedTabs.forEach(tab => { - let tabElementCode = ` - ${tab.name} - `; - let instanceElementCode = `
- -
`; - let settingsModalCode = ``; - - let range = document.createRange(); - let tabElement = range.createContextualFragment(tabElementCode); - let instanceElement = range.createContextualFragment(instanceElementCode); - let settingsModal = range.createContextualFragment(settingsModalCode); - - document.querySelector('.tabs').insertBefore(tabElement, document.querySelector('.add-tab-icon')); - document.querySelector('.tab-contents').appendChild(instanceElement); - document.querySelector('.modals-div').appendChild(settingsModal); - - $(`#tab-${tab.id}`).tab(); - - $(`.settings-modal-${tab.id}`) - .modal({ - onApprove: () => { - let editedInstance = { - name: $(`#${tab.id}-name`).val(), - id: `${tab.id}`, - settings: { - notifications: $(`.${tab.id}-notifications-value`).checkbox('is checked'), - sound: $(`.${tab.id}-sound-value`).checkbox('is checked'), - theme: $(`.${tab.id}-theme-value`).dropdown('get value') - } - } - let tabsStore = tabs.get('instances'); - let findTab = tabsStore.find(x => x.id === tab.id); - let newTabIndex = tabsStore.indexOf(findTab); - tabsStore[newTabIndex] = editedInstance; - tabs.set('instances', tabsStore); - window.location.reload(); - } - }) - .modal('attach events', `#tab-${tab.id} .cog.icon`, 'show'); - - if (tab.settings.notifications == true) { - $(`.${tab.id}-notifications-value`).checkbox('check'); - } else { - $(`.${tab.id}-notifications-value`).checkbox('uncheck'); - } - - if (tab.settings.sound == true) { - $(`.${tab.id}-sound-value`).checkbox('check'); - } else { - $(`.${tab.id}-sound-value`).checkbox('uncheck'); - } - + addNewInstance(tab); }); document.querySelector('.menu').firstElementChild.classList.add('active'); @@ -143,6 +57,8 @@ function loadTabsFromStorage() { }); }); } + + setWebViewSettingsLoop(); } $('.ui.modal') @@ -171,7 +87,11 @@ $('.ui.modal') tabsStore.push(newInstance); tabs.set('instances', tabsStore); - window.location.reload(); + + addNewInstance(newInstance); + $('.tab-element.active').removeClass('active'); + $(`#tab-${newInstance.id}`).addClass('active'); + $(`#tab-${newInstance.id}`).click(); } } @@ -284,16 +204,18 @@ window.Notification = ProxyNotification; }); } -document.querySelectorAll('.tab').forEach(tabElement => { - let tabID = tabElement.id.replace('tab-content-', ''); - let tabJSON = tabs.get('instances').find(x => x.id === tabID); - let webviewElement = document.querySelector(`#${tabElement.id}`).querySelector('webview'); +function setWebViewSettingsLoop() { + document.querySelectorAll('.tab').forEach(tabElement => { + let tabID = tabElement.id.replace('tab-content-', ''); + let tabJSON = tabs.get('instances').find(x => x.id === tabID); + let webviewElement = document.querySelector(`#${tabElement.id}`).querySelector('webview'); - $(`.${tabID}-theme-value`).dropdown('set selected', tabJSON.settings.theme); - $(`.${tabID}-theme-value`).dropdown(); + $(`.${tabID}-theme-value`).dropdown('set selected', tabJSON.settings.theme); + $(`.${tabID}-theme-value`).dropdown(); - setWebViewSettings(webviewElement, tabJSON); -}); + setWebViewSettings(webviewElement, tabJSON); + }); +} function checkForInstances() { let instances = tabs.get('instances'); @@ -302,9 +224,84 @@ function checkForInstances() { document.querySelector('.no-tabs').style.display = 'flex'; } else { document.querySelector('.no-tabs').style.display = 'none'; + document.querySelector('.menu').firstElementChild.classList.add('active'); + document.querySelector('.menu').firstElementChild.click(); } } +function addNewInstance(instance) { + let tab = instance; + let tabElementCode = HTML.tabElement(tab); + let instanceElementCode = HTML.instanceElement(tab); + let settingsModalCode = HTML.settingsModalElement(tab); + let range = document.createRange(); + let tabElement = range.createContextualFragment(tabElementCode); + let instanceElement = range.createContextualFragment(instanceElementCode); + let settingsModal = range.createContextualFragment(settingsModalCode); + document.querySelector('.tabs').insertBefore(tabElement, document.querySelector('.add-tab-icon')); + document.querySelector('.tab-contents').appendChild(instanceElement); + document.querySelector('.modals-div').appendChild(settingsModal); + + $(`#tab-${tab.id}`).tab(); + + $(`.settings-modal-${tab.id}`) + .modal({ + onApprove: () => { + let editedInstance = { + name: $(`#${tab.id}-name`).val(), + id: `${tab.id}`, + settings: { + notifications: $(`.${tab.id}-notifications-value`).checkbox('is checked'), + sound: $(`.${tab.id}-sound-value`).checkbox('is checked'), + theme: $(`.${tab.id}-theme-value`).dropdown('get value') + } + } + let tabsStore = tabs.get('instances'); + let findTab = tabsStore.find(x => x.id === tab.id); + let newTabIndex = tabsStore.indexOf(findTab); + tabsStore[newTabIndex] = editedInstance; + tabs.set('instances', tabsStore); + window.location.reload(); + } + }) + .modal('attach events', `#tab-${tab.id} .cog.icon`, 'show'); + + if (tab.settings.notifications == true) { + $(`.${tab.id}-notifications-value`).checkbox('check'); + } else { + $(`.${tab.id}-notifications-value`).checkbox('uncheck'); + } + + if (tab.settings.sound == true) { + $(`.${tab.id}-sound-value`).checkbox('check'); + } else { + $(`.${tab.id}-sound-value`).checkbox('uncheck'); + } + + document.querySelectorAll('.menu .item > .close.icon.ui').forEach(e => { + e.addEventListener('click', () => { + let id = e.parentElement.getAttribute('data-tab'); + + let tabsStore = tabs.get('instances'); + let newTabs = tabsStore.filter(tab => tab.id !== id); + + tabs.set('instances', newTabs); + + document.getElementById(`tab-content-${id}`).remove(); + e.parentElement.remove(); + + checkForInstances(); + }); + }); + + $('.dropdown').dropdown(); + $('.dropdown').dropdown({ + values: generateThemeNames() + }); + + setWebViewSettingsLoop(); +} + ipcRenderer.on('new-themes-added', e => window.location.reload(true)); // Setting title explicitly