From 3453a9733b3f895c16bd317a1333668736ade27f Mon Sep 17 00:00:00 2001 From: Mefsaal Date: Thu, 28 Apr 2022 19:59:58 -0300 Subject: [PATCH 001/141] some test --- src/i18n/en_US.json | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/src/i18n/en_US.json b/src/i18n/en_US.json index 78413968..64eec84b 100644 --- a/src/i18n/en_US.json +++ b/src/i18n/en_US.json @@ -263,6 +263,14 @@ "action.cast.scanning": "Scanning...", "action.createNew": "Create New...", "action.openArtworkInBrowser": "Open artwork in browser", + "menubar.options.about": "About", + "menubar.options.settings": "Settings", + "menubar.options.services": "Services", + "menubar.options.hide": "Hide Cider", + "menubar.options.hideothers": "Hide Others", + "menubar.options.unhide": "Show All", + "menubar.options.quit": "Quit Cider", + "settings.header.general": "General", "settings.header.general.description": "Adjust the general settings for Cider.", "settings.option.general.language": "Language", From 3e728848d79d630d0a6a6b268ea6ad0bd5ef4a9a Mon Sep 17 00:00:00 2001 From: vapormusic Date: Fri, 29 Apr 2022 16:28:12 +0700 Subject: [PATCH 002/141] uptest --- package.json | 2 +- src/main/base/browserwindow.ts | 1 + src/main/plugins/raop.ts | 12 ++++++ src/renderer/less/helpers.less | 3 +- src/renderer/main/vueapp.js | 7 ++++ src/renderer/views/app/panels.ejs | 3 ++ .../views/components/airplay-modal.ejs | 42 +++++++++++++++++++ 7 files changed, 68 insertions(+), 2 deletions(-) create mode 100644 src/renderer/views/components/airplay-modal.ejs diff --git a/package.json b/package.json index 70e22263..6cad8ece 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@sentry/electron": "^3.0.7", "@sentry/integrations": "^6.19.6", "adm-zip": "0.4.10", - "airtunes2": "git+https://github.com/vapormusic/node_airtunes2.git", + "airtunes2": "git+https://github.com/vapormusic/node_airtunes2.git#hap", "castv2-client": "^1.2.0", "chokidar": "^3.5.3", "discord-rpc": "^4.0.1", diff --git a/src/main/base/browserwindow.ts b/src/main/base/browserwindow.ts index afb38607..56d847be 100644 --- a/src/main/base/browserwindow.ts +++ b/src/main/base/browserwindow.ts @@ -95,6 +95,7 @@ export class BrowserWindow { "components/fullscreen", "components/miniplayer", "components/castmenu", + "components/airplay-modal", "components/artist-chip", "components/hello-world", "components/inline-collection-list", diff --git a/src/main/plugins/raop.ts b/src/main/plugins/raop.ts index e6908375..ba8e8395 100644 --- a/src/main/plugins/raop.ts +++ b/src/main/plugins/raop.ts @@ -178,6 +178,12 @@ export default class RAOP { this._win.webContents.setAudioMuted(true); this._win.webContents.executeJavaScript(`CiderAudio.sendAudio()`).catch((err: any) => console.error(err)); } + if (status == "need_password"){ + this._win.webContents.executeJavaScript(`app.setAirPlayCodeUI()`) + } + if (status == "pair_success"){ + this._win.webContents.executeJavaScript(`app.sendAirPlaySuccess()`) + } if (status == 'stopped') { this.airtunes.stopAll(() => { console.log('end'); @@ -210,6 +216,12 @@ export default class RAOP { }); + electron.ipcMain.on('setAirPlayPasscode', (event, passcode) => { + if (this.device){ + this.device.setPasscode(passcode) + } + }) + electron.ipcMain.on('writeWAV', (event, leftbuffer, rightbuffer) => { if (this.airtunes != null) { if (this.worker == null) { diff --git a/src/renderer/less/helpers.less b/src/renderer/less/helpers.less index db659232..245cce92 100644 --- a/src/renderer/less/helpers.less +++ b/src/renderer/less/helpers.less @@ -70,10 +70,11 @@ .spatialproperties-panel { .modal-window { + &:not(.airplay-modal){ height : 700px; max-height: 700px; width : 800px; - max-width : 800px; + max-width : 800px;} overflow : hidden; .info-header { diff --git a/src/renderer/main/vueapp.js b/src/renderer/main/vueapp.js index bcc7dfce..e40ee7a7 100644 --- a/src/renderer/main/vueapp.js +++ b/src/renderer/main/vueapp.js @@ -207,6 +207,7 @@ const app = new Vue({ showPlaylist: false, castMenu: false, moreInfo: false, + airplayPW: false, }, socialBadges: { badgeMap: {}, @@ -3836,6 +3837,12 @@ const app = new Vue({ // tracks are found in relationship.data }, + setAirPlayCodeUI() { + this.modals.airplayPW = true + }, + sendAirPlaySuccess(){ + notyf.success('Device paired successfully!'); + }, windowFocus(val) { if (val) { document.querySelectorAll(".animated-artwork-video").forEach(el => { diff --git a/src/renderer/views/app/panels.ejs b/src/renderer/views/app/panels.ejs index 69a6f18e..eaccb5f2 100644 --- a/src/renderer/views/app/panels.ejs +++ b/src/renderer/views/app/panels.ejs @@ -28,6 +28,9 @@ + + + diff --git a/src/renderer/views/components/airplay-modal.ejs b/src/renderer/views/components/airplay-modal.ejs new file mode 100644 index 00000000..16ab91a4 --- /dev/null +++ b/src/renderer/views/components/airplay-modal.ejs @@ -0,0 +1,42 @@ + + \ No newline at end of file From f403b52af1821580a14d32be53599829574b288c Mon Sep 17 00:00:00 2001 From: Amaru8 <52407090+Amaru8@users.noreply.github.com> Date: Fri, 29 Apr 2022 21:44:15 +0200 Subject: [PATCH 003/141] test --- src/renderer/assets/feather/heart-fill.svg | 1 + .../views/components/mediaitem-list-item.ejs | 17 +++++++++++++++++ 2 files changed, 18 insertions(+) create mode 100644 src/renderer/assets/feather/heart-fill.svg diff --git a/src/renderer/assets/feather/heart-fill.svg b/src/renderer/assets/feather/heart-fill.svg new file mode 100644 index 00000000..1f790aad --- /dev/null +++ b/src/renderer/assets/feather/heart-fill.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/src/renderer/views/components/mediaitem-list-item.ejs b/src/renderer/views/components/mediaitem-list-item.ejs index 0a1ab179..4348b125 100644 --- a/src/renderer/views/components/mediaitem-list-item.ejs +++ b/src/renderer/views/components/mediaitem-list-item.ejs @@ -67,6 +67,9 @@