diff --git a/.eslintrc.json b/.eslintrc.json
index a72b93b9..01ee5e2a 100644
--- a/.eslintrc.json
+++ b/.eslintrc.json
@@ -5,6 +5,7 @@
},
"extends": [
"eslint:recommended",
+ "prettier",
"plugin:react/recommended",
"plugin:@typescript-eslint/recommended"
],
diff --git a/.prettierignore b/.prettierignore
new file mode 100644
index 00000000..0e4cfbd3
--- /dev/null
+++ b/.prettierignore
@@ -0,0 +1,6 @@
+node_modules
+public
+dist
+lang
+coverage
+*.json
diff --git a/.prettierrc.json b/.prettierrc.json
new file mode 100644
index 00000000..932ed3ef
--- /dev/null
+++ b/.prettierrc.json
@@ -0,0 +1,7 @@
+{
+ "trailingComma": "es5",
+ "tabWidth": 4,
+ "semi": false,
+ "singleQuote": true,
+ "printWidth": 100
+}
diff --git a/package.json b/package.json
index e3c283ae..180563c6 100644
--- a/package.json
+++ b/package.json
@@ -4,12 +4,15 @@
"bootstrap": "lerna bootstrap",
"build": "lerna run build",
"clean": "lerna clean && rm -rf node_modules",
- "lint": "lerna run lint",
+ "lint": "lerna run lint --stream",
"test": "lerna run test --stream"
},
"private": true,
"devDependencies": {
- "lerna": "^3.16.4"
+ "husky": "4",
+ "lerna": "^3.16.4",
+ "lint-staged": "^10.5.4",
+ "prettier": "^2.2.1"
},
"workspaces": [
"packages/*"
@@ -37,5 +40,16 @@
]
},
"homepage": "http://localhost:8080/react",
- "license": "https://wisemapping.atlassian.net/wiki/spaces/WS/pages/524357/WiseMapping+Public+License+Version+1.0+WPL"
+ "license": "https://wisemapping.atlassian.net/wiki/spaces/WS/pages/524357/WiseMapping+Public+License+Version+1.0+WPL",
+ "husky": {
+ "hooks": {
+ "pre-commit": "lint-staged",
+ "pre-push": "yarn lint && yarn test"
+ }
+ },
+ "lint-staged": {
+ "**/*.{ts,tsx}": [
+ "prettier --write"
+ ]
+ }
}
diff --git a/packages/editor/package.json b/packages/editor/package.json
index bed76ce5..463b4523 100644
--- a/packages/editor/package.json
+++ b/packages/editor/package.json
@@ -15,8 +15,10 @@
"@typescript-eslint/eslint-plugin": "^4.8.1",
"@typescript-eslint/parser": "^4.8.1",
"eslint": "^7.14.0",
+ "eslint-config-prettier": "^8.0.0",
"eslint-plugin-react": "^7.21.5",
"eslint-plugin-react-hooks": "^4.2.0",
+ "prettier": "^2.2.1",
"ts-loader": "^8.0.11",
"ts-node": "^9.0.0",
"typescript": "^4.1.2"
diff --git a/packages/editor/src/components/canvas/index.tsx b/packages/editor/src/components/canvas/index.tsx
index 6ad5cb89..dbc87f1f 100644
--- a/packages/editor/src/components/canvas/index.tsx
+++ b/packages/editor/src/components/canvas/index.tsx
@@ -1,8 +1,6 @@
-import React from 'react';
-import { StyledCanvas } from './styled';
+import React from 'react'
+import { StyledCanvas } from './styled'
-const Canvas = (): React.ReactElement => (
- canvas
-);
+const Canvas = (): React.ReactElement => canvas
-export default Canvas;
+export default Canvas
diff --git a/packages/editor/src/components/canvas/styled.ts b/packages/editor/src/components/canvas/styled.ts
index 7cc7eb85..8f35d710 100644
--- a/packages/editor/src/components/canvas/styled.ts
+++ b/packages/editor/src/components/canvas/styled.ts
@@ -1,8 +1,8 @@
-import styled from 'styled-components';
+import styled from 'styled-components'
export const StyledCanvas = styled.div`
height: 100%
width: 100%;
flex: 1;
-`;
+`
diff --git a/packages/editor/src/components/footer/index.tsx b/packages/editor/src/components/footer/index.tsx
index da0aad74..b42ffdca 100644
--- a/packages/editor/src/components/footer/index.tsx
+++ b/packages/editor/src/components/footer/index.tsx
@@ -1,8 +1,6 @@
-import React from 'react';
-import { StyledFooter } from './styled';
+import React from 'react'
+import { StyledFooter } from './styled'
-const Footer = (): React.ReactElement => (
- footer
-);
+const Footer = (): React.ReactElement => footer
-export default Footer;
+export default Footer
diff --git a/packages/editor/src/components/footer/styled.ts b/packages/editor/src/components/footer/styled.ts
index fd557520..e9d95535 100644
--- a/packages/editor/src/components/footer/styled.ts
+++ b/packages/editor/src/components/footer/styled.ts
@@ -1,8 +1,8 @@
-import styled from 'styled-components';
-import { times } from '../../size';
+import styled from 'styled-components'
+import { times } from '../../size'
export const StyledFooter = styled.div`
- height: ${times(10)};
- width: 100%;
- border: 1px solid black;
-`;
+ height: ${times(10)};
+ width: 100%;
+ border: 1px solid black;
+`
diff --git a/packages/editor/src/components/frame/index.tsx b/packages/editor/src/components/frame/index.tsx
index 2cf8527f..31f88de4 100644
--- a/packages/editor/src/components/frame/index.tsx
+++ b/packages/editor/src/components/frame/index.tsx
@@ -1,15 +1,15 @@
-import React from 'react';
-import Footer from '../footer';
-import TopBar from '../top-bar';
-import Canvas from '../canvas';
-import { StyledFrame } from './styled';
+import React from 'react'
+import Footer from '../footer'
+import TopBar from '../top-bar'
+import Canvas from '../canvas'
+import { StyledFrame } from './styled'
const Frame = (): React.ReactElement => (
-
-
-
-
-
-);
+
+
+
+
+
+)
-export default Frame;
+export default Frame
diff --git a/packages/editor/src/components/frame/styled.ts b/packages/editor/src/components/frame/styled.ts
index 0d31f372..d892f457 100644
--- a/packages/editor/src/components/frame/styled.ts
+++ b/packages/editor/src/components/frame/styled.ts
@@ -1,8 +1,8 @@
-import styled from 'styled-components';
+import styled from 'styled-components'
export const StyledFrame = styled.div`
- width: 100%;
- height: 100%;
- display: flex;
- flex-direction: column;
-`;
+ width: 100%;
+ height: 100%;
+ display: flex;
+ flex-direction: column;
+`
diff --git a/packages/editor/src/components/top-bar/index.tsx b/packages/editor/src/components/top-bar/index.tsx
index 5670f1de..09f3f28c 100644
--- a/packages/editor/src/components/top-bar/index.tsx
+++ b/packages/editor/src/components/top-bar/index.tsx
@@ -1,8 +1,6 @@
-import React from 'react';
+import React from 'react'
import { StyledTopBar } from './styled'
-const TopBar = ():React.ReactElement => (
- top bar
-);
+const TopBar = (): React.ReactElement => top bar
-export default TopBar;
+export default TopBar
diff --git a/packages/editor/src/components/top-bar/styled.ts b/packages/editor/src/components/top-bar/styled.ts
index f79be7be..aed29805 100644
--- a/packages/editor/src/components/top-bar/styled.ts
+++ b/packages/editor/src/components/top-bar/styled.ts
@@ -1,8 +1,8 @@
-import styled from 'styled-components';
-import { times } from '../../size';
+import styled from 'styled-components'
+import { times } from '../../size'
export const StyledTopBar = styled.div`
- height: ${times(10)};
- width: 100%;
- border: 1px solid black;
-`;
+ height: ${times(10)};
+ width: 100%;
+ border: 1px solid black;
+`
diff --git a/packages/editor/src/index.tsx b/packages/editor/src/index.tsx
index 5b7b798e..2a51ac6a 100644
--- a/packages/editor/src/index.tsx
+++ b/packages/editor/src/index.tsx
@@ -1,3 +1,3 @@
-import Editor from './components/frame';
+import Editor from './components/frame'
-export default Editor;
+export default Editor
diff --git a/packages/editor/src/size.ts b/packages/editor/src/size.ts
index e3432eb0..99fcd521 100644
--- a/packages/editor/src/size.ts
+++ b/packages/editor/src/size.ts
@@ -1,10 +1,9 @@
+const unit = 4 // pixels
-const unit = 4; // pixels
+export const XS = '4px'
+export const S = '8px'
+export const M = '16px'
+export const L = '24px'
+export const XL = '24px'
-export const XS = '4px';
-export const S = '8px';
-export const M = '16px';
-export const L = '24px';
-export const XL = '24px';
-
-export const times = (n: number):string => `${unit * n}px`;
+export const times = (n: number): string => `${unit * n}px`
diff --git a/packages/webapp/cypress/integration/maps.test.ts b/packages/webapp/cypress/integration/maps.test.ts
index de55c77d..8a9d518a 100644
--- a/packages/webapp/cypress/integration/maps.test.ts
+++ b/packages/webapp/cypress/integration/maps.test.ts
@@ -1,16 +1,16 @@
-import MapsPage from "../pageObject/MapsPage";
+import MapsPage from '../pageObject/MapsPage'
-context("Maps Page", () => {
- beforeEach(() => {
- cy.visit("http://localhost:3000/c/maps");
- });
+context('Maps Page', () => {
+ beforeEach(() => {
+ cy.visit('http://localhost:3000/c/maps')
+ })
- it("should load the maps page", () => {
- MapsPage.isLoaded();
- });
+ it('should load the maps page', () => {
+ MapsPage.isLoaded()
+ })
- it("should open the create dialog", () => {
- MapsPage.create();
- MapsPage.isCreateDialogVisible();
- });
-});
+ it('should open the create dialog', () => {
+ MapsPage.create()
+ MapsPage.isCreateDialogVisible()
+ })
+})
diff --git a/packages/webapp/cypress/pageObject/MapsPage.ts b/packages/webapp/cypress/pageObject/MapsPage.ts
index 1df20628..73e877eb 100644
--- a/packages/webapp/cypress/pageObject/MapsPage.ts
+++ b/packages/webapp/cypress/pageObject/MapsPage.ts
@@ -1,14 +1,14 @@
export default class MapsPage {
- static isLoaded() {
- return cy.findByTestId("create");
- }
+ static isLoaded() {
+ return cy.findByTestId('create')
+ }
- static create() {
- return cy.findByTestId("create").click();
- }
+ static create() {
+ return cy.findByTestId('create').click()
+ }
- static isCreateDialogVisible() {
- //TODO move to findByText when the double create dialog issue is solved
- return cy.findAllByText("Create a new mindmap");
- }
+ static isCreateDialogVisible() {
+ //TODO move to findByText when the double create dialog issue is solved
+ return cy.findAllByText('Create a new mindmap')
+ }
}
diff --git a/packages/webapp/cypress/plugins/index.ts b/packages/webapp/cypress/plugins/index.ts
index 5bfdbc45..ab93c3fe 100644
--- a/packages/webapp/cypress/plugins/index.ts
+++ b/packages/webapp/cypress/plugins/index.ts
@@ -2,6 +2,6 @@
* @type {Cypress.PluginConfig}
*/
module.exports = (on, config) => {
- // `on` is used to hook into various events Cypress emits
- // `config` is the resolved Cypress config
+ // `on` is used to hook into various events Cypress emits
+ // `config` is the resolved Cypress config
}
diff --git a/packages/webapp/cypress/support/index.ts b/packages/webapp/cypress/support/index.ts
index f65e7f7c..43c03b75 100644
--- a/packages/webapp/cypress/support/index.ts
+++ b/packages/webapp/cypress/support/index.ts
@@ -1 +1 @@
-import './commands'
\ No newline at end of file
+import './commands'
diff --git a/packages/webapp/package.json b/packages/webapp/package.json
index b02fc7fa..ade50ce9 100644
--- a/packages/webapp/package.json
+++ b/packages/webapp/package.json
@@ -29,11 +29,13 @@
"css-loader": "^5.0.1",
"cypress": "^6.5.0",
"eslint": "^7.14.0",
+ "eslint-config-prettier": "^8.0.0",
"eslint-plugin-react": "^7.21.5",
"eslint-plugin-react-hooks": "^4.2.0",
"file-loader": "^6.2.0",
"html-webpack-dynamic-env-plugin": "^0.0.2",
"html-webpack-plugin": "^5.1.0",
+ "prettier": "^2.2.1",
"sass-loader": "^10.1.0",
"style-loader": "^2.0.0",
"ts-loader": "^8.0.11",
diff --git a/packages/webapp/src/@types/index.d.ts b/packages/webapp/src/@types/index.d.ts
index e238d01c..dbd12dc9 100644
--- a/packages/webapp/src/@types/index.d.ts
+++ b/packages/webapp/src/@types/index.d.ts
@@ -1,2 +1,2 @@
-declare module '*.png';
-declare module '*.svg';
+declare module '*.png'
+declare module '*.svg'
diff --git a/packages/webapp/src/@types/typings.d.ts b/packages/webapp/src/@types/typings.d.ts
index fe4cdc9f..b44fe72c 100644
--- a/packages/webapp/src/@types/typings.d.ts
+++ b/packages/webapp/src/@types/typings.d.ts
@@ -1,19 +1,19 @@
-declare module '*.jpeg';
-declare module '*.jpg';
-declare module '*.jpeg';
-declare module '*.png';
-declare module '*.svg';
-declare module '*.json';
+declare module '*.jpeg'
+declare module '*.jpg'
+declare module '*.jpeg'
+declare module '*.png'
+declare module '*.svg'
+declare module '*.json'
import { Dayjs } from 'dayjs'
type DateType = string | number | Date | Dayjs
// @Todo: review if there is a better support for this.
declare module 'dayjs' {
- interface Dayjs {
- fromNow(withoutSuffix?: boolean): string
- from(compared: DateType, withoutSuffix?: boolean): string
- toNow(withoutSuffix?: boolean): string
- to(compared: DateType, withoutSuffix?: boolean): string
- }
-}
\ No newline at end of file
+ interface Dayjs {
+ fromNow(withoutSuffix?: boolean): string
+ from(compared: DateType, withoutSuffix?: boolean): string
+ toNow(withoutSuffix?: boolean): string
+ to(compared: DateType, withoutSuffix?: boolean): string
+ }
+}
diff --git a/packages/webapp/src/app.tsx b/packages/webapp/src/app.tsx
index c343d32c..73492f7b 100644
--- a/packages/webapp/src/app.tsx
+++ b/packages/webapp/src/app.tsx
@@ -1,65 +1,76 @@
-import React, { ReactElement } from 'react';
-import { IntlProvider } from 'react-intl';
-import { Route, Switch, Redirect, BrowserRouter as Router } from 'react-router-dom';
+import React, { ReactElement } from 'react'
+import { IntlProvider } from 'react-intl'
+import { Route, Switch, Redirect, BrowserRouter as Router } from 'react-router-dom'
-import RegistrationSuccessPage from './components/registration-success-page';
-import ForgotPasswordSuccessPage from './components/forgot-password-success-page';
-import RegistationPage from './components/registration-page';
-import LoginPage from './components/login-page';
-import store from "./redux/store";
-import { ForgotPasswordPage } from './components/forgot-password-page';
-import { Provider } from 'react-redux';
-import { QueryClient, QueryClientProvider } from 'react-query';
+import RegistrationSuccessPage from './components/registration-success-page'
+import ForgotPasswordSuccessPage from './components/forgot-password-success-page'
+import RegistationPage from './components/registration-page'
+import LoginPage from './components/login-page'
+import store from './redux/store'
+import { ForgotPasswordPage } from './components/forgot-password-page'
+import { Provider } from 'react-redux'
+import { QueryClient, QueryClientProvider } from 'react-query'
import { theme } from './theme'
-import AppI18n, { Locales } from './classes/app-i18n';
-import MapsPage from './components/maps-page';
-import CssBaseline from '@material-ui/core/CssBaseline';
-import { ThemeProvider } from '@material-ui/core/styles';
+import AppI18n, { Locales } from './classes/app-i18n'
+import MapsPage from './components/maps-page'
+import CssBaseline from '@material-ui/core/CssBaseline'
+import { ThemeProvider } from '@material-ui/core/styles'
const queryClient = new QueryClient({
- defaultOptions: {
- queries: {
- refetchIntervalInBackground: false,
- staleTime: 5 * 1000 * 60 // 10 minutes
- }
- }
-});
+ defaultOptions: {
+ queries: {
+ refetchIntervalInBackground: false,
+ staleTime: 5 * 1000 * 60, // 10 minutes
+ },
+ },
+})
-const App = ():ReactElement => {
- const appi18n = new AppI18n();
- const locale = appi18n.getBrowserLocale();
+const App = (): ReactElement => {
+ const appi18n = new AppI18n()
+ const locale = appi18n.getBrowserLocale()
- return locale.message ? (
-
-
- }>
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- ) : (
Loading ...
)
+ return locale.message ? (
+
+
+ }
+ >
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ ) : (
+ Loading ...
+ )
}
-export default App;
+export default App
diff --git a/packages/webapp/src/classes/app-i18n/index.ts b/packages/webapp/src/classes/app-i18n/index.ts
index 9af15a03..dfa5ead2 100644
--- a/packages/webapp/src/classes/app-i18n/index.ts
+++ b/packages/webapp/src/classes/app-i18n/index.ts
@@ -1,48 +1,46 @@
-import { fetchAccount } from './../../redux/clientSlice';
-import 'dayjs/locale/fr';
-import 'dayjs/locale/en';
-import 'dayjs/locale/es';
+import { fetchAccount } from './../../redux/clientSlice'
+import 'dayjs/locale/fr'
+import 'dayjs/locale/en'
+import 'dayjs/locale/es'
export class Locale {
- code: LocaleCode;
- label: string;
- message: Record ;
+ code: LocaleCode
+ label: string
+ message: Record
constructor(code: LocaleCode, label: string, message: unknown) {
- this.code = code;
- this.label = label;
- this.message = message as Record;
+ this.code = code
+ this.label = label
+ this.message = message as Record
}
}
export default class AppI18n {
public getUserLocale(): Locale {
- const account = fetchAccount();
- return account ? account.locale : this.getBrowserLocale();
+ const account = fetchAccount()
+ return account ? account.locale : this.getBrowserLocale()
}
public getBrowserLocale(): Locale {
- let localeCode = (navigator.languages && navigator.languages[0])
- || navigator.language;
+ let localeCode = (navigator.languages && navigator.languages[0]) || navigator.language
// Just remove the variant ...
- localeCode = localeCode.split('-')[0];
+ localeCode = localeCode.split('-')[0]
- let result = Locales.EN;
+ let result = Locales.EN
try {
result = localeFromStr(localeCode)
} catch {
- console.warn(`Unsupported languange code ${localeCode}`);
+ console.warn(`Unsupported languange code ${localeCode}`)
}
- return result;
+ return result
}
}
-export type LocaleCode = 'en' | 'es' | 'fr' | 'de';
+export type LocaleCode = 'en' | 'es' | 'fr' | 'de'
-export const Locales =
-{
+export const Locales = {
EN: new Locale('en', 'English', require('./../../compiled-lang/en.json')),
ES: new Locale('es', 'Español', require('./../../compiled-lang/es.json')),
DE: new Locale('fr', 'Français', require('./../../compiled-lang/fr.json')),
@@ -50,15 +48,13 @@ export const Locales =
}
export const localeFromStr = (code: string): Locale => {
- const locales: Locale[] = Object
- .values(Locales);
+ const locales: Locale[] = Object.values(Locales)
- const result = locales
- .find((l) => l.code == code);
+ const result = locales.find((l) => l.code == code)
if (!result) {
throw `Language code could not be found in list of default supported: + ${code}`
}
- return result;
+ return result
}
diff --git a/packages/webapp/src/classes/client/client-health-sentinel/index.tsx b/packages/webapp/src/classes/client/client-health-sentinel/index.tsx
index 43c5c0e9..bc0ffc2e 100644
--- a/packages/webapp/src/classes/client/client-health-sentinel/index.tsx
+++ b/packages/webapp/src/classes/client/client-health-sentinel/index.tsx
@@ -1,20 +1,20 @@
-import { useSelector } from 'react-redux';
-import React from "react";
-import { activeInstanceStatus, ClientStatus } from '../../../redux/clientSlice';
-import { FormattedMessage } from 'react-intl';
-import Dialog from '@material-ui/core/Dialog';
-import DialogTitle from '@material-ui/core/DialogTitle';
-import DialogContent from '@material-ui/core/DialogContent';
-import Alert from '@material-ui/lab/Alert';
-import DialogActions from '@material-ui/core/DialogActions';
-import Button from '@material-ui/core/Button';
-import AlertTitle from '@material-ui/lab/AlertTitle';
+import { useSelector } from 'react-redux'
+import React from 'react'
+import { activeInstanceStatus, ClientStatus } from '../../../redux/clientSlice'
+import { FormattedMessage } from 'react-intl'
+import Dialog from '@material-ui/core/Dialog'
+import DialogTitle from '@material-ui/core/DialogTitle'
+import DialogContent from '@material-ui/core/DialogContent'
+import Alert from '@material-ui/lab/Alert'
+import DialogActions from '@material-ui/core/DialogActions'
+import Button from '@material-ui/core/Button'
+import AlertTitle from '@material-ui/lab/AlertTitle'
const ClientHealthSentinel = (): React.ReactElement => {
- const status: ClientStatus = useSelector(activeInstanceStatus);
+ const status: ClientStatus = useSelector(activeInstanceStatus)
const handleOnClose = () => {
- window.location.href = '/c/login';
+ window.location.href = '/c/login'
}
return (
@@ -23,30 +23,33 @@ const ClientHealthSentinel = (): React.ReactElement => {
open={status.state != 'healthy'}
onClose={handleOnClose}
maxWidth="sm"
- fullWidth={true}>
-
+ fullWidth={true}
+ >
-
+
-
+
+
+
-
-
)
-};
-export default ClientHealthSentinel;
\ No newline at end of file
+}
+export default ClientHealthSentinel
diff --git a/packages/webapp/src/classes/client/index.ts b/packages/webapp/src/classes/client/index.ts
index 50c0069b..4633e3fd 100644
--- a/packages/webapp/src/classes/client/index.ts
+++ b/packages/webapp/src/classes/client/index.ts
@@ -1,109 +1,108 @@
-import { Locale, LocaleCode } from "../app-i18n"
+import { Locale, LocaleCode } from '../app-i18n'
export type NewUser = {
- email: string;
- firstname: string;
- lastname: string;
- password: string;
- recaptcha: string | null;
+ email: string
+ firstname: string
+ lastname: string
+ password: string
+ recaptcha: string | null
}
export type ImportMapInfo = {
- title: string;
- description?: string;
- contentType?: string;
- content?: ArrayBuffer | null | string;
+ title: string
+ description?: string
+ contentType?: string
+ content?: ArrayBuffer | null | string
}
export type Label = {
- id: number;
- title: string;
- color: string;
- iconName: string;
+ id: number
+ title: string
+ color: string
+ iconName: string
}
-export type Role = 'owner' | 'editor' | 'viewer';
+export type Role = 'owner' | 'editor' | 'viewer'
export type MapInfo = {
- id: number;
- starred: boolean;
- title: string;
- labels: number[];
- createdBy: string;
- creationTime: string;
- lastModificationBy: string;
- lastModificationTime: string;
- description: string;
- isPublic: boolean;
- role: Role;
+ id: number
+ starred: boolean
+ title: string
+ labels: number[]
+ createdBy: string
+ creationTime: string
+ lastModificationBy: string
+ lastModificationTime: string
+ description: string
+ isPublic: boolean
+ role: Role
}
export type ChangeHistory = {
- id: number;
- lastModificationBy: string;
- lastModificationTime: string;
+ id: number
+ lastModificationBy: string
+ lastModificationTime: string
}
export type BasicMapInfo = {
- title: string;
- description?: string;
+ title: string
+ description?: string
}
export type FieldError = {
- id: string,
+ id: string
msg: string
}
export type ErrorInfo = {
- msg?: string;
- fields?: Map;
+ msg?: string
+ fields?: Map
}
export type AccountInfo = {
- firstname: string;
- lastname: string;
- email: string;
- locale: Locale;
+ firstname: string
+ lastname: string
+ email: string
+ locale: Locale
}
export type Permission = {
- name?: string;
- email: string;
- role: Role;
+ name?: string
+ email: string
+ role: Role
}
interface Client {
deleteAccount(): Promise
importMap(model: ImportMapInfo): Promise
- createMap(map: BasicMapInfo): Promise;
- deleteMaps(ids: number[]): Promise;
- deleteMap(id: number): Promise;
- renameMap(id: number, basicInfo: BasicMapInfo): Promise;
- fetchAllMaps(): Promise;
+ createMap(map: BasicMapInfo): Promise
+ deleteMaps(ids: number[]): Promise
+ deleteMap(id: number): Promise
+ renameMap(id: number, basicInfo: BasicMapInfo): Promise
+ fetchAllMaps(): Promise
- fetchMapPermissions(id: number): Promise;
- addMapPermissions(id: number, message: string, permissions: Permission[]): Promise;
- deleteMapPermission(id: number, email: string): Promise;
+ fetchMapPermissions(id: number): Promise
+ addMapPermissions(id: number, message: string, permissions: Permission[]): Promise
+ deleteMapPermission(id: number, email: string): Promise
- duplicateMap(id: number, basicInfo: BasicMapInfo): Promise;
+ duplicateMap(id: number, basicInfo: BasicMapInfo): Promise
- updateAccountLanguage(locale: LocaleCode): Promise;
- updateAccountPassword(pasword: string): Promise;
- updateAccountInfo(firstname: string, lastname: string): Promise;
+ updateAccountLanguage(locale: LocaleCode): Promise
+ updateAccountPassword(pasword: string): Promise
+ updateAccountInfo(firstname: string, lastname: string): Promise
- updateStarred(id: number, starred: boolean): Promise;
- updateMapToPublic(id: number, starred: boolean): Promise;
+ updateStarred(id: number, starred: boolean): Promise
+ updateMapToPublic(id: number, starred: boolean): Promise
- fetchLabels(): Promise