105 lines
4.4 KiB
JavaScript
105 lines
4.4 KiB
JavaScript
module.exports = (Plugin, Api, Vendor, Dependencies) => {
|
|
|
|
const { $, moment, _ } = Vendor;
|
|
const { Events, Logger } = Api;
|
|
|
|
return class extends Plugin {
|
|
onStart() {
|
|
Events.subscribe('TEST_EVENT', this.eventTest);
|
|
Logger.log('onStart');
|
|
|
|
Logger.log(`Plugin setting "default-0" value: ${this.getSetting('default-0')}`);
|
|
this.events.on('setting-updated', event => {
|
|
console.log('Received plugin setting update:', event);
|
|
});
|
|
this.events.on('settings-updated', event => {
|
|
console.log('Received plugin settings update:', event);
|
|
});
|
|
|
|
Logger.log(`Internal setting "core/default/test-setting" value: ${Api.Settings.get('core', 'default', 'test-setting')}`);
|
|
Events.subscribe('setting-updated', event => {
|
|
console.log('Received internal setting update:', event);
|
|
});
|
|
|
|
const exampleModule = new Dependencies['Example Module'];
|
|
Logger.log(`2+4=${exampleModule.add(2, 4)}`);
|
|
return true;
|
|
}
|
|
|
|
onStop() {
|
|
Events.unsubscribeAll();
|
|
Logger.log('onStop');
|
|
console.log(this.showSettingsModal());
|
|
return true;
|
|
}
|
|
|
|
onUnload(reload) {
|
|
Logger.log('Unloading plugin');
|
|
delete require.cache[require.resolve('./component')];
|
|
}
|
|
|
|
eventTest(e) {
|
|
Logger.log(e);
|
|
}
|
|
|
|
get bridge() {
|
|
return {
|
|
test1: this.test1.bind(this),
|
|
test2: this.test2.bind(this)
|
|
};
|
|
}
|
|
|
|
test1() { return 'It works!'; }
|
|
test2() { return 'This works too!'; }
|
|
|
|
settingChanged(category, setting_id, value) {
|
|
if (!this.enabled) return;
|
|
Logger.log(`${category}/${setting_id} changed to ${value}`);
|
|
}
|
|
|
|
settingsChanged(settings) {
|
|
if (!this.enabled) return;
|
|
Logger.log([ 'Settings updated', settings ]);
|
|
}
|
|
|
|
get settingscomponent() {
|
|
const plugin = this;
|
|
return this._settingscomponent ? this._settingscomponent : this._settingscomponent = {
|
|
template: "<div style=\"margin-bottom: 15px; background-color: rgba(0, 0, 0, 0.2); border: 1px dashed rgba(255, 255, 255, 0.2); padding: 10px; color: #f6f6f7; font-weight: 500; font-size: 15px;\">Test custom setting {{ setting.id }}. This is from Plugin.settingscomponent.<br />Plugin ID: {{ plugin.id }}</div>",
|
|
props: ['setting', 'change'],
|
|
data() { return { plugin }; }
|
|
};
|
|
}
|
|
|
|
getSettingsComponent(setting, change) {
|
|
return this._settingscomponent2 ? this._settingscomponent2 : this.settingscomponent2 = {
|
|
template: "<div style=\"margin-bottom: 15px; background-color: rgba(0, 0, 0, 0.2); border: 1px dashed rgba(255, 255, 255, 0.2); padding: 10px; color: #f6f6f7; font-weight: 500; font-size: 15px;\">Test custom setting {{ setting.id }}. This is from Plugin.getSettingsComponent().</div>",
|
|
props: ['setting', 'change']
|
|
};
|
|
}
|
|
|
|
getSettingsComponentHTMLElement(setting, change) {
|
|
const el = document.createElement('div');
|
|
el.setAttribute('style', 'margin-bottom: 15px; background-color: rgba(0, 0, 0, 0.2); border: 1px dashed rgba(255, 255, 255, 0.2); padding: 10px; color: #f6f6f7; font-weight: 500; font-size: 15px;');
|
|
el.textContent = `Test custom setting ${setting.id}. This is from Plugin.getSettingsComponentHTMLElement(). Current value: ${setting.value}.`;
|
|
|
|
const button1 = document.createElement('button');
|
|
button1.setAttribute('class', 'bd-button bd-button-primary');
|
|
button1.setAttribute('style', 'display: inline-block; margin-left: 10px;');
|
|
button1.addEventListener('click', () => change(1));
|
|
button1.textContent = 'Set value to 1';
|
|
el.appendChild(button1);
|
|
|
|
const button2 = document.createElement('button');
|
|
button2.setAttribute('class', 'bd-button bd-button-primary');
|
|
button2.setAttribute('style', 'display: inline-block; margin-left: 10px;');
|
|
button2.addEventListener('click', () => change(2));
|
|
button2.textContent = 'Set value to 2';
|
|
el.appendChild(button2);
|
|
|
|
return el;
|
|
}
|
|
}
|
|
|
|
}
|