mirror of
https://github.com/standardnotes/app.git
synced 2026-01-16 23:01:30 +00:00
* feat: snjs app groups * fix: update snjs version to point to wip commit * wip: account switcher * feat: rename lock manager to auto lock service * fix: more relevant sign out copy * chore(deps): update snjs * fix: use setTimeout instead of setImmediate * feat: make account switcher expiremental feature * chore(deps): upgrade snjs
104 lines
2.7 KiB
TypeScript
104 lines
2.7 KiB
TypeScript
import { WebDeviceInterface } from '@/web_device_interface';
|
|
import { WebApplication } from './application';
|
|
import { ApplicationDescriptor, SNApplicationGroup, DeviceInterface } from 'snjs';
|
|
import {
|
|
ArchiveManager,
|
|
DesktopManager,
|
|
KeyboardManager,
|
|
AutolockService,
|
|
NativeExtManager,
|
|
PreferencesManager,
|
|
StatusManager,
|
|
ThemeManager
|
|
} from '@/services';
|
|
import { AppState } from '@/ui_models/app_state';
|
|
import { Bridge } from '@/services/bridge';
|
|
|
|
export class ApplicationGroup extends SNApplicationGroup {
|
|
|
|
$compile: ng.ICompileService
|
|
$rootScope: ng.IRootScopeService
|
|
$timeout: ng.ITimeoutService
|
|
|
|
/* @ngInject */
|
|
constructor(
|
|
$compile: ng.ICompileService,
|
|
$rootScope: ng.IRootScopeService,
|
|
$timeout: ng.ITimeoutService,
|
|
private defaultSyncServerHost: string,
|
|
private bridge: Bridge,
|
|
) {
|
|
super(new WebDeviceInterface(
|
|
$timeout,
|
|
bridge
|
|
));
|
|
this.$compile = $compile;
|
|
this.$timeout = $timeout;
|
|
this.$rootScope = $rootScope;
|
|
}
|
|
|
|
async initialize(callback?: any) {
|
|
await super.initialize({
|
|
applicationCreator: this.createApplication
|
|
});
|
|
|
|
/** FIXME(baptiste): rely on a less fragile method to detect Electron */
|
|
if ((window as any).isElectron) {
|
|
Object.defineProperty(window, 'desktopManager', {
|
|
get: () => (this.primaryApplication as WebApplication).getDesktopService()
|
|
});
|
|
}
|
|
}
|
|
|
|
private createApplication = (descriptor: ApplicationDescriptor, deviceInterface: DeviceInterface) => {
|
|
const scope = this.$rootScope.$new(true);
|
|
const application = new WebApplication(
|
|
deviceInterface as WebDeviceInterface,
|
|
descriptor.identifier,
|
|
this.$compile,
|
|
scope,
|
|
this.defaultSyncServerHost,
|
|
this.bridge,
|
|
);
|
|
const appState = new AppState(
|
|
this.$rootScope,
|
|
this.$timeout,
|
|
application
|
|
);
|
|
const archiveService = new ArchiveManager(
|
|
application
|
|
);
|
|
const desktopService = new DesktopManager(
|
|
this.$rootScope,
|
|
this.$timeout,
|
|
application,
|
|
this.bridge,
|
|
);
|
|
const keyboardService = new KeyboardManager();
|
|
const autolockService = new AutolockService(
|
|
application
|
|
);
|
|
const nativeExtService = new NativeExtManager(
|
|
application
|
|
);
|
|
const prefsService = new PreferencesManager(
|
|
application
|
|
);
|
|
const statusService = new StatusManager();
|
|
const themeService = new ThemeManager(
|
|
application,
|
|
);
|
|
application.setWebServices({
|
|
appState,
|
|
archiveService,
|
|
desktopService,
|
|
keyboardService,
|
|
autolockService,
|
|
nativeExtService,
|
|
prefsService,
|
|
statusService,
|
|
themeService
|
|
});
|
|
return application;
|
|
}
|
|
}
|