Merge branch 'feat__extension' into V3
20
extension/README.md
Normal file
|
@ -0,0 +1,20 @@
|
|||
Это расширение для firefox и chrome для добавления кнопки Смотреть в Anix на сайт anixart.tv, а так-же найти в Anix на сайт кинопоиск, если обнаружен жанр аниме
|
||||
|
||||
## Скачать
|
||||
|
||||
Firefox: https://addons.mozilla.org/en-US/firefox/addon/watch-on-anix/
|
||||
|
||||
Chrome: https://github.com/Radiquum/anix/raw/V3/extension/chrome/watch-on-anix-chrome.zip
|
||||
|
||||
## Установка
|
||||
|
||||
Firefox:
|
||||
|
||||
- Загрузите расширение из AMO
|
||||
|
||||
Chrome:
|
||||
|
||||
1. скачайте и распакуйте архив
|
||||
2. зайдите в расширения браузера chrome://extensions/
|
||||
3. включите режим разработчика
|
||||
4. нажмите "загрузить распакованное расширение" и выберите директорию куда вы распаковали архив
|
BIN
extension/chrome/icon-16x16.png
Normal file
After Width: | Height: | Size: 875 B |
BIN
extension/chrome/icon-32x32.png
Normal file
After Width: | Height: | Size: 2.6 KiB |
BIN
extension/chrome/icon-48x48.png
Normal file
After Width: | Height: | Size: 5.2 KiB |
BIN
extension/chrome/icon-72x72.png
Normal file
After Width: | Height: | Size: 10 KiB |
BIN
extension/chrome/icon-96x96.png
Normal file
After Width: | Height: | Size: 16 KiB |
116
extension/chrome/main.js
Normal file
|
@ -0,0 +1,116 @@
|
|||
function determineHost() {
|
||||
const url = new URL(window.location.href);
|
||||
return {
|
||||
host: url.host,
|
||||
pathname: url.pathname,
|
||||
};
|
||||
}
|
||||
|
||||
function addButtonToAnixart(pathname) {
|
||||
// find a container and an open in app link with button
|
||||
const container = document.querySelector('div[style="text-align: center;"]');
|
||||
const openInAppLink = document.querySelector('a[href^="anixart"');
|
||||
const openInAppLinkButton = openInAppLink.querySelector("button");
|
||||
openInAppLinkButton.style = "margin-top: 0px !important;"; // disable default button margin
|
||||
openInAppLinkButton.classList = "btn btn-secondary"; // change default button from primary to secondary
|
||||
|
||||
// create a custom footer
|
||||
const footer = document.createElement("div");
|
||||
footer.style =
|
||||
"display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; align-items: center; margin-top: 20px;";
|
||||
|
||||
// create and set custom link
|
||||
const link = document.createElement("a");
|
||||
const button = document.createElement("button");
|
||||
button.style = "margin-top: 0px !important;";
|
||||
button.classList = "btn btn-primary";
|
||||
button.textContent = "Открыть в Anix";
|
||||
|
||||
const url = new URL(window.location.href);
|
||||
link.href = `https://anix.wah.su${pathname}?ref=anixart.tv&source=extension`;
|
||||
link.appendChild(button);
|
||||
|
||||
// append link and open in app link to footer
|
||||
footer.appendChild(link);
|
||||
footer.appendChild(openInAppLink);
|
||||
|
||||
// append footer to container
|
||||
container.appendChild(footer);
|
||||
}
|
||||
|
||||
function kinopoiskIsAnimeGenrePresent() {
|
||||
const genre = document.querySelector('a[href^="/lists/movies/genre--anime"]');
|
||||
|
||||
if (genre) {
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
function addButtonToKinopoisk() {
|
||||
let isAnime = kinopoiskIsAnimeGenrePresent();
|
||||
if (!isAnime) {
|
||||
console.log("genre not found");
|
||||
return;
|
||||
}
|
||||
let title = document.querySelector('h1[itemprop="name"]');
|
||||
if (!title) {
|
||||
console.log("title not found");
|
||||
return;
|
||||
}
|
||||
title = title.textContent.split(" (")[0];
|
||||
|
||||
const buttonStyle = `
|
||||
display: inline-block;
|
||||
font-weight: 400;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
cursor: pointer;
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
user-select: none;
|
||||
background-color: transparent;
|
||||
border: 1px solid transparent;
|
||||
font-size: 1.5rem;
|
||||
line-height: 1.5;
|
||||
border-radius: .25rem;
|
||||
transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
|
||||
padding: 1rem 2rem;
|
||||
color: #fff;
|
||||
background-color: #F04E4E;
|
||||
border-color: #F04E4E;
|
||||
`;
|
||||
|
||||
const buttonHoverStyle = `
|
||||
color: #fff !important;
|
||||
background-color: #E23D3D !important;
|
||||
border-color: #E23D3D !important;
|
||||
`
|
||||
|
||||
const link = document.createElement("a");
|
||||
const button = document.createElement("button");
|
||||
|
||||
link.style =
|
||||
"text-decoration: none; position: fixed; bottom: 0; right: 0; margin: 1.5rem; z-index: 1000;";
|
||||
link.href = "https://anix.wah.su/search?q=" + title + "&ref=kinopoisk.ru&source=extension";
|
||||
link.appendChild(button);
|
||||
button.style = buttonStyle;
|
||||
button.onmouseover = function () {
|
||||
button.style = buttonStyle + buttonHoverStyle
|
||||
}
|
||||
button.onmouseout = function () {
|
||||
button.style = buttonStyle;
|
||||
}
|
||||
button.textContent = "Найти в Anix";
|
||||
|
||||
document.body.appendChild(link);
|
||||
}
|
||||
|
||||
const { host, pathname } = determineHost();
|
||||
|
||||
if (host == "anixart.tv") {
|
||||
addButtonToAnixart(pathname);
|
||||
} else if (host == "www.kinopoisk.ru") {
|
||||
addButtonToKinopoisk();
|
||||
}
|
27
extension/chrome/manifest.json
Normal file
|
@ -0,0 +1,27 @@
|
|||
{
|
||||
"manifest_version": 3,
|
||||
"version": "1.2",
|
||||
"name": "Watch on Anix",
|
||||
"description": "Adds a button to watch on Anix.",
|
||||
"content_scripts": [
|
||||
{
|
||||
"matches": [
|
||||
"https://anixart.tv/release/*",
|
||||
"https://anixart.tv/collection/*",
|
||||
"https://anixart.tv/profile/*",
|
||||
"https://www.kinopoisk.ru/film/*",
|
||||
"https://www.kinopoisk.ru/series/*"
|
||||
],
|
||||
"js": [
|
||||
"main.js"
|
||||
]
|
||||
}
|
||||
],
|
||||
"icons": {
|
||||
"16": "icon-16x16.png",
|
||||
"32": "icon-32x32.png",
|
||||
"48": "icon-48x48.png",
|
||||
"72": "icon-72x72.png",
|
||||
"96": "icon-96x96.png"
|
||||
}
|
||||
}
|
BIN
extension/chrome/watch-on-anix-chrome.zip
Normal file
BIN
extension/firefox/icon-16x16.png
Normal file
After Width: | Height: | Size: 875 B |
BIN
extension/firefox/icon-32x32.png
Normal file
After Width: | Height: | Size: 2.6 KiB |
BIN
extension/firefox/icon-48x48.png
Normal file
After Width: | Height: | Size: 5.2 KiB |
BIN
extension/firefox/icon-72x72.png
Normal file
After Width: | Height: | Size: 10 KiB |
BIN
extension/firefox/icon-96x96.png
Normal file
After Width: | Height: | Size: 16 KiB |
116
extension/firefox/main.js
Normal file
|
@ -0,0 +1,116 @@
|
|||
function determineHost() {
|
||||
const url = new URL(window.location.href);
|
||||
return {
|
||||
host: url.host,
|
||||
pathname: url.pathname,
|
||||
};
|
||||
}
|
||||
|
||||
function addButtonToAnixart(pathname) {
|
||||
// find a container and an open in app link with button
|
||||
const container = document.querySelector('div[style="text-align: center;"]');
|
||||
const openInAppLink = document.querySelector('a[href^="anixart"');
|
||||
const openInAppLinkButton = openInAppLink.querySelector("button");
|
||||
openInAppLinkButton.style = "margin-top: 0px !important;"; // disable default button margin
|
||||
openInAppLinkButton.classList = "btn btn-secondary"; // change default button from primary to secondary
|
||||
|
||||
// create a custom footer
|
||||
const footer = document.createElement("div");
|
||||
footer.style =
|
||||
"display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; align-items: center; margin-top: 20px;";
|
||||
|
||||
// create and set custom link
|
||||
const link = document.createElement("a");
|
||||
const button = document.createElement("button");
|
||||
button.style = "margin-top: 0px !important;";
|
||||
button.classList = "btn btn-primary";
|
||||
button.textContent = "Открыть в Anix";
|
||||
|
||||
const url = new URL(window.location.href);
|
||||
link.href = `https://anix.wah.su${pathname}?ref=anixart.tv&source=extension`;
|
||||
link.appendChild(button);
|
||||
|
||||
// append link and open in app link to footer
|
||||
footer.appendChild(link);
|
||||
footer.appendChild(openInAppLink);
|
||||
|
||||
// append footer to container
|
||||
container.appendChild(footer);
|
||||
}
|
||||
|
||||
function kinopoiskIsAnimeGenrePresent() {
|
||||
const genre = document.querySelector('a[href^="/lists/movies/genre--anime"]');
|
||||
|
||||
if (genre) {
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
function addButtonToKinopoisk() {
|
||||
let isAnime = kinopoiskIsAnimeGenrePresent();
|
||||
if (!isAnime) {
|
||||
console.log("genre not found");
|
||||
return;
|
||||
}
|
||||
let title = document.querySelector('h1[itemprop="name"]');
|
||||
if (!title) {
|
||||
console.log("title not found");
|
||||
return;
|
||||
}
|
||||
title = title.textContent.split(" (")[0];
|
||||
|
||||
const buttonStyle = `
|
||||
display: inline-block;
|
||||
font-weight: 400;
|
||||
text-align: center;
|
||||
vertical-align: middle;
|
||||
cursor: pointer;
|
||||
-webkit-user-select: none;
|
||||
-moz-user-select: none;
|
||||
-ms-user-select: none;
|
||||
user-select: none;
|
||||
background-color: transparent;
|
||||
border: 1px solid transparent;
|
||||
font-size: 1.5rem;
|
||||
line-height: 1.5;
|
||||
border-radius: .25rem;
|
||||
transition: color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;
|
||||
padding: 1rem 2rem;
|
||||
color: #fff;
|
||||
background-color: #F04E4E;
|
||||
border-color: #F04E4E;
|
||||
`;
|
||||
|
||||
const buttonHoverStyle = `
|
||||
color: #fff !important;
|
||||
background-color: #E23D3D !important;
|
||||
border-color: #E23D3D !important;
|
||||
`
|
||||
|
||||
const link = document.createElement("a");
|
||||
const button = document.createElement("button");
|
||||
|
||||
link.style =
|
||||
"text-decoration: none; position: fixed; bottom: 0; right: 0; margin: 1.5rem; z-index: 1000;";
|
||||
link.href = "https://anix.wah.su/search?q=" + title + "&ref=kinopoisk.ru&source=extension";
|
||||
link.appendChild(button);
|
||||
button.style = buttonStyle;
|
||||
button.onmouseover = function () {
|
||||
button.style = buttonStyle + buttonHoverStyle
|
||||
}
|
||||
button.onmouseout = function () {
|
||||
button.style = buttonStyle;
|
||||
}
|
||||
button.textContent = "Найти в Anix";
|
||||
|
||||
document.body.appendChild(link);
|
||||
}
|
||||
|
||||
const { host, pathname } = determineHost();
|
||||
|
||||
if (host == "anixart.tv") {
|
||||
addButtonToAnixart(pathname);
|
||||
} else if (host == "www.kinopoisk.ru") {
|
||||
addButtonToKinopoisk();
|
||||
}
|
32
extension/firefox/manifest.json
Normal file
|
@ -0,0 +1,32 @@
|
|||
{
|
||||
"manifest_version": 2,
|
||||
"version": "1.2",
|
||||
"name": "Watch on Anix",
|
||||
"description": "Adds a button to watch on Anix.",
|
||||
"browser_specific_settings": {
|
||||
"gecko": {
|
||||
"id": "{8c53d0c2-43ad-4498-b700-290bd2e1030f}"
|
||||
}
|
||||
},
|
||||
"content_scripts": [
|
||||
{
|
||||
"matches": [
|
||||
"https://anixart.tv/release/*",
|
||||
"https://anixart.tv/collection/*",
|
||||
"https://anixart.tv/profile/*",
|
||||
"https://www.kinopoisk.ru/film/*",
|
||||
"https://www.kinopoisk.ru/series/*"
|
||||
],
|
||||
"js": [
|
||||
"main.js"
|
||||
]
|
||||
}
|
||||
],
|
||||
"icons": {
|
||||
"16": "icon-16x16.png",
|
||||
"32": "icon-32x32.png",
|
||||
"48": "icon-48x48.png",
|
||||
"72": "icon-72x72.png",
|
||||
"96": "icon-96x96.png"
|
||||
}
|
||||
}
|