alchemy-form 0.1.11 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +29 -0
- package/assets/stylesheets/form/alchemy_form.scss +2 -16
- package/assets/stylesheets/form/elements/_button.scss +52 -0
- package/assets/stylesheets/form/{alchemy_code_input.scss → elements/_code_input.scss} +1 -1
- package/assets/stylesheets/form/{alchemy_feedback_input.scss → elements/_feedback_input.scss} +6 -8
- package/assets/stylesheets/form/{alchemy_field.scss → elements/_field.scss} +1 -1
- package/assets/stylesheets/form/{alchemy_field_array.scss → elements/_field_array.scss} +2 -2
- package/assets/stylesheets/form/{alchemy_field_translatable.scss → elements/_field_translatable.scss} +1 -1
- package/assets/stylesheets/form/elements/_form.scss +16 -0
- package/assets/stylesheets/form/{alchemy_pager.scss → elements/_pager.scss} +1 -1
- package/assets/stylesheets/form/{query_builder.scss → elements/_query_builder.scss} +7 -7
- package/assets/stylesheets/form/{alchemy_select.scss → elements/_select.scss} +2 -2
- package/assets/stylesheets/form/elements/_state.scss +8 -0
- package/assets/stylesheets/form/{alchemy_table.scss → elements/_table.scss} +2 -2
- package/assets/stylesheets/form/elements/_tabs.scss +47 -0
- package/assets/stylesheets/form/{alchemy_toggle.scss → elements/_toggle.scss} +1 -1
- package/assets/stylesheets/form/elements/index.scss +14 -0
- package/controller/form_api_controller.js +0 -1
- package/element/00_form_base.js +16 -8
- package/element/05_feedback_input.js +4 -13
- package/element/10_alchemy_field_custom.js +13 -15
- package/element/10_dataprovider.js +282 -0
- package/element/15_alchemy_field_entry.js +8 -10
- package/element/20_query_builder_base.js +4 -13
- package/element/25_query_builder_data.js +2 -2
- package/element/30_tab_base.js +29 -0
- package/element/40_stateful.js +125 -0
- package/element/al_button.js +109 -0
- package/element/{code_input.js → al_code_input.js} +1 -10
- package/element/{alchemy_field.js → al_field.js} +82 -41
- package/element/{alchemy_field_array.js → al_field_array.js} +7 -18
- package/element/{alchemy_field_array_entry.js → al_field_array_entry.js} +7 -9
- package/element/{alchemy_field_schema.js → al_field_schema.js} +23 -11
- package/element/{alchemy_field_translatable.js → al_field_translatable.js} +6 -17
- package/element/{alchemy_field_translatable_entry.js → al_field_translatable_entry.js} +2 -4
- package/element/{alchemy_form.js → al_form.js} +7 -16
- package/element/{alchemy_label.js → al_label.js} +1 -10
- package/element/{number_input.js → al_number_input.js} +2 -2
- package/element/{alchemy_pager.js → al_pager.js} +49 -41
- package/element/{alchemy_password_input.js → al_password_input.js} +0 -0
- package/element/{query_builder.js → al_query_builder.js} +3 -12
- package/element/{query_builder_entry.js → al_query_builder_entry.js} +8 -7
- package/element/{query_builder_group.js → al_query_builder_group.js} +7 -7
- package/element/{query_builder_value.js → al_query_builder_value.js} +2 -2
- package/element/{query_builder_variable.js → al_query_builder_variable.js} +1 -1
- package/element/{alchemy_select.js → al_select.js} +35 -108
- package/element/{alchemy_select_item.js → al_select_item.js} +33 -13
- package/element/al_state.js +26 -0
- package/element/{string_input.js → al_string_input.js} +2 -2
- package/element/al_tab_button.js +138 -0
- package/element/al_tab_context.js +102 -0
- package/element/al_tab_list.js +66 -0
- package/element/al_tab_panel.js +44 -0
- package/element/{alchemy_table.js → al_table.js} +204 -185
- package/element/{alchemy_toggle.js → al_toggle.js} +1 -10
- package/helper/form_actions/00_form_action.js +15 -4
- package/helper/form_actions/url_action.js +3 -2
- package/helper/query_builder_ns.js +108 -0
- package/helper/query_builder_variable_definition/00_variable_definition.js +52 -1
- package/helper/query_builder_variable_definition/boolean_variable_definition.js +1 -1
- package/helper_field/query_builder_field.js +49 -28
- package/helper_field/query_builder_value.js +0 -45
- package/helper_field/query_builder_variable.js +0 -45
- package/package.json +2 -2
- package/view/form/elements/alchemy_button.hwk +1 -0
- package/view/form/elements/alchemy_field.hwk +4 -4
- package/view/form/elements/alchemy_field_array.hwk +2 -2
- package/view/form/elements/alchemy_field_schema.hwk +2 -2
- package/view/form/elements/alchemy_field_translatable.hwk +2 -2
- package/view/form/elements/alchemy_field_translatable_entry.hwk +2 -2
- package/view/form/elements/alchemy_select_item.hwk +1 -3
- package/view/form/elements/query_builder.hwk +1 -1
- package/view/form/elements/query_builder_entry.hwk +6 -6
- package/view/form/elements/query_builder_value.hwk +2 -2
- package/view/form/elements/query_builder_variable.hwk +2 -2
- package/view/form/inputs/edit/belongs_to.hwk +2 -2
- package/view/form/inputs/edit/boolean.hwk +2 -2
- package/view/form/inputs/edit/enum.hwk +2 -2
- package/view/form/inputs/edit/has_and_belongs_to_many.hwk +2 -2
- package/view/form/inputs/edit/html.hwk +2 -2
- package/view/form/inputs/edit/query_builder.hwk +2 -2
- package/view/form/inputs/edit/query_builder_assignment.hwk +2 -2
- package/view/form/inputs/edit/query_builder_value.hwk +2 -2
- package/view/form/inputs/edit/query_builder_variable.hwk +2 -2
- package/view/form/inputs/edit/schema.hwk +2 -2
- package/view/form/inputs/edit/sourcecode.hwk +2 -2
- package/view/form/inputs/edit_inline/boolean.hwk +2 -2
- package/view/form/inputs/view/string.hwk +6 -1
- package/view/form/inputs/view_inline/datetime.hwk +8 -4
- package/view/form/inputs/view_inline/enum.hwk +1 -0
- package/view/form/inputs/view_inline/string.hwk +6 -1
- package/view/form/select/qb_item.hwk +1 -0
- package/view/form/wrappers/default/default.hwk +2 -2
- package/helper/widgets/alchemy_field_widget.js +0 -137
- package/helper/widgets/alchemy_form_widget.js +0 -169
- package/helper/widgets/alchemy_table_widget.js +0 -53
- package/view/form/inputs/view_inline/file.hwk +0 -6
|
@@ -1,4 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
{% if alchemy_field.config.options.time_ago %}
|
|
2
|
+
<time-ago date={% value %}></time-ago>
|
|
3
|
+
{% else %}
|
|
4
|
+
<time
|
|
5
|
+
class="alchemy-field-value"
|
|
6
|
+
datetime={% value.toISOString() %}
|
|
7
|
+
>{{ value.format('Y‑m‑d H:i') }}</time>
|
|
8
|
+
{% /if %}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<span class="alchemy-field-value alchemy-field-enum">{{ value }}</span>
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
<div class="form-field-info">
|
|
2
|
-
<
|
|
2
|
+
<al-label>
|
|
3
3
|
<span
|
|
4
4
|
data-he-name="field-title"
|
|
5
5
|
data-he-slot="field-title"
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
data-he-name="field-description"
|
|
9
9
|
data-he-slot="field-description"
|
|
10
10
|
><%= alchemy_field.field_description %></small>
|
|
11
|
-
</
|
|
11
|
+
</al-label>
|
|
12
12
|
</div>
|
|
13
13
|
<div data-he-name="field"></div>
|
|
14
14
|
<div class="validation-feedback">
|
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* The Field Widget class
|
|
3
|
-
*
|
|
4
|
-
* @constructor
|
|
5
|
-
*
|
|
6
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
7
|
-
* @since 0.1.0
|
|
8
|
-
* @version 0.1.0
|
|
9
|
-
*
|
|
10
|
-
* @param {Object} data
|
|
11
|
-
*/
|
|
12
|
-
const AlchemyField = Function.inherits('Alchemy.Widget', 'AlchemyField');
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Prepare the schema
|
|
16
|
-
*
|
|
17
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
18
|
-
* @since 0.1.0
|
|
19
|
-
* @version 0.1.0
|
|
20
|
-
*/
|
|
21
|
-
AlchemyField.constitute(function prepareSchema() {
|
|
22
|
-
|
|
23
|
-
//let widgets = this.createSchema();
|
|
24
|
-
|
|
25
|
-
// widgets.addField('type', 'Enum', {values: alchemy.getClassGroup('widgets')});
|
|
26
|
-
// widgets.addField('config', 'Schema', {schema: 'type'});
|
|
27
|
-
|
|
28
|
-
// this.schema.addField('widgets', widgets, {array: true});
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* Find the alchemy-form parent
|
|
33
|
-
*
|
|
34
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
35
|
-
* @since 0.1.4
|
|
36
|
-
* @version 0.1.4
|
|
37
|
-
*/
|
|
38
|
-
AlchemyField.enforceProperty(function alchemy_form(new_value) {
|
|
39
|
-
|
|
40
|
-
if (!new_value && this.config && this.config.alchemy_form) {
|
|
41
|
-
new_value = this.config.alchemy_form;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
if (!new_value) {
|
|
45
|
-
|
|
46
|
-
let parent = this.parent_instance;
|
|
47
|
-
|
|
48
|
-
while (parent) {
|
|
49
|
-
|
|
50
|
-
new_value = parent.alchemy_form;
|
|
51
|
-
|
|
52
|
-
if (new_value) {
|
|
53
|
-
break;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
if (parent.element) {
|
|
57
|
-
new_value = parent.element.querySelector('alchemy-form');
|
|
58
|
-
|
|
59
|
-
if (new_value) {
|
|
60
|
-
break;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
parent = parent.parent_instance;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
return new_value;
|
|
69
|
-
});
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Populate the widget
|
|
73
|
-
*
|
|
74
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
75
|
-
* @since 0.1.0
|
|
76
|
-
* @version 0.1.11
|
|
77
|
-
*/
|
|
78
|
-
AlchemyField.setMethod(function populateWidget() {
|
|
79
|
-
|
|
80
|
-
let config = this.config;
|
|
81
|
-
|
|
82
|
-
let alchemy_form = this.alchemy_form;
|
|
83
|
-
|
|
84
|
-
let field_el = this.createElement('alchemy-field');
|
|
85
|
-
|
|
86
|
-
if (alchemy_form) {
|
|
87
|
-
field_el.alchemy_form = alchemy_form;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
field_el.field_name = config.field;
|
|
91
|
-
|
|
92
|
-
if (config.purpose) {
|
|
93
|
-
field_el.purpose = config.purpose;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
if (config.mode) {
|
|
97
|
-
field_el.mode = config.mode;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
if (config.view) {
|
|
101
|
-
field_el.field_view = config.view;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
if (config.readonly) {
|
|
105
|
-
field_el.readonly = true;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
if (config.widget_settings) {
|
|
109
|
-
field_el.widget_settings = config.widget_settings;
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
if (config.data_src) {
|
|
113
|
-
field_el.data_src = config.data_src;
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
this.element.append(field_el);
|
|
117
|
-
});
|
|
118
|
-
|
|
119
|
-
/**
|
|
120
|
-
* Get the config of this widget
|
|
121
|
-
*
|
|
122
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
123
|
-
* @since 0.1.0
|
|
124
|
-
* @version 0.1.0
|
|
125
|
-
*
|
|
126
|
-
* @return {Object}
|
|
127
|
-
*/
|
|
128
|
-
AlchemyField.setMethod(function syncConfig() {
|
|
129
|
-
|
|
130
|
-
let config = this.config;
|
|
131
|
-
|
|
132
|
-
if (!config) {
|
|
133
|
-
config = this.config = {};
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
return this.config;
|
|
137
|
-
});
|
|
@@ -1,169 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* The Form Widget class
|
|
3
|
-
*
|
|
4
|
-
* @constructor
|
|
5
|
-
*
|
|
6
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
7
|
-
* @since 0.1.0
|
|
8
|
-
* @version 0.1.0
|
|
9
|
-
*
|
|
10
|
-
* @param {Object} data
|
|
11
|
-
*/
|
|
12
|
-
const AlchemyForm = Function.inherits('Alchemy.Widget', 'AlchemyForm');
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Populate the widget
|
|
16
|
-
*
|
|
17
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
18
|
-
* @since 0.1.0
|
|
19
|
-
* @version 0.1.11
|
|
20
|
-
*/
|
|
21
|
-
AlchemyForm.setMethod(function populateWidget() {
|
|
22
|
-
|
|
23
|
-
let config = this.config,
|
|
24
|
-
form = this.createElement('alchemy-form');
|
|
25
|
-
|
|
26
|
-
let col_el = this.createElement('alchemy-widgets-column'),
|
|
27
|
-
col = col_el.instance;
|
|
28
|
-
|
|
29
|
-
col.parent_instance = this;
|
|
30
|
-
|
|
31
|
-
form.classList.add('alchemy-widgets-container');
|
|
32
|
-
|
|
33
|
-
if (config.purpose) {
|
|
34
|
-
form.purpose = config.purpose;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
if (config.mode) {
|
|
38
|
-
form.mode = config.mode;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
if (this.config && this.config.widgets) {
|
|
42
|
-
let widgets = this.config.widgets.slice(0),
|
|
43
|
-
widget,
|
|
44
|
-
i;
|
|
45
|
-
|
|
46
|
-
for (i = 0; i < widgets.length; i++) {
|
|
47
|
-
widget = widgets[i];
|
|
48
|
-
|
|
49
|
-
if (widget.type == 'alchemy_field') {
|
|
50
|
-
widget = Object.assign({}, widget);
|
|
51
|
-
widget.config = Object.assign({}, widget.config);
|
|
52
|
-
widget.config.alchemy_form = form;
|
|
53
|
-
widgets[i] = widget;
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
col.widget.value = widgets;
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
let record = this.element.getContextVariable('record');
|
|
61
|
-
|
|
62
|
-
if (record) {
|
|
63
|
-
form.document = record;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if (config.model) {
|
|
67
|
-
form.model = config.model;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
if (config.view_type) {
|
|
71
|
-
form.view_type = config.view_type;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
form.append(col.widget);
|
|
75
|
-
|
|
76
|
-
this.element.append(form);
|
|
77
|
-
|
|
78
|
-
let violations = this.element.getContextVariable('form_violations');
|
|
79
|
-
|
|
80
|
-
if (violations) {
|
|
81
|
-
form.showError(violations);
|
|
82
|
-
}
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* Get the nested column
|
|
87
|
-
*
|
|
88
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
89
|
-
* @since 0.1.0
|
|
90
|
-
* @version 0.1.0
|
|
91
|
-
*/
|
|
92
|
-
AlchemyForm.setMethod(function getNestedColumn(widget) {
|
|
93
|
-
|
|
94
|
-
if (!widget) {
|
|
95
|
-
widget = this.widget;
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
if (!widget) {
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
let col = widget.querySelector('alchemy-form > alchemy-widgets-column');
|
|
103
|
-
|
|
104
|
-
return col;
|
|
105
|
-
});
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* Start the editor
|
|
109
|
-
*
|
|
110
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
111
|
-
* @since 0.1.0
|
|
112
|
-
* @version 0.1.0
|
|
113
|
-
*/
|
|
114
|
-
AlchemyForm.setMethod(function _startEditor() {
|
|
115
|
-
|
|
116
|
-
let col = this.getNestedColumn();
|
|
117
|
-
|
|
118
|
-
if (!col) {
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
col.startEditor();
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
/**
|
|
126
|
-
* Stop the editor
|
|
127
|
-
*
|
|
128
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
129
|
-
* @since 0.1.0
|
|
130
|
-
* @version 0.1.0
|
|
131
|
-
*/
|
|
132
|
-
AlchemyForm.setMethod(function _stopEditor() {
|
|
133
|
-
|
|
134
|
-
let col = this.getNestedColumn();
|
|
135
|
-
|
|
136
|
-
if (!col) {
|
|
137
|
-
return;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
col.stopEditor();
|
|
141
|
-
});
|
|
142
|
-
|
|
143
|
-
/**
|
|
144
|
-
* Get the config of this widget
|
|
145
|
-
*
|
|
146
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
147
|
-
* @since 0.1.0
|
|
148
|
-
* @version 0.1.0
|
|
149
|
-
*
|
|
150
|
-
* @return {Object}
|
|
151
|
-
*/
|
|
152
|
-
AlchemyForm.setMethod(function syncConfig() {
|
|
153
|
-
|
|
154
|
-
let config = this.config;
|
|
155
|
-
|
|
156
|
-
if (!config) {
|
|
157
|
-
config = this.config = {};
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
let col = this.getNestedColumn();
|
|
161
|
-
|
|
162
|
-
if (col) {
|
|
163
|
-
config.widgets = col.instance.syncConfig();
|
|
164
|
-
} else {
|
|
165
|
-
config.widgets = [];
|
|
166
|
-
}
|
|
167
|
-
|
|
168
|
-
return this.config;
|
|
169
|
-
});
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* The Table Widget class
|
|
3
|
-
*
|
|
4
|
-
* @constructor
|
|
5
|
-
*
|
|
6
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
7
|
-
* @since 0.1.0
|
|
8
|
-
* @version 0.1.0
|
|
9
|
-
*
|
|
10
|
-
* @param {Object} data
|
|
11
|
-
*/
|
|
12
|
-
const AlchemyTable = Function.inherits('Alchemy.Widget', 'AlchemyTable');
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Populate the widget
|
|
16
|
-
*
|
|
17
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
18
|
-
* @since 0.1.0
|
|
19
|
-
* @version 0.1.8
|
|
20
|
-
*/
|
|
21
|
-
AlchemyTable.setMethod(function populateWidget() {
|
|
22
|
-
|
|
23
|
-
let table = this.createElement('alchemy-table'),
|
|
24
|
-
config = this.config;
|
|
25
|
-
|
|
26
|
-
if (config.id) {
|
|
27
|
-
table.id = config.id;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
// Always enable the actions?
|
|
31
|
-
table.has_actions = true;
|
|
32
|
-
|
|
33
|
-
if (config.fieldset) {
|
|
34
|
-
table.fieldset = config.fieldset;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
if (config.page_size) {
|
|
38
|
-
table.page_size = config.page_size;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
if (config.show_filters) {
|
|
42
|
-
table.show_filters = config.show_filters;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
if (config.recordsource) {
|
|
46
|
-
table.recordsource = config.recordsource;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
table.purpose = config.purpose || 'view';
|
|
50
|
-
table.mode = config.mode || 'inline';
|
|
51
|
-
|
|
52
|
-
this.element.append(table);
|
|
53
|
-
});
|