2014-11-23 23:41:20 +00:00
|
|
|
/*global define,Promise*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Module defining CreateAction. Created by vwoeltje on 11/10/14.
|
|
|
|
*/
|
|
|
|
define(
|
|
|
|
['./CreateWizard'],
|
|
|
|
function (CreateWizard) {
|
|
|
|
"use strict";
|
|
|
|
|
|
|
|
/**
|
2014-11-24 02:03:48 +00:00
|
|
|
* The Create Action is performed to create new instances of
|
|
|
|
* domain objects of a specific type. This is the action that
|
|
|
|
* is performed when a user uses the Create menu.
|
2014-11-23 23:41:20 +00:00
|
|
|
*
|
|
|
|
* @constructor
|
2014-11-24 02:03:48 +00:00
|
|
|
* @param {Type} type the type of domain object to create
|
|
|
|
* @param {DomainObject} parent the domain object that should
|
|
|
|
* act as a container for the newly-created object
|
|
|
|
* (note that the user will have an opportunity to
|
|
|
|
* override this)
|
|
|
|
* @param {ActionContext} context the context in which the
|
|
|
|
* action is being performed
|
|
|
|
* @param {DialogService} dialogService the dialog service
|
|
|
|
* to use when requesting user input
|
|
|
|
* @param {CreationService} creationService the creation service,
|
|
|
|
* which handles the actual instantiation and persistence
|
|
|
|
* of the newly-created domain object
|
2014-11-23 23:41:20 +00:00
|
|
|
*/
|
|
|
|
function CreateAction(type, parent, context, dialogService, creationService) {
|
|
|
|
/*
|
2014-11-24 02:03:48 +00:00
|
|
|
Overview of steps in object creation:
|
2014-11-23 23:41:20 +00:00
|
|
|
|
|
|
|
1. Show dialog
|
|
|
|
a. Prepare dialog contents
|
|
|
|
b. Invoke dialogService
|
|
|
|
2. Create new object in persistence service
|
|
|
|
a. Generate UUID
|
|
|
|
b. Store model
|
|
|
|
3. Mutate destination container
|
|
|
|
a. Get mutation capability
|
|
|
|
b. Add new id to composition
|
|
|
|
4. Persist destination container
|
|
|
|
a. ...use persistence capability.
|
|
|
|
*/
|
|
|
|
|
|
|
|
function perform() {
|
2014-11-24 02:03:48 +00:00
|
|
|
// The wizard will handle creating the form model based
|
|
|
|
// on the type...
|
2014-11-23 23:41:20 +00:00
|
|
|
var wizard = new CreateWizard(type, parent);
|
|
|
|
|
2014-11-24 02:03:48 +00:00
|
|
|
// Create and persist the new object, based on user
|
|
|
|
// input.
|
2014-11-23 23:41:20 +00:00
|
|
|
function persistResult(formValue) {
|
|
|
|
var parent = wizard.getLocation(formValue),
|
|
|
|
newModel = wizard.createModel(formValue);
|
|
|
|
return creationService.createObject(newModel, parent);
|
|
|
|
}
|
|
|
|
|
|
|
|
function doNothing() {
|
|
|
|
// Create cancelled, do nothing
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return dialogService.getUserInput(
|
2014-12-04 01:00:22 +00:00
|
|
|
wizard.getFormStructure(),
|
2014-12-03 20:52:51 +00:00
|
|
|
wizard.getInitialFormValue()
|
2014-11-23 23:41:20 +00:00
|
|
|
).then(persistResult, doNothing);
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
2014-11-24 02:03:48 +00:00
|
|
|
/**
|
|
|
|
* Create a new object of the given type.
|
|
|
|
* This will prompt for user input first.
|
|
|
|
* @method
|
|
|
|
* @memberof CreateAction
|
|
|
|
*/
|
2014-11-23 23:41:20 +00:00
|
|
|
perform: perform,
|
2014-11-24 02:03:48 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get metadata about this action. This includes fields:
|
|
|
|
* * `name`: Human-readable name
|
|
|
|
* * `key`: Machine-readable identifier ("create")
|
|
|
|
* * `glyph`: Glyph to use as an icon for this action
|
|
|
|
* * `description`: Human-readable description
|
|
|
|
* * `context`: The context in which this action will be performed.
|
|
|
|
*
|
|
|
|
* @return {object} metadata about the create action
|
|
|
|
*/
|
2014-11-23 23:41:20 +00:00
|
|
|
getMetadata: function () {
|
|
|
|
return {
|
|
|
|
key: 'create',
|
|
|
|
glyph: type.getGlyph(),
|
|
|
|
name: type.getName(),
|
2015-03-18 01:00:25 +00:00
|
|
|
type: type.getKey(),
|
2014-11-23 23:41:20 +00:00
|
|
|
description: type.getDescription(),
|
|
|
|
context: context
|
|
|
|
};
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return CreateAction;
|
|
|
|
}
|
|
|
|
);
|