-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit 336102e
Showing
22 changed files
with
1,727 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
web-ext-artifacts | ||
node_modules |
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
[data:image/s3,"s3://crabby-images/1da30/1da302203b44f99175c0d052e3ab426474fd0393" alt=""](https://github.com/mojira/message-extension/issues) | ||
[data:image/s3,"s3://crabby-images/a370e/a370ea9329b9cb7e9f31617b9482983bb5f4f43c" alt=""](https://github.com/mojira/message-extension/stargazers) | ||
[data:image/s3,"s3://crabby-images/9680f/9680f150cc9cd2415c466dcf3e5a6d15de09e0e1" alt=""](https://github.com/mojira/message-extension/blob/master/LICENSE.md) | ||
|
||
# Mojira Helper Message Browser Extension | ||
This is a browser extension made for simplifying the mod and helper workflow on Mojira. It integrates the helper messages from the [`helper-messages`](https://github.com/mojira/helper-messages) repository directly into the Mojira interface, so that messages can be pasted very easily without the need of visiting another website. | ||
|
||
On top of that, it always keeps the messages up-to-date with the latest version from the `helper-messages` repository. | ||
|
||
As of right now, the extension has only been tested in Mozilla Firefox. It is possible that it works in other browsers like Chrome or Opera as well, but those are currently unsupported. | ||
|
||
⚠ Please note that the helper messages may only be used on the bug tracker by helpers, moderators or Mojang staff. Do not use them yourself if you do not belong to one of these groups as it may confuse users regarding your role. | ||
|
||
## Installation | ||
1. Download the latest version of the extension from the [releases](https://github.com/mojira/message-extension/releases) page. | ||
2. Open `about:addons` in your browser | ||
3. Click on the gear icon | ||
4. Select "Install Add-on from File..." | ||
5. Select the downloaded file | ||
|
||
## Usage | ||
When the addon recognizes a Mojira text field, it automatically highlights it in a green color to indicate that the addon is active. At the same time, it adds an additional "Add Message" button to the toolbar of that text field. You can use that button to insert messages and view all available messages along with their shortcuts. | ||
|
||
You can also insert messages by typing the shortcut of the message prefixed with a configurable prefix into the text field. | ||
|
||
Currently, both methods only work with the "Text" version of the text field. In "Visual" mode, the addon will not function properly! | ||
|
||
Once a text field is initialized, its available messages will no longer change, even if the addon settings have been changed. You need to reload the page in order for any potential changes to take effect. | ||
|
||
### Message updates | ||
The addon regularily checks whether the helper messages have been updated, and if they have, it automatically saves the new messages and continues to use the new version. This is indicated by a badge on the Mojira icon. | ||
|
||
While the addon is checking for addons, the badge is green and display a question mark. | ||
|
||
When the addon has found an update, the badge turns blue and contains the letter "i", and if an error occurred, it is red with an exclamation mark. These two badges can be dismissed by clicking on the icon. | ||
|
||
### Settings | ||
You can configure the addon by clicking the Mojira icon in the browser's toolbar. There you can configure which messages you want to use, and how often (if at all) the addon should check for message updates. | ||
|
||
## Contributing | ||
Issues and pull requests are always very much appreciated. If you want to help developing the extension, here are a few tips: | ||
|
||
* Run `npm i` in order to install the needed dependencies. Currently this only includes the type definitions for web extensions. | ||
* Run `npm i -g web-ext` in order to install some handy developer tools for web extension development. | ||
* Run `web-ext run` in order to launch a blank instance of Firefox where your addon is running. The addon is reloaded every time a file is changed. | ||
* You can visit `about:debugging` in that Firefox instance and access the addon's console and dev interface from the "This Firefox" tab. | ||
* You can run `web-ext lint --self-hosted` in order to check whether the addon has any issues that might prevent it from being signed. | ||
|
||
## Publishing | ||
When a new version is released, it first needs to be signed by Mozilla. After this is done, the addon file is uploaded to the "releases" page and the version manifest in the `releases` branch is updated. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,52 @@ | ||
{ | ||
"manifest_version": 2, | ||
"name": "Mojira Message Extension", | ||
"version": "0.1", | ||
|
||
"description": "Easily access helper messages directly on Mojira by using shortcuts. Please note that the helper messages may only be used by Mojira helpers, Mojira moderators, and Mojang staff.", | ||
|
||
"browser_specific_settings": { | ||
"gecko": { | ||
"id": "message-extension@mojira.github.io", | ||
"update_url": "https://raw.githubusercontent.com/mojira/message-extension/releases/updates.json", | ||
"strict_min_version": "68.0" | ||
} | ||
}, | ||
|
||
"icons": { | ||
"48": "icons/mojira-logo-48.png", | ||
"96": "icons/mojira-logo-96.png" | ||
}, | ||
|
||
"background": { | ||
"page": "src/background.html" | ||
}, | ||
|
||
"options_ui": { | ||
"page": "src/options/options.html", | ||
"browser_style": true | ||
}, | ||
|
||
"browser_action": { | ||
"default_icon": "icons/mojira-logo-32.png", | ||
"default_title": "Mojira Helper Messages", | ||
"browser_style": true | ||
}, | ||
|
||
"content_scripts": [{ | ||
"matches": ["*://bugs.mojang.com/*"], | ||
"css": [ | ||
"src/styling.css" | ||
], | ||
"js": [ | ||
"src/util/util.js", | ||
"src/main.js" | ||
] | ||
}], | ||
|
||
"permissions": [ | ||
"alarms", | ||
"clipboardRead", | ||
"storage" | ||
] | ||
} |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
{ | ||
"name": "mojira-message-extension", | ||
"version": "0.1.0", | ||
"description": "A browser extension for simplifying the mod & helper workflow on Mojang's bug tracker Mojira", | ||
"main": "main.js", | ||
"scripts": { | ||
"test": "echo \"Error: no test specified\" && exit 1" | ||
}, | ||
"author": "violine1101", | ||
"license": "GPL-3.0", | ||
"devDependencies": { | ||
"web-ext-types": "github:kelseasy/web-ext-types" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,8 @@ | ||
<!DOCTYPE html> | ||
<html lang="en"> | ||
<head> | ||
<meta charset="utf-8"> | ||
<script type="module" src="./util/messages.js"></script> | ||
<script type="module" src="./background.js"></script> | ||
</head> | ||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
import { getMessages, checkForUpdates } from './util/messages.js'; | ||
import { getAutoUpdateInterval, getPrefix } from './util/settings.js'; | ||
|
||
(async () => { | ||
browser.browserAction.onClicked.addListener(() => { | ||
browser.runtime.openOptionsPage(); | ||
}); | ||
|
||
await checkForUpdates(); | ||
|
||
browser.alarms.create('check-for-message-updates', { | ||
periodInMinutes: await getAutoUpdateInterval() | ||
}); | ||
|
||
browser.alarms.onAlarm.addListener(async alarm => { | ||
if (alarm.name === 'check-for-message-updates') { | ||
await checkForUpdates(); | ||
} | ||
}); | ||
|
||
browser.runtime.onMessage.addListener(message => { | ||
switch (message) { | ||
case 'messages-request': | ||
return getMessages(); | ||
case 'prefix-request': | ||
return getPrefix(); | ||
} | ||
}); | ||
})(); |
Oops, something went wrong.