Merge pull request #18531 from civicrm/5.30
[civicrm-core.git] / js / model / crm.designer.js
1 (function($, _) {
2 if (!CRM.Designer) CRM.Designer = {};
3
4 // TODO Optimize this class
5 CRM.Designer.PaletteFieldModel = CRM.Backbone.Model.extend({
6 defaults: {
7 /**
8 * @var {string} required; a form-specific binding to an entity instance (eg 'student', 'mother')
9 */
10 entityName: null,
11
12 /**
13 * @var {string}
14 */
15 fieldName: null
16 },
17 initialize: function() {
18 },
19 getFieldSchema: function() {
20 return this.getRel('ufGroupModel').getFieldSchema(this.get('entityName'), this.get('fieldName'));
21 },
22 getLabel: function() {
23 // Note: if fieldSchema were a bit tighter, then we need to get a label from PaletteFieldModel at all
24 return this.getFieldSchema().title || this.get('fieldName');
25 },
26 getSectionName: function() {
27 // Note: if fieldSchema were a bit tighter, then we need to get a section from PaletteFieldModel at all
28 return this.getFieldSchema().section || 'default';
29 },
30 getSection: function() {
31 return this.getRel('ufGroupModel').getModelClass(this.get('entityName')).prototype.sections[this.getSectionName()];
32 },
33 /**
34 * Add a new UFField model to a UFFieldCollection (if doing so is legal).
35 * If it fails, display an alert.
36 *
37 * @param {int} ufGroupId
38 * @param {CRM.UF.UFFieldCollection} ufFieldCollection
39 * @param {Object} addOptions
40 * @return {CRM.UF.UFFieldModel} or null (if the field is not addable)
41 */
42 addToUFCollection: function(ufFieldCollection, addOptions) {
43 var name, paletteFieldModel = this;
44 var ufFieldModel = paletteFieldModel.createUFFieldModel(ufFieldCollection.getRel('ufGroupModel'));
45 ufFieldModel.set('uf_group_id', ufFieldCollection.uf_group_id);
46 if (!ufFieldCollection.isAddable(ufFieldModel)) {
47 CRM.alert(
48 ts('The field "%1" is already included.', {
49 1: paletteFieldModel.getLabel()
50 }),
51 ts('Duplicate'),
52 'alert'
53 );
54 return null;
55 }
56 ufFieldCollection.add(ufFieldModel, addOptions);
57 // Load metadata and set defaults
58 // TODO: currently only works for custom fields
59 name = this.get('fieldName').split('_');
60 if (name[0] === 'custom') {
61 CRM.api('custom_field', 'getsingle', {id: name[1]}, {success: function(field) {
62 ufFieldModel.set(_.pick(field, 'help_pre', 'help_post', 'is_required'));
63 }});
64 }
65 return ufFieldModel;
66 },
67 createUFFieldModel: function(ufGroupModel) {
68 var model = new CRM.UF.UFFieldModel({
69 is_active: 1,
70 label: this.getLabel(),
71 entity_name: this.get('entityName'),
72 field_type: this.getFieldSchema().civiFieldType,
73 field_name: this.get('fieldName')
74 });
75 return model;
76 }
77 });
78
79 /**
80 *
81 * options:
82 * - ufGroupModel: UFGroupModel
83 */
84 CRM.Designer.PaletteFieldCollection = CRM.Backbone.Collection.extend({
85 model: CRM.Designer.PaletteFieldModel,
86 initialize: function(models, options) {
87 this.initializeCopyToChildrenRelation('ufGroupModel', options.ufGroupModel, models);
88 },
89
90 /**
91 * Look up a palette-field
92 *
93 * @param entityName
94 * @param fieldName
95 * @return {CRM.Designer.PaletteFieldModel}
96 */
97 getFieldByName: function(entityName, fieldName) {
98 if (fieldName.indexOf('formatting') === 0) {
99 fieldName = 'formatting';
100 }
101 return this.find(function(paletteFieldModel) {
102 return ((!entityName || paletteFieldModel.get('entityName') == entityName) && paletteFieldModel.get('fieldName') == fieldName);
103 });
104 },
105
106 /**
107 * Get a list of all fields, grouped into sections by "entityName+sectionName".
108 *
109 * @return {Object} keys are sections ("entityName+sectionName"); values are CRM.Designer.PaletteFieldModel
110 */
111 getFieldsByEntitySection: function() {
112 // TODO cache
113 var fieldsByEntitySection = this.groupBy(function(paletteFieldModel) {
114 return paletteFieldModel.get('entityName') + '-' + paletteFieldModel.getSectionName();
115 });
116 return fieldsByEntitySection;
117 }
118 });
119 })(CRM.$, CRM._);