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
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
const QueryBuilder = Fn.getNamespace('Alchemy.QueryBuilder');
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Apply query builder settings to a criteria
|
|
5
|
+
*
|
|
6
|
+
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
7
|
+
* @since 0.1.12
|
|
8
|
+
* @version 0.1.12
|
|
9
|
+
*
|
|
10
|
+
* @param {Object} conditions
|
|
11
|
+
* @param {Criteria} criteria
|
|
12
|
+
* @param {Boolean} inverted
|
|
13
|
+
*/
|
|
14
|
+
QueryBuilder.applyToCriteria = function applyToCriteria(conditions, criteria, inverted) {
|
|
15
|
+
|
|
16
|
+
if (!conditions || !conditions.rules?.length) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
let group;
|
|
21
|
+
|
|
22
|
+
if (conditions.condition == 'or') {
|
|
23
|
+
group = criteria.or();
|
|
24
|
+
} else {
|
|
25
|
+
group = criteria.and();
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
if (inverted == null) {
|
|
29
|
+
inverted = false;
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
if (conditions.inverted) {
|
|
33
|
+
inverted = !inverted;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
for (let rule of conditions.rules) {
|
|
37
|
+
applyRule(rule, criteria, inverted);
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Apply a single rule to a criteria
|
|
43
|
+
*
|
|
44
|
+
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
45
|
+
* @since 0.1.12
|
|
46
|
+
* @version 0.1.12
|
|
47
|
+
*
|
|
48
|
+
* @param {Object} rule
|
|
49
|
+
* @param {Criteria} criteria
|
|
50
|
+
* @param {Boolean} inverted
|
|
51
|
+
*/
|
|
52
|
+
function applyRule(rule, criteria, inverted) {
|
|
53
|
+
|
|
54
|
+
if (rule.type == 'group') {
|
|
55
|
+
return QueryBuilder.applyToCriteria(rule, criteria, inverted);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
if (rule.type != 'qb_entry') {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// Referencing other fields is not supported
|
|
63
|
+
if (rule.value_variable) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
let context = criteria.where(rule.field);
|
|
68
|
+
|
|
69
|
+
if (inverted) {
|
|
70
|
+
context = context.not();
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
if (rule.operator == 'is_empty') {
|
|
74
|
+
context.isEmpty();
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
if (rule.operator == 'is_null') {
|
|
79
|
+
context.isNull();
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
let value = rule.value_explicit.value;
|
|
84
|
+
|
|
85
|
+
let method;
|
|
86
|
+
|
|
87
|
+
switch (rule.operator) {
|
|
88
|
+
case 'ne':
|
|
89
|
+
case 'not_equals':
|
|
90
|
+
method = 'ne';
|
|
91
|
+
break;
|
|
92
|
+
|
|
93
|
+
case 'starts_with':
|
|
94
|
+
value = RegExp.interpret('^' + value);
|
|
95
|
+
method = 'equals';
|
|
96
|
+
break;
|
|
97
|
+
|
|
98
|
+
case 'ends_with':
|
|
99
|
+
value = RegExp.interpret(value + '$');
|
|
100
|
+
method = 'equals';
|
|
101
|
+
break;
|
|
102
|
+
|
|
103
|
+
default:
|
|
104
|
+
method = rule.operator;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
context[method](value);
|
|
108
|
+
}
|
|
@@ -102,12 +102,48 @@ VariableDefinition.constitute(function prepareOperators() {
|
|
|
102
102
|
this.assignment_operators = {};
|
|
103
103
|
});
|
|
104
104
|
|
|
105
|
+
/**
|
|
106
|
+
* Get a list of definitions from the input
|
|
107
|
+
*
|
|
108
|
+
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
109
|
+
* @since 0.1.12
|
|
110
|
+
* @version 0.1.12
|
|
111
|
+
*
|
|
112
|
+
* @param {*} input
|
|
113
|
+
*
|
|
114
|
+
* @return {VariableDefinition[]}
|
|
115
|
+
*/
|
|
116
|
+
VariableDefinition.setStatic(function fromMany(input) {
|
|
117
|
+
|
|
118
|
+
let result = [];
|
|
119
|
+
|
|
120
|
+
if (input) {
|
|
121
|
+
|
|
122
|
+
let schema = input.schema;
|
|
123
|
+
|
|
124
|
+
if (schema && schema instanceof Classes.Alchemy.Schema) {
|
|
125
|
+
|
|
126
|
+
for (let entry of schema) {
|
|
127
|
+
|
|
128
|
+
let instance = VariableDefinition.cast(entry);
|
|
129
|
+
|
|
130
|
+
if (instance) {
|
|
131
|
+
result.push(instance);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
return result;
|
|
139
|
+
});
|
|
140
|
+
|
|
105
141
|
/**
|
|
106
142
|
* Create the correct variable definition
|
|
107
143
|
*
|
|
108
144
|
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
109
145
|
* @since 0.1.6
|
|
110
|
-
* @version 0.1.
|
|
146
|
+
* @version 0.1.12
|
|
111
147
|
*/
|
|
112
148
|
VariableDefinition.setStatic(function cast(entry) {
|
|
113
149
|
|
|
@@ -119,6 +155,21 @@ VariableDefinition.setStatic(function cast(entry) {
|
|
|
119
155
|
return entry;
|
|
120
156
|
}
|
|
121
157
|
|
|
158
|
+
if (entry instanceof Classes.Alchemy.Field) {
|
|
159
|
+
let field = entry;
|
|
160
|
+
|
|
161
|
+
entry = {
|
|
162
|
+
name : field.name,
|
|
163
|
+
title : field.title,
|
|
164
|
+
description : field.options.description,
|
|
165
|
+
type : field.constructor.type_name,
|
|
166
|
+
};
|
|
167
|
+
|
|
168
|
+
if (!VariableDefinition.getMember(entry.type)) {
|
|
169
|
+
entry.type = 'string';
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
|
|
122
173
|
if (!entry.type) {
|
|
123
174
|
return null;
|
|
124
175
|
}
|
|
@@ -19,6 +19,6 @@ const BooleanDefinition = Function.inherits('Alchemy.QueryBuilder.VariableDefini
|
|
|
19
19
|
* @param {Hawkejs.Renderer}
|
|
20
20
|
*/
|
|
21
21
|
BooleanDefinition.setMethod(function createValueInput(renderer) {
|
|
22
|
-
let toggle = renderer.createElement('
|
|
22
|
+
let toggle = renderer.createElement('al-toggle');
|
|
23
23
|
return toggle;
|
|
24
24
|
});
|
|
@@ -50,42 +50,63 @@ QueryBuilderField.setMethod(function cast(value, to_datasource) {
|
|
|
50
50
|
*
|
|
51
51
|
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
52
52
|
* @since 0.1.6
|
|
53
|
-
* @version 0.
|
|
53
|
+
* @version 0.2.0
|
|
54
54
|
*
|
|
55
55
|
* @param {Object} config
|
|
56
56
|
* @param {HTMLElement} element
|
|
57
57
|
*/
|
|
58
58
|
QueryBuilderField.setMethod(function loadData(config, element) {
|
|
59
59
|
|
|
60
|
+
const options = this.options || {},
|
|
61
|
+
source_type = options.variable_data || 'document',
|
|
62
|
+
add_form_value = options.add_form_value || false;
|
|
63
|
+
|
|
64
|
+
let api_route,
|
|
65
|
+
form;
|
|
66
|
+
|
|
67
|
+
let body = {
|
|
68
|
+
source_type,
|
|
69
|
+
config,
|
|
70
|
+
};
|
|
71
|
+
|
|
60
72
|
if (element) {
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
if (form) {
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
if (doc && doc.root_document) {
|
|
67
|
-
doc = doc.root_document;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
let model_name,
|
|
71
|
-
$pk;
|
|
72
|
-
|
|
73
|
-
if (doc) {
|
|
74
|
-
model_name = doc.$model_name;
|
|
75
|
-
$pk = doc.$pk;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
return element.hawkejs_helpers.Alchemy.getResource({
|
|
79
|
-
name : 'FormApi#queryBuilderData',
|
|
80
|
-
post : true,
|
|
81
|
-
body : {
|
|
82
|
-
model : model_name,
|
|
83
|
-
$pk : $pk,
|
|
84
|
-
config : config,
|
|
85
|
-
}
|
|
86
|
-
});
|
|
73
|
+
form = element.queryParents('al-form');
|
|
74
|
+
|
|
75
|
+
if (add_form_value && form) {
|
|
76
|
+
body.form_value = form.value;
|
|
87
77
|
}
|
|
88
78
|
}
|
|
89
79
|
|
|
90
|
-
|
|
80
|
+
// Use the current document data to get the variable data
|
|
81
|
+
if (form && source_type == 'document') {
|
|
82
|
+
|
|
83
|
+
let doc = form.document;
|
|
84
|
+
|
|
85
|
+
if (doc && doc.root_document) {
|
|
86
|
+
doc = doc.root_document;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
let model_name,
|
|
90
|
+
$pk;
|
|
91
|
+
|
|
92
|
+
if (doc) {
|
|
93
|
+
model_name = doc.$model_name;
|
|
94
|
+
$pk = doc.$pk;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
body.model = model_name;
|
|
98
|
+
body.$pk = $pk;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
if (options.route) {
|
|
102
|
+
api_route = options.route;
|
|
103
|
+
} else {
|
|
104
|
+
api_route = 'FormApi#queryBuilderData';
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
return element.hawkejs_helpers.Alchemy.getResource({
|
|
108
|
+
name : api_route,
|
|
109
|
+
post : true,
|
|
110
|
+
body,
|
|
111
|
+
});
|
|
91
112
|
});
|
|
@@ -9,48 +9,3 @@
|
|
|
9
9
|
* @version 0.1.6
|
|
10
10
|
*/
|
|
11
11
|
const QueryBuilderValue = Function.inherits('Alchemy.Field.QueryBuilder', 'QueryBuilderValue');
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Load remote data
|
|
15
|
-
*
|
|
16
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
17
|
-
* @since 0.1.6
|
|
18
|
-
* @version 0.1.6
|
|
19
|
-
*
|
|
20
|
-
* @param {Object} config
|
|
21
|
-
* @param {HTMLElement} element
|
|
22
|
-
*/
|
|
23
|
-
QueryBuilderValue.setMethod(function loadData(config, element) {
|
|
24
|
-
|
|
25
|
-
if (element) {
|
|
26
|
-
let form = element.queryParents('alchemy-form');
|
|
27
|
-
|
|
28
|
-
if (form) {
|
|
29
|
-
let doc = form.document;
|
|
30
|
-
|
|
31
|
-
if (doc && doc.root_document) {
|
|
32
|
-
doc = doc.root_document;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
let model_name,
|
|
36
|
-
$pk;
|
|
37
|
-
|
|
38
|
-
if (doc) {
|
|
39
|
-
model_name = doc.$model_name;
|
|
40
|
-
$pk = doc.$pk;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
return element.hawkejs_helpers.Alchemy.getResource({
|
|
44
|
-
name : 'FormApi#queryBuilderData',
|
|
45
|
-
post : true,
|
|
46
|
-
body : {
|
|
47
|
-
model : model_name,
|
|
48
|
-
$pk : $pk,
|
|
49
|
-
config : config,
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
return [];
|
|
56
|
-
});
|
|
@@ -9,48 +9,3 @@
|
|
|
9
9
|
* @version 0.1.6
|
|
10
10
|
*/
|
|
11
11
|
const QueryBuilderVariable = Function.inherits('Alchemy.Field.QueryBuilder', 'QueryBuilderVariable');
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* Load remote data
|
|
15
|
-
*
|
|
16
|
-
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
17
|
-
* @since 0.1.6
|
|
18
|
-
* @version 0.1.6
|
|
19
|
-
*
|
|
20
|
-
* @param {Object} config
|
|
21
|
-
* @param {HTMLElement} element
|
|
22
|
-
*/
|
|
23
|
-
QueryBuilderVariable.setMethod(function loadData(config, element) {
|
|
24
|
-
|
|
25
|
-
if (element) {
|
|
26
|
-
let form = element.queryParents('alchemy-form');
|
|
27
|
-
|
|
28
|
-
if (form) {
|
|
29
|
-
let doc = form.document;
|
|
30
|
-
|
|
31
|
-
if (doc && doc.root_document) {
|
|
32
|
-
doc = doc.root_document;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
let model_name,
|
|
36
|
-
$pk;
|
|
37
|
-
|
|
38
|
-
if (doc) {
|
|
39
|
-
model_name = doc.$model_name;
|
|
40
|
-
$pk = doc.$pk;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
return element.hawkejs_helpers.Alchemy.getResource({
|
|
44
|
-
name : 'FormApi#queryBuilderData',
|
|
45
|
-
post : true,
|
|
46
|
-
body : {
|
|
47
|
-
model : model_name,
|
|
48
|
-
$pk : $pk,
|
|
49
|
-
config : config,
|
|
50
|
-
}
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
return [];
|
|
56
|
-
});
|
package/package.json
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "alchemy-form",
|
|
3
3
|
"description": "Form plugin for Alchemy",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.2.0",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type" : "git",
|
|
7
7
|
"url" : "https://github.com/11ways/alchemy-form.git"
|
|
8
8
|
},
|
|
9
9
|
"peerDependencies": {
|
|
10
10
|
"alchemymvc" : ">=1.2.0",
|
|
11
|
-
"alchemy-media" : "~0.
|
|
11
|
+
"alchemy-media" : "~0.7.0"
|
|
12
12
|
},
|
|
13
13
|
"license": "MIT",
|
|
14
14
|
"engines": {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<div class="apb-content"><% Hawkejs.replaceChildren($0, child_nodes) %></div>
|
|
@@ -15,15 +15,15 @@ variables = {
|
|
|
15
15
|
|
|
16
16
|
<% if (wrapper_files) start('field') %>
|
|
17
17
|
<% if (self.is_translatable) { %>
|
|
18
|
-
<
|
|
18
|
+
<al-field-translatable
|
|
19
19
|
#field_context=<% self %>
|
|
20
20
|
#alchemy_field=<% self %>
|
|
21
|
-
></
|
|
21
|
+
></al-field-translatable>
|
|
22
22
|
<% } else if (self.is_array) { %>
|
|
23
|
-
<
|
|
23
|
+
<al-field-array
|
|
24
24
|
#field_context=<% self %>
|
|
25
25
|
#alchemy_field=<% self %>
|
|
26
|
-
></
|
|
26
|
+
></al-field-array>
|
|
27
27
|
<% } else if (view_files && view_files.length) { %>
|
|
28
28
|
<div class="field">
|
|
29
29
|
<% include(view_files, variables); %>
|
|
@@ -9,14 +9,14 @@
|
|
|
9
9
|
<div class="entries">
|
|
10
10
|
{% with values as value %}
|
|
11
11
|
{% each %}
|
|
12
|
-
<
|
|
12
|
+
<al-field-array-entry
|
|
13
13
|
#alchemy_field_array=<% self %>
|
|
14
14
|
#field_context=<% self %>
|
|
15
15
|
#alchemy_field=<% alchemy_field %>
|
|
16
16
|
|
|
17
17
|
#value=<% value %>
|
|
18
18
|
index=<% $index %>
|
|
19
|
-
></
|
|
19
|
+
></al-field-array-entry>
|
|
20
20
|
{% /each %}
|
|
21
21
|
{% /with %}
|
|
22
22
|
</div>
|
|
@@ -21,14 +21,14 @@
|
|
|
21
21
|
<% index = 0 %>
|
|
22
22
|
<% for (prefix in prefixes) { %>
|
|
23
23
|
|
|
24
|
-
<
|
|
24
|
+
<al-field-translatable-entry
|
|
25
25
|
#alchemy_field_translatable=<% self %>
|
|
26
26
|
#field_context=<% self %>
|
|
27
27
|
#alchemy_field=<% alchemy_field %>
|
|
28
28
|
|
|
29
29
|
#value=<% values[prefix] %>
|
|
30
30
|
prefix=<% prefix %>
|
|
31
|
-
><% if (index > 0) $0.hidden = true; %></
|
|
31
|
+
><% if (index > 0) $0.hidden = true; %></al-field-translatable-entry>
|
|
32
32
|
|
|
33
33
|
<% index++ %>
|
|
34
34
|
<% } %>
|
|
@@ -9,10 +9,10 @@
|
|
|
9
9
|
|
|
10
10
|
<div class="field">
|
|
11
11
|
<% if (alchemy_field.is_array) { %>
|
|
12
|
-
<
|
|
12
|
+
<al-field-array
|
|
13
13
|
#field_context=<% self %>
|
|
14
14
|
#alchemy_field=<% alchemy_field %>
|
|
15
|
-
></
|
|
15
|
+
></al-field-array>
|
|
16
16
|
<% } else { %>
|
|
17
17
|
<% include(view_files, variables) %>
|
|
18
18
|
<% } %>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
<
|
|
1
|
+
<al-query-builder-group></al-query-builder-group>
|
|
@@ -1,26 +1,26 @@
|
|
|
1
1
|
<div class="qb-field-wrapper">
|
|
2
|
-
<
|
|
2
|
+
<al-select
|
|
3
3
|
class="qb-field"
|
|
4
4
|
#dataprovider={% self %}
|
|
5
5
|
value-item-template="form/select/qb_item"
|
|
6
6
|
option-item-template="form/select/qb_item"
|
|
7
|
-
></
|
|
7
|
+
></al-select>
|
|
8
8
|
</div>
|
|
9
9
|
<div class="qb-operator-wrapper">
|
|
10
|
-
<
|
|
10
|
+
<al-select
|
|
11
11
|
class="qb-operator"
|
|
12
12
|
#dataprovider={% self %}
|
|
13
13
|
value-item-template="form/select/qb_item"
|
|
14
14
|
option-item-template="form/select/qb_item"
|
|
15
|
-
></
|
|
15
|
+
></al-select>
|
|
16
16
|
</div>
|
|
17
17
|
<div class="qb-value-wrapper">
|
|
18
|
-
<
|
|
18
|
+
<al-select
|
|
19
19
|
class="qb-value-type"
|
|
20
20
|
#dataprovider={% self %}
|
|
21
21
|
value-item-template="form/select/qb_item"
|
|
22
22
|
option-item-template="form/select/qb_item"
|
|
23
|
-
></
|
|
23
|
+
></al-select>
|
|
24
24
|
|
|
25
25
|
<div class="qb-value-input-wrapper">
|
|
26
26
|
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
options = alchemy_field.config.options || {};
|
|
3
3
|
%>
|
|
4
4
|
|
|
5
|
-
<
|
|
5
|
+
<al-query-builder-value
|
|
6
6
|
class="alchemy-field-value"
|
|
7
7
|
#value={% value %}
|
|
8
8
|
#dataprovider={% alchemy_field %}
|
|
9
9
|
variable-types={% options.variable_types %}
|
|
10
10
|
source-types={% options.source_types %}
|
|
11
|
-
></
|
|
11
|
+
></al-query-builder-value>
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
options = alchemy_field.config.options || {};
|
|
3
3
|
%>
|
|
4
4
|
|
|
5
|
-
<
|
|
5
|
+
<al-query-builder-variable
|
|
6
6
|
class="alchemy-field-value"
|
|
7
7
|
#value={% value %}
|
|
8
8
|
#dataprovider={% alchemy_field %}
|
|
9
9
|
variable-types={% options.variable_types %}
|
|
10
|
-
></
|
|
10
|
+
></al-query-builder-variable>
|