alchemy-form 0.1.4 → 0.1.7
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 +23 -0
- package/assets/stylesheets/form/alchemy_field_array.scss +4 -0
- package/assets/stylesheets/form/alchemy_toggle.scss +2 -0
- package/assets/stylesheets/form/query_builder.scss +185 -0
- package/config/routes.js +8 -0
- package/controller/form_api_controller.js +51 -2
- package/element/20_query_builder_base.js +82 -0
- package/element/25_query_builder_data.js +139 -0
- package/element/alchemy_field.js +19 -2
- package/element/alchemy_select.js +40 -2
- package/element/alchemy_select_item.js +42 -1
- package/element/alchemy_table.js +123 -21
- package/element/query_builder.js +90 -0
- package/element/query_builder_entry.js +388 -0
- package/element/query_builder_group.js +248 -0
- package/element/query_builder_value.js +316 -0
- package/element/query_builder_variable.js +103 -0
- package/helper/form_actions/00_form_action.js +328 -0
- package/helper/form_actions/url_action.js +69 -0
- package/helper/query_builder_variable_definition/00_variable_definition.js +371 -0
- package/helper/query_builder_variable_definition/boolean_variable_definition.js +24 -0
- package/helper/query_builder_variable_definition/list_variable_definition.js +38 -0
- package/helper/query_builder_variable_definition/number_variable_definition.js +106 -0
- package/helper/query_builder_variable_definition/string_variable_definition.js +46 -0
- package/helper_field/query_builder_assignment.js +11 -0
- package/helper_field/query_builder_field.js +91 -0
- package/helper_field/query_builder_value.js +56 -0
- package/helper_field/query_builder_variable.js +56 -0
- package/package.json +1 -1
- package/view/form/elements/alchemy_field_array.hwk +3 -1
- package/view/form/elements/alchemy_field_array_entry.hwk +3 -1
- package/view/form/elements/alchemy_select_item.hwk +6 -1
- package/view/form/elements/query_builder.hwk +1 -0
- package/view/form/elements/query_builder_entry.hwk +33 -0
- package/view/form/elements/query_builder_group.hwk +64 -0
- package/view/form/elements/query_builder_value.hwk +10 -0
- package/view/form/elements/query_builder_variable.hwk +6 -0
- package/view/form/inputs/edit/query_builder.hwk +5 -0
- package/view/form/inputs/edit/query_builder_assignment.hwk +6 -0
- package/view/form/inputs/edit/query_builder_value.hwk +11 -0
- package/view/form/inputs/edit/query_builder_variable.hwk +10 -0
- package/view/form/select/qb_item.hwk +7 -0
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A QueryBuilderValue field lets you get variable values
|
|
3
|
+
* using the QueryBuilder logic
|
|
4
|
+
*
|
|
5
|
+
* @constructor
|
|
6
|
+
*
|
|
7
|
+
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
8
|
+
* @since 0.1.6
|
|
9
|
+
* @version 0.1.6
|
|
10
|
+
*/
|
|
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
|
+
});
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* A QueryBuilderVariable field lets you select a specific variable
|
|
3
|
+
* using the QueryBuilder logic
|
|
4
|
+
*
|
|
5
|
+
* @constructor
|
|
6
|
+
*
|
|
7
|
+
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
8
|
+
* @since 0.1.6
|
|
9
|
+
* @version 0.1.6
|
|
10
|
+
*/
|
|
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
|
@@ -2,7 +2,9 @@
|
|
|
2
2
|
<% view_files = alchemy_field.view_files %>
|
|
3
3
|
<% values = self.original_value %>
|
|
4
4
|
|
|
5
|
-
<button class="add-entry">
|
|
5
|
+
<button class="add-entry">
|
|
6
|
+
{%t "add-entry" name=alchemy_field.field_name title=alchemy_field.field_title %}
|
|
7
|
+
</button>
|
|
6
8
|
|
|
7
9
|
<div class="entries">
|
|
8
10
|
{% with values as value %}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<alchemy-query-builder-group></alchemy-query-builder-group>
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
<div class="qb-field-wrapper">
|
|
2
|
+
<alchemy-select
|
|
3
|
+
class="qb-field"
|
|
4
|
+
#dataprovider={% self %}
|
|
5
|
+
value-item-template="form/select/qb_item"
|
|
6
|
+
option-item-template="form/select/qb_item"
|
|
7
|
+
></alchemy-select>
|
|
8
|
+
</div>
|
|
9
|
+
<div class="qb-operator-wrapper">
|
|
10
|
+
<alchemy-select
|
|
11
|
+
class="qb-operator"
|
|
12
|
+
#dataprovider={% self %}
|
|
13
|
+
value-item-template="form/select/qb_item"
|
|
14
|
+
option-item-template="form/select/qb_item"
|
|
15
|
+
></alchemy-select>
|
|
16
|
+
</div>
|
|
17
|
+
<div class="qb-value-wrapper">
|
|
18
|
+
<alchemy-select
|
|
19
|
+
class="qb-value-type"
|
|
20
|
+
#dataprovider={% self %}
|
|
21
|
+
value-item-template="form/select/qb_item"
|
|
22
|
+
option-item-template="form/select/qb_item"
|
|
23
|
+
></alchemy-select>
|
|
24
|
+
|
|
25
|
+
<div class="qb-value-input-wrapper">
|
|
26
|
+
|
|
27
|
+
</div>
|
|
28
|
+
</div>
|
|
29
|
+
<div class="qb-delete-wrapper">
|
|
30
|
+
<button class="qb-delete-entry qb-btn qb-primary">
|
|
31
|
+
Delete
|
|
32
|
+
</button>
|
|
33
|
+
</div>
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
<% radio_name = getId('qb') %>
|
|
2
|
+
<% invert_name = getId('qb') %>
|
|
3
|
+
|
|
4
|
+
<div class="qb-group-header">
|
|
5
|
+
<div class="qb-group-type">
|
|
6
|
+
<input
|
|
7
|
+
id="{% radio_name %}_and"
|
|
8
|
+
type="radio"
|
|
9
|
+
name={% radio_name %}
|
|
10
|
+
value="and"
|
|
11
|
+
>
|
|
12
|
+
<label
|
|
13
|
+
for="{% radio_name %}_and"
|
|
14
|
+
class="qb-btn"
|
|
15
|
+
>
|
|
16
|
+
AND
|
|
17
|
+
</label>
|
|
18
|
+
|
|
19
|
+
<input
|
|
20
|
+
id="{% radio_name %}_or"
|
|
21
|
+
type="radio"
|
|
22
|
+
name={% radio_name %}
|
|
23
|
+
value="or"
|
|
24
|
+
>
|
|
25
|
+
<label
|
|
26
|
+
for="{% radio_name %}_or"
|
|
27
|
+
class="qb-btn"
|
|
28
|
+
>
|
|
29
|
+
OR
|
|
30
|
+
</label>
|
|
31
|
+
</div>
|
|
32
|
+
|
|
33
|
+
<div class="qb-group-invert">
|
|
34
|
+
<input
|
|
35
|
+
id={% invert_name %}
|
|
36
|
+
class="group-invert-chk"
|
|
37
|
+
type="checkbox"
|
|
38
|
+
>
|
|
39
|
+
<label
|
|
40
|
+
for={% invert_name %}
|
|
41
|
+
class="qb-btn"
|
|
42
|
+
>
|
|
43
|
+
NOT
|
|
44
|
+
</label>
|
|
45
|
+
</div>
|
|
46
|
+
|
|
47
|
+
<div class="qb-group-actions">
|
|
48
|
+
<button class="qb-add-rule qb-btn qb-primary">
|
|
49
|
+
Add rule
|
|
50
|
+
</button>
|
|
51
|
+
<button class="qb-add-group qb-btn qb-primary">
|
|
52
|
+
Add group
|
|
53
|
+
</button>
|
|
54
|
+
<button class="qb-delete-group qb-btn qb-primary">
|
|
55
|
+
Delete group
|
|
56
|
+
<% if (self.is_root_group) $0.hidden = true %>
|
|
57
|
+
</button>
|
|
58
|
+
</div>
|
|
59
|
+
</div>
|
|
60
|
+
<div class="qb-group-body">
|
|
61
|
+
<div class="qb-rules-list">
|
|
62
|
+
|
|
63
|
+
</div>
|
|
64
|
+
</div>
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
<%
|
|
2
|
+
options = alchemy_field.config.options || {};
|
|
3
|
+
%>
|
|
4
|
+
|
|
5
|
+
<alchemy-query-builder-value
|
|
6
|
+
class="alchemy-field-value"
|
|
7
|
+
#value={% value %}
|
|
8
|
+
#dataprovider={% alchemy_field %}
|
|
9
|
+
variable-types={% options.variable_types %}
|
|
10
|
+
source-types={% options.source_types %}
|
|
11
|
+
></alchemy-query-builder-value>
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
<%
|
|
2
|
+
options = alchemy_field.config.options || {};
|
|
3
|
+
%>
|
|
4
|
+
|
|
5
|
+
<alchemy-query-builder-variable
|
|
6
|
+
class="alchemy-field-value"
|
|
7
|
+
#value={% value %}
|
|
8
|
+
#dataprovider={% alchemy_field %}
|
|
9
|
+
variable-types={% options.variable_types %}
|
|
10
|
+
></alchemy-query-builder-variable>
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
<div class="qb-select-item qb-select-type-{% self.type %}">
|
|
2
|
+
<div class="type-and-name">
|
|
3
|
+
<span class="option-type" data-type={% data.type_name %}></span>
|
|
4
|
+
<span class="option-title">{{ data.title or data.name }}</span>
|
|
5
|
+
</div>
|
|
6
|
+
<span class="option-description">{{ data.description }}</span>
|
|
7
|
+
</div>
|