diff --git a/plugins/plugins/copy-lyrics/dist/index.js b/plugins/plugins/copy-lyrics/dist/index.js index d3aaa85..8e797ae 100644 --- a/plugins/plugins/copy-lyrics/dist/index.js +++ b/plugins/plugins/copy-lyrics/dist/index.js @@ -1,4 +1,4 @@ -var f=Object.defineProperty;var b=Object.getOwnPropertyDescriptor;var v=Object.getOwnPropertyNames;var L=Object.prototype.hasOwnProperty;var O=(t,e)=>()=>(t&&(e=t(t=0)),e);var R=(t,e)=>{for(var n in e)f(t,n,{get:e[n],enumerable:!0})},A=(t,e,n,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of v(e))!L.call(t,r)&&r!==n&&f(t,r,{get:()=>e[r],enumerable:!(i=b(e,r))||i.enumerable});return t};var M=t=>A(f({},"__esModule",{value:!0}),t);var C={};R(C,{Tracer:()=>m,libTrace:()=>_});import{actions as E}from"@neptune";var m,_,x=O(()=>{"use strict";m=t=>{let e=o=>{let c=(...a)=>{o(t,...a)};return c.withContext=a=>(...u)=>{o(t,a,...u)},c},n=e(console.log),i=e(console.warn),r=e(console.error),p=e(console.debug),s=(o,c,a)=>{let u=d=>{o(d),c({message:`${t} - ${d}`,category:"OTHER",severity:a})};return u.withContext=d=>{let T=o.withContext(d);return l=>{T(l),l instanceof Error&&(l=l.message),c({message:`${t}.${d} - ${l}`,category:"OTHER",severity:a})}},u};return{log:n,warn:i,err:r,debug:p,msg:{log:s(n,E.message.messageInfo,"INFO"),warn:s(i,E.message.messageWarn,"WARN"),err:s(r,E.message.messageError,"ERROR")}}},_=m("[lib]")});x();x();var y=m("[Copy Lyrics]"),$=` +var p=Object.defineProperty;var S=Object.getOwnPropertyDescriptor;var v=Object.getOwnPropertyNames;var A=Object.prototype.hasOwnProperty;var L=(t,e)=>()=>(t&&(e=t(t=0)),e);var O=(t,e)=>{for(var r in e)p(t,r,{get:e[r],enumerable:!0})},R=(t,e,r,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of v(e))!A.call(t,o)&&o!==r&&p(t,o,{get:()=>e[o],enumerable:!(i=S(e,o))||i.enumerable});return t};var M=t=>R(p({},"__esModule",{value:!0}),t);var C={};O(C,{Tracer:()=>m,libTrace:()=>_});import{actions as E}from"@neptune";var m,_,h=L(()=>{"use strict";m=t=>{let e=s=>{let n=(...c)=>{s(t,...c)};return n.withContext=c=>(...u)=>{s(t,c,...u)},n},r=e(console.log),i=e(console.warn),o=e(console.error),f=e(console.debug),a=(s,n,c)=>{let u=l=>{s(l),n({message:`${t} - ${l}`,category:"OTHER",severity:c})};return u.withContext=l=>{let T=s.withContext(l);return d=>{T(d),d instanceof Error&&(d=d.message),n({message:`${t}.${l} - ${d}`,category:"OTHER",severity:c})}},u};return{log:r,warn:i,err:o,debug:f,msg:{log:a(r,E.message.messageInfo,"INFO"),warn:a(i,E.message.messageWarn,"WARN"),err:a(o,E.message.messageError,"ERROR")}}},_=m("[lib]")});h();h();var x=m("[Copy Lyrics]"),D=` [class^="lyricsText"]>div>span { user-select: text; cursor: text; @@ -8,6 +8,6 @@ var f=Object.defineProperty;var b=Object.getOwnPropertyDescriptor;var v=Object.g background: rgb(0, 0, 0); color: rgb(255, 255, 255); } -`;function D(t){let e=document.createElement("style");return e.type="text/css",e.styleSheet?e.styleSheet.cssText=t:e.appendChild(document.createTextNode(t)),document.head.appendChild(e),e}function w(t){let e=document.createElement("textarea");e.value=t,e.style.position="fixed",document.body.appendChild(e),e.select();try{if(!document.execCommand("copy"))throw new Error("Failed to copy text.")}catch(n){y.msg.err(n)}finally{document.body.removeChild(e)}}var g=D($),h=!1,N=function(){h=!0},S=function(t){if(h){let e=window.getSelection();if(e.toString().length>0){let n=[],r=e.getRangeAt(0).commonAncestorContainer;if(r.nodeType!==Node.ELEMENT_NODE&&r.nodeType!==Node.DOCUMENT_NODE){let o=e.toString().trim();w(o),y.msg.log("Copied to clipboard!");return}let p=r.getElementsByTagName("span");for(let o of p)e.containsNode(o,!0)&&n.push(o);let s="";n.forEach(o=>{s+=o.textContent+` -`,[...o.classList].some(c=>c.startsWith("endOfStanza--"))&&(s+=` -`)}),s=s.trim(),w(s),y.msg.log("Copied to clipboard!"),window.getSelection&&e.removeAllRanges()}h=!1}};document.addEventListener("mousedown",N);document.addEventListener("mouseup",S);function F(){g&&g.parentNode&&g.parentNode.removeChild(g),document.removeEventListener("mousedown",N),document.removeEventListener("mouseup",S)}export{F as onUnload}; +`;function $(t){let e=document.createElement("style");return e.type="text/css",e.styleSheet?e.styleSheet.cssText=t:e.appendChild(document.createTextNode(t)),document.head.appendChild(e),e}function b(t){let e=document.createElement("textarea");e.value=t,e.style.position="fixed",document.body.appendChild(e),e.select();try{if(!document.execCommand("copy"))throw new Error("Failed to copy text.")}catch(r){x.msg.err(r)}finally{document.body.removeChild(e)}}var g=$(D),y=!1,w=function(){y=!0},N=function(t){if(y){let e=window.getSelection();if(e.toString().length>0){let r=[],o=e.getRangeAt(0).commonAncestorContainer;if(o.nodeType!==Node.ELEMENT_NODE&&o.nodeType!==Node.DOCUMENT_NODE){let n=o.parentElement;if(n&&n.hasAttribute("data-current")||o.ELEMENT_NODE.hasAttribute("data-current")){let c=e.toString().trim();b(c),x.msg.log("Copied to clipboard!");return}}let f=o.getElementsByTagName("span");for(let n of f)e.containsNode(n,!0)&&r.push(n);let a=!1,s="";r.forEach(n=>{n.hasAttribute("data-current")&&(a=!0,s+=n.textContent+` +`,[...n.classList].some(c=>c.startsWith("endOfStanza--"))&&(s+=` +`))}),a&&console.log(a),s=s.trim(),a===!0&&(b(s),x.msg.log("Copied to clipboard!"),window.getSelection&&e.removeAllRanges())}y=!1}};document.addEventListener("mousedown",w);document.addEventListener("mouseup",N);function F(){g&&g.parentNode&&g.parentNode.removeChild(g),document.removeEventListener("mousedown",w),document.removeEventListener("mouseup",N)}export{F as onUnload}; diff --git a/plugins/plugins/copy-lyrics/dist/manifest.json b/plugins/plugins/copy-lyrics/dist/manifest.json index fc4d926..cebeae7 100644 --- a/plugins/plugins/copy-lyrics/dist/manifest.json +++ b/plugins/plugins/copy-lyrics/dist/manifest.json @@ -1 +1 @@ -{"name":"Copy Lyrics","description":"A working neptune plugin that allows the user to copy the lyrics of a song selecting it.","author":"itzzexcel@github","hash":"ba615a10ac2818b121df8abdfe299c36","metafile":{"inputs":{"plugins/copy-lyrics/src/tracer.js":{"bytes":1596,"imports":[{"path":"@neptune","kind":"import-statement","external":true}],"format":"esm"},"plugins/copy-lyrics/src/index.js":{"bytes":3386,"imports":[{"path":"plugins/copy-lyrics/src/tracer.js","kind":"import-statement","original":"./tracer"},{"path":"plugins/copy-lyrics/src/tracer.js","kind":"require-call","original":"./tracer"}],"format":"esm"}},"outputs":{"plugins/copy-lyrics/dist/index.js":{"imports":[{"path":"@neptune","kind":"import-statement","external":true}],"exports":["onUnload"],"entryPoint":"plugins/copy-lyrics/src/index.js","inputs":{"plugins/copy-lyrics/src/tracer.js":{"bytesInOutput":693},"plugins/copy-lyrics/src/index.js":{"bytesInOutput":1464}},"bytes":2627}}}} \ No newline at end of file +{"name":"Copy Lyrics","description":"A working neptune plugin that allows the user to copy the lyrics of a song selecting it.","author":"itzzexcel@github","hash":"f69f72f93e3010a2597ed0f5f5d504b6","metafile":{"inputs":{"plugins/copy-lyrics/src/tracer.js":{"bytes":1596,"imports":[{"path":"@neptune","kind":"import-statement","external":true}],"format":"esm"},"plugins/copy-lyrics/src/index.js":{"bytes":4042,"imports":[{"path":"plugins/copy-lyrics/src/tracer.js","kind":"import-statement","original":"./tracer"},{"path":"plugins/copy-lyrics/src/tracer.js","kind":"require-call","original":"./tracer"}],"format":"esm"}},"outputs":{"plugins/copy-lyrics/dist/index.js":{"imports":[{"path":"@neptune","kind":"import-statement","external":true}],"exports":["onUnload"],"entryPoint":"plugins/copy-lyrics/src/index.js","inputs":{"plugins/copy-lyrics/src/tracer.js":{"bytesInOutput":693},"plugins/copy-lyrics/src/index.js":{"bytesInOutput":1642}},"bytes":2805}}}} \ No newline at end of file diff --git a/plugins/plugins/copy-lyrics/src/index.js b/plugins/plugins/copy-lyrics/src/index.js index c6343da..146525b 100644 --- a/plugins/plugins/copy-lyrics/src/index.js +++ b/plugins/plugins/copy-lyrics/src/index.js @@ -16,28 +16,25 @@ const unlockSelection = ` `; function ApplyCSS(style) { - const styleElement = document.createElement('style'); - styleElement.type = 'text/css'; - if (styleElement.styleSheet) - styleElement.styleSheet.cssText = style; - else - styleElement.appendChild(document.createTextNode(style)); + const styleElement = document.createElement("style"); + styleElement.type = "text/css"; + if (styleElement.styleSheet) styleElement.styleSheet.cssText = style; + else styleElement.appendChild(document.createTextNode(style)); document.head.appendChild(styleElement); return styleElement; } function SetClipboard(text) { - const textarea = document.createElement('textarea'); + const textarea = document.createElement("textarea"); textarea.value = text; - textarea.style.position = 'fixed'; // Avoid scrolling to bottom + textarea.style.position = "fixed"; // Avoid scrolling to bottom document.body.appendChild(textarea); textarea.select(); try { - const success = document.execCommand('copy'); - if (!success) - throw new Error('Failed to copy text.'); + const success = document.execCommand("copy"); + if (!success) throw new Error("Failed to copy text."); } catch (err) { trace.msg.err(err); } finally { @@ -60,21 +57,24 @@ const onMouseUp = function (event) { const selectedSpans = []; const range = selection.getRangeAt(0); let container = range.commonAncestorContainer; - // If the container is NOT and element and a document, try to adjust it. if ( container.nodeType !== Node.ELEMENT_NODE && container.nodeType !== Node.DOCUMENT_NODE ) { - let text_ = selection.toString().trim(); - SetClipboard(text_); - trace.msg.log("Copied to clipboard!"); + // Get the parent element if it's a text node + const parentElement = container.parentElement; + if (parentElement && parentElement.hasAttribute("data-current") || container.ELEMENT_NODE.hasAttribute("data-current")) { + let text_ = selection.toString().trim(); + SetClipboard(text_); + trace.msg.log("Copied to clipboard!"); - return; + return; + } } // Get all the spans inside the container. - const spans = container.getElementsByTagName('span'); + const spans = container.getElementsByTagName("span"); for (let span of spans) { if (selection.containsNode(span, true)) { selectedSpans.push(span); @@ -82,33 +82,45 @@ const onMouseUp = function (event) { } // Concat the text of the selected spans. - let text = ''; - selectedSpans.forEach(span => { - text += span.textContent + '\n'; - if ([...span.classList].some(className => className.startsWith('endOfStanza--'))) { - text += '\n'; + let hasCorrectAttribute = false; + let text = ""; + selectedSpans.forEach((span) => { + if (span.hasAttribute("data-current")) { + hasCorrectAttribute = true; + text += span.textContent + "\n"; + if ([...span.classList].some((className) => className.startsWith("endOfStanza--"))) { + text += "\n"; + } } }); + + if (hasCorrectAttribute) { + console.log(hasCorrectAttribute); + } + text = text.trim(); - SetClipboard(text); - trace.msg.log("Copied to clipboard!"); - if (window.getSelection) { - selection.removeAllRanges(); + if (hasCorrectAttribute === true) { + SetClipboard(text); + trace.msg.log("Copied to clipboard!"); + if (window.getSelection) { + selection.removeAllRanges(); + } } + } isSelecting = false; } }; -document.addEventListener('mousedown', onMouseDown); -document.addEventListener('mouseup', onMouseUp); +document.addEventListener("mousedown", onMouseDown); +document.addEventListener("mouseup", onMouseUp); export function onUnload() { if (styleElement && styleElement.parentNode) { styleElement.parentNode.removeChild(styleElement); } - document.removeEventListener('mousedown', onMouseDown); - document.removeEventListener('mouseup', onMouseUp); + document.removeEventListener("mousedown", onMouseDown); + document.removeEventListener("mouseup", onMouseUp); } diff --git a/plugins/plugins/oled-theme/dist/index.js b/plugins/plugins/oled-theme/dist/index.js new file mode 100644 index 0000000..08bd03e --- /dev/null +++ b/plugins/plugins/oled-theme/dist/index.js @@ -0,0 +1 @@ +var h=Object.defineProperty;var x=Object.getOwnPropertyDescriptor;var I=Object.getOwnPropertyNames;var N=Object.prototype.hasOwnProperty;var O=(t,e)=>()=>(t&&(e=t(t=0)),e);var b=(t,e)=>{for(var n in e)h(t,n,{get:e[n],enumerable:!0})},S=(t,e,n,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of I(e))!N.call(t,r)&&r!==n&&h(t,r,{get:()=>e[r],enumerable:!(s=x(e,r))||s.enumerable});return t};var _=t=>S(h({},"__esModule",{value:!0}),t);var T={};b(T,{Tracer:()=>m,libTrace:()=>$});import{actions as f}from"@neptune";var m,$,g=O(()=>{"use strict";m=t=>{let e=c=>{let a=(...o)=>{c(t,...o)};return a.withContext=o=>(...d)=>{c(t,o,...d)},a},n=e(console.log),s=e(console.warn),r=e(console.error),w=e(console.debug),p=(c,a,o)=>{let d=l=>{c(l),a({message:`${t} - ${l}`,category:"OTHER",severity:o})};return d.withContext=l=>{let R=c.withContext(l);return i=>{R(i),i instanceof Error&&(i=i.message),a({message:`${t}.${l} - ${i}`,category:"OTHER",severity:o})}},d};return{log:n,warn:s,err:r,debug:w,msg:{log:p(n,f.message.messageInfo,"INFO"),warn:p(s,f.message.messageWarn,"WARN"),err:p(r,f.message.messageError,"ERROR")}}},$=m("[lib]")});g();import{intercept as E}from"@neptune";g();var k=m("[OLED Theme]"),A="https://raw.githubusercontent.com/ItzzExcel/neptune-projects/refs/heads/main/themes/black-neptune-theme.css",C,u;function U(t){let e=document.createElement("style");return e.type="text/css",e.styleSheet?e.styleSheet.cssText=t:e.appendChild(document.createTextNode(t)),document.head.appendChild(e),e}function D(){u&&u.parentNode&&u.parentNode.removeChild(u)}async function L(t){try{let e=await fetch(t);if(!e.ok)throw new Error(`HTTP error! status: ${e.status}`);return await e.text()}catch(e){return k.msg.err(`Failed to fetch URL: ${e.message}`),null}}(async()=>(C=await L(A),u=U(C)))();function y([t]){}E("playbackControls/PREFILL_MEDIA_PRODUCT_TRANSITION",y);E("playbackControls/MEDIA_PRODUCT_TRANSITION",y);function z(){D()}export{z as onUnload}; diff --git a/plugins/plugins/oled-theme/dist/manifest.json b/plugins/plugins/oled-theme/dist/manifest.json new file mode 100644 index 0000000..d66f4a1 --- /dev/null +++ b/plugins/plugins/oled-theme/dist/manifest.json @@ -0,0 +1 @@ +{"name":"OLED Theme","description":"A working theme. ong.","author":"itzzexcel@github","hash":"d6f50bec7e0b1f8d7b829666128cb241","metafile":{"inputs":{"plugins/oled-theme/src/tracer.js":{"bytes":1596,"imports":[{"path":"@neptune","kind":"import-statement","external":true}],"format":"esm"},"plugins/oled-theme/src/index.js":{"bytes":1729,"imports":[{"path":"plugins/oled-theme/src/tracer.js","kind":"import-statement","original":"./tracer"},{"path":"@neptune","kind":"import-statement","external":true},{"path":"plugins/oled-theme/src/tracer.js","kind":"require-call","original":"./tracer"}],"format":"esm"}},"outputs":{"plugins/oled-theme/dist/index.js":{"imports":[{"path":"@neptune","kind":"import-statement","external":true},{"path":"@neptune","kind":"import-statement","external":true}],"exports":["onUnload"],"entryPoint":"plugins/oled-theme/src/index.js","inputs":{"plugins/oled-theme/src/tracer.js":{"bytesInOutput":693},"plugins/oled-theme/src/index.js":{"bytesInOutput":800}},"bytes":1963}}}} \ No newline at end of file diff --git a/plugins/plugins/oled-theme/package.json b/plugins/plugins/oled-theme/package.json new file mode 100644 index 0000000..d020e40 --- /dev/null +++ b/plugins/plugins/oled-theme/package.json @@ -0,0 +1,6 @@ +{ + "dependencies": { + "canvas-confetti": "^1.6.0", + "neptune-types": "1.0.1" + } +} \ No newline at end of file diff --git a/plugins/plugins/oled-theme/plugin.json b/plugins/plugins/oled-theme/plugin.json new file mode 100644 index 0000000..a10adfe --- /dev/null +++ b/plugins/plugins/oled-theme/plugin.json @@ -0,0 +1,6 @@ +{ + "name": "OLED Theme", + "description": "A working theme. ong.", + "author": "itzzexcel@github", + "main": "./src/index.js" +} \ No newline at end of file diff --git a/plugins/plugins/oled-theme/pnpm-lock.yaml b/plugins/plugins/oled-theme/pnpm-lock.yaml new file mode 100644 index 0000000..1d2e826 --- /dev/null +++ b/plugins/plugins/oled-theme/pnpm-lock.yaml @@ -0,0 +1,16 @@ +lockfileVersion: '6.1' + +settings: + autoInstallPeers: true + excludeLinksFromLockfile: false + +dependencies: + canvas-confetti: + specifier: ^1.6.0 + version: 1.6.0 + +packages: + + /canvas-confetti@1.6.0: + resolution: {integrity: sha512-ej+w/m8Jzpv9Z7W7uJZer14Ke8P2ogsjg4ZMGIuq4iqUOqY2Jq8BNW42iGmNfRwREaaEfFIczLuZZiEVSYNHAA==} + dev: false diff --git a/plugins/plugins/oled-theme/src/index.js b/plugins/plugins/oled-theme/src/index.js new file mode 100644 index 0000000..8ba8ec1 --- /dev/null +++ b/plugins/plugins/oled-theme/src/index.js @@ -0,0 +1,58 @@ +require("./tracer") +import { Tracer } from "./tracer"; +import { intercept, store } from "@neptune" + +const trace = Tracer("[OLED Theme]"); +const themeUrl = "https://raw.githubusercontent.com/ItzzExcel/neptune-projects/refs/heads/main/themes/black-neptune-theme.css"; + +let style; +let styleElement; + +function ApplyCSS(style) { + const styleElement = document.createElement("style"); + styleElement.type = "text/css"; + if (styleElement.styleSheet) styleElement.styleSheet.cssText = style; + else styleElement.appendChild(document.createTextNode(style)); + + document.head.appendChild(styleElement); + return styleElement; +} + +function CleanUpCSS() { + if (styleElement && styleElement.parentNode) { + styleElement.parentNode.removeChild(styleElement); + } +} + +async function HttpGet(url) { + try { + const response = await fetch(url); + if (!response.ok) { + throw new Error(`HTTP error! status: ${response.status}`); + } + const content = await response.text(); + return content; + } catch (error) { + trace.msg.err(`Failed to fetch URL: ${error.message}`); + return null; + } +} + +// Since HttpGet is async, we need to await its result +(async () => { + style = await HttpGet(themeUrl); + styleElement = ApplyCSS(style); + // trace.msg.log("CSS Applied!"); +})(); + +function onTrackChanged([track]) { + /* How to get the album cover URL 💔💔💔 */ +} + +intercept("playbackControls/PREFILL_MEDIA_PRODUCT_TRANSITION", onTrackChanged); +intercept("playbackControls/MEDIA_PRODUCT_TRANSITION", onTrackChanged); + +export function onUnload() { + CleanUpCSS(); + // trace.msg.log("Exiting..."); +} \ No newline at end of file diff --git a/plugins/plugins/oled-theme/src/tracer.js b/plugins/plugins/oled-theme/src/tracer.js new file mode 100644 index 0000000..f18bcd3 --- /dev/null +++ b/plugins/plugins/oled-theme/src/tracer.js @@ -0,0 +1,55 @@ +// Based on https://github.com/Inrixia/neptune-plugins/blob/3d28c9ea3252782da830698032dbb49dbe5b9fd6/plugins/_lib/trace.ts +// Credits to inrixia + +import { actions } from "@neptune"; + +export const Tracer = (source) => { + const createLogger = (logger) => { + const _logger = (...data) => { + logger(source, ...data); + return undefined; + }; + _logger.withContext = (context) => (...data) => { + logger(source, context, ...data); + return undefined; + }; + return _logger; + }; + + const log = createLogger(console.log); + const warn = createLogger(console.warn); + const err = createLogger(console.error); + const debug = createLogger(console.debug); + + const createMessager = (logger, messager, severity) => { + const _messager = (message) => { + logger(message); + messager({ message: `${source} - ${message}`, category: "OTHER", severity }); + return undefined; + }; + _messager.withContext = (context) => { + const loggerWithContext = logger.withContext(context); + return (message) => { + loggerWithContext(message); + if (message instanceof Error) message = message.message; + messager({ message: `${source}.${context} - ${message}`, category: "OTHER", severity }); + return undefined; + }; + }; + return _messager; + }; + + return { + log, + warn, + err, + debug, + msg: { + log: createMessager(log, actions.message.messageInfo, "INFO"), + warn: createMessager(warn, actions.message.messageWarn, "WARN"), + err: createMessager(err, actions.message.messageError, "ERROR"), + }, + }; +}; + +export const libTrace = Tracer("[lib]"); \ No newline at end of file