mirror of
https://bitbucket.org/wisemapping/wisemapping-frontend.git
synced 2024-11-25 15:47:55 +01:00
Fix save changes before leaving the window
This commit is contained in:
parent
defc7cd140
commit
09f04190d8
@ -3,7 +3,7 @@ services:
|
|||||||
e2e:
|
e2e:
|
||||||
image: cypress/included:8.4.1
|
image: cypress/included:8.4.1
|
||||||
container_name: wisemapping-integration-tests
|
container_name: wisemapping-integration-tests
|
||||||
entrypoint: '/bin/sh -c "yarn bootstrap && yarn build && yarn test:integration"'
|
entrypoint: '/bin/sh -c "yarn install && yarn bootstrap && yarn build && yarn test:integration"'
|
||||||
working_dir: /e2e
|
working_dir: /e2e
|
||||||
environment:
|
environment:
|
||||||
- CYPRESS_imageSnaphots=true
|
- CYPRESS_imageSnaphots=true
|
||||||
|
@ -53,7 +53,7 @@ export function buildDesigner(options: DesignerOptions): Designer {
|
|||||||
|
|
||||||
// Register toolbar event ...
|
// Register toolbar event ...
|
||||||
if ($('#toolbar').length) {
|
if ($('#toolbar').length) {
|
||||||
const menu = new Menu(designer, 'toolbar', options.mapId ? options.mapId : 'unknown');
|
const menu = new Menu(designer, 'toolbar');
|
||||||
|
|
||||||
// If a node has focus, focus can be move to another node using the keys.
|
// If a node has focus, focus can be move to another node using the keys.
|
||||||
designer.cleanScreen = () => {
|
designer.cleanScreen = () => {
|
||||||
|
@ -20,16 +20,22 @@ import { $msg } from '../Messages';
|
|||||||
import PersistenceManager from '../PersistenceManager';
|
import PersistenceManager from '../PersistenceManager';
|
||||||
import { $notify } from './ToolbarNotifier';
|
import { $notify } from './ToolbarNotifier';
|
||||||
import { $notifyModal } from './ModalDialogNotifier';
|
import { $notifyModal } from './ModalDialogNotifier';
|
||||||
|
import Designer from '../Designer';
|
||||||
|
import ToolbarItem from './ToolbarItem';
|
||||||
|
|
||||||
class IMenu {
|
class IMenu {
|
||||||
constructor(designer, containerId, mapId) {
|
private _designer: Designer;
|
||||||
|
|
||||||
|
protected _toolbarElems: ToolbarItem[];
|
||||||
|
|
||||||
|
private _mindmapUpdated: boolean;
|
||||||
|
|
||||||
|
constructor(designer: Designer, containerId: string) {
|
||||||
$assert(designer, 'designer can not be null');
|
$assert(designer, 'designer can not be null');
|
||||||
$assert(containerId, 'containerId can not be null');
|
$assert(containerId, 'containerId can not be null');
|
||||||
|
|
||||||
this._designer = designer;
|
this._designer = designer;
|
||||||
this._toolbarElems = [];
|
this._toolbarElems = [];
|
||||||
this._containerId = containerId;
|
|
||||||
this._mapId = mapId;
|
|
||||||
this._mindmapUpdated = false;
|
this._mindmapUpdated = false;
|
||||||
const me = this;
|
const me = this;
|
||||||
|
|
||||||
@ -45,7 +51,7 @@ class IMenu {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
discardChanges(designer) {
|
discardChanges(designer: Designer) {
|
||||||
// Avoid autosave before leaving the page ....
|
// Avoid autosave before leaving the page ....
|
||||||
this.setRequireChange(false);
|
this.setRequireChange(false);
|
||||||
|
|
||||||
@ -61,13 +67,13 @@ class IMenu {
|
|||||||
window.location.reload();
|
window.location.reload();
|
||||||
}
|
}
|
||||||
|
|
||||||
unlockMap(designer) {
|
unlockMap(designer: Designer) {
|
||||||
const mindmap = designer.getMindmap();
|
const mindmap = designer.getMindmap();
|
||||||
const persistenceManager = PersistenceManager.getInstance();
|
const persistenceManager = PersistenceManager.getInstance();
|
||||||
persistenceManager.unlockMap(mindmap);
|
persistenceManager.unlockMap(mindmap);
|
||||||
}
|
}
|
||||||
|
|
||||||
save(saveElem, designer, saveHistory, sync) {
|
save(saveElem: JQuery, designer: Designer, saveHistory: boolean, sync?: boolean) {
|
||||||
// Load map content ...
|
// Load map content ...
|
||||||
const mindmap = designer.getMindmap();
|
const mindmap = designer.getMindmap();
|
||||||
const mindmapProp = designer.getMindmapProperties();
|
const mindmapProp = designer.getMindmapProperties();
|
||||||
@ -103,11 +109,11 @@ class IMenu {
|
|||||||
}, sync);
|
}, sync);
|
||||||
}
|
}
|
||||||
|
|
||||||
isSaveRequired() {
|
isSaveRequired(): boolean {
|
||||||
return this._mindmapUpdated;
|
return this._mindmapUpdated;
|
||||||
}
|
}
|
||||||
|
|
||||||
setRequireChange(value) {
|
setRequireChange(value: boolean) {
|
||||||
this._mindmapUpdated = value;
|
this._mindmapUpdated = value;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -31,8 +31,8 @@ import AccountSettingsPanel from './AccountSettingsPanel';
|
|||||||
import Designer from '../Designer';
|
import Designer from '../Designer';
|
||||||
|
|
||||||
class Menu extends IMenu {
|
class Menu extends IMenu {
|
||||||
constructor(designer: Designer, containerId: string, mapId: string, readOnly = false, baseUrl = '') {
|
constructor(designer: Designer, containerId: string, readOnly = false, baseUrl = '') {
|
||||||
super(designer, containerId, mapId);
|
super(designer, containerId);
|
||||||
const saveElem = $('#save');
|
const saveElem = $('#save');
|
||||||
|
|
||||||
const widgetsBaseUrl = `${baseUrl}css/widget`;
|
const widgetsBaseUrl = `${baseUrl}css/widget`;
|
||||||
@ -106,7 +106,7 @@ class Menu extends IMenu {
|
|||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
},
|
},
|
||||||
setValue(value:string) {
|
setValue(value: string) {
|
||||||
designer.changeTopicShape(value);
|
designer.changeTopicShape(value);
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -146,7 +146,7 @@ class Menu extends IMenu {
|
|||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
},
|
},
|
||||||
setValue(hex:string) {
|
setValue(hex: string) {
|
||||||
designer.changeBackgroundColor(hex);
|
designer.changeBackgroundColor(hex);
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -171,7 +171,7 @@ class Menu extends IMenu {
|
|||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
},
|
},
|
||||||
setValue(hex) {
|
setValue(hex: string) {
|
||||||
designer.changeBorderColor(hex);
|
designer.changeBorderColor(hex);
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -297,9 +297,7 @@ class Menu extends IMenu {
|
|||||||
Menu._registerTooltip('save', $msg('SAVE'), 'meta+S');
|
Menu._registerTooltip('save', $msg('SAVE'), 'meta+S');
|
||||||
|
|
||||||
if (!readOnly) {
|
if (!readOnly) {
|
||||||
// To prevent the user from leaving the page with changes ...
|
$(window).bind('beforeunload', () => {
|
||||||
// Element.NativeEvents.unload = 1;
|
|
||||||
$(window).bind('unload', () => {
|
|
||||||
if (this.isSaveRequired()) {
|
if (this.isSaveRequired()) {
|
||||||
this.save(saveElem, designer, false, true);
|
this.save(saveElem, designer, false, true);
|
||||||
}
|
}
|
||||||
@ -374,7 +372,7 @@ class Menu extends IMenu {
|
|||||||
this._registerEvents(designer);
|
this._registerEvents(designer);
|
||||||
}
|
}
|
||||||
|
|
||||||
private _registerEvents(designer:Designer) {
|
private _registerEvents(designer: Designer) {
|
||||||
// Register on close events ...
|
// Register on close events ...
|
||||||
this._toolbarElems.forEach((panel) => {
|
this._toolbarElems.forEach((panel) => {
|
||||||
panel.addEvent('show', () => {
|
panel.addEvent('show', () => {
|
||||||
@ -421,7 +419,7 @@ class Menu extends IMenu {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
private _addButton(buttonId:string, isTopic:boolean, isRelationship:boolean, fn) {
|
private _addButton(buttonId: string, isTopic: boolean, isRelationship: boolean, fn) {
|
||||||
// Register Events ...
|
// Register Events ...
|
||||||
let result = null;
|
let result = null;
|
||||||
if ($(`#${buttonId}`)) {
|
if ($(`#${buttonId}`)) {
|
||||||
@ -436,7 +434,7 @@ class Menu extends IMenu {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
static _registerTooltip(buttonId: string, text: string, shortcut: string = null) {
|
private static _registerTooltip(buttonId: string, text: string, shortcut: string = null) {
|
||||||
if ($(`#${buttonId}`)) {
|
if ($(`#${buttonId}`)) {
|
||||||
let tooltip = text;
|
let tooltip = text;
|
||||||
if (shortcut) {
|
if (shortcut) {
|
||||||
|
Loading…
Reference in New Issue
Block a user