alchemy-form 0.1.3 → 0.1.6
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 +24 -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/00_form_base.js +37 -1
- package/element/20_query_builder_base.js +82 -0
- package/element/alchemy_field.js +65 -15
- package/element/alchemy_field_schema.js +45 -11
- package/element/alchemy_form.js +1 -12
- package/element/alchemy_select.js +68 -13
- 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 +221 -0
- package/element/query_builder_value.js +435 -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 +351 -0
- package/helper/query_builder_variable_definition/boolean_variable_definition.js +24 -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/widgets/alchemy_field_widget.js +48 -1
- package/helper/widgets/alchemy_form_widget.js +17 -2
- 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/package.json +2 -2
- 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_field_schema.hwk +2 -4
- 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/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/select/qb_item.hwk +7 -0
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Schema fields are nested schema's
|
|
3
|
+
*
|
|
4
|
+
* @constructor
|
|
5
|
+
*
|
|
6
|
+
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
7
|
+
* @since 0.1.6
|
|
8
|
+
* @version 0.1.6
|
|
9
|
+
*/
|
|
10
|
+
const QueryBuilderField = Function.inherits('Alchemy.Field', function QueryBuilder(schema, name, options) {
|
|
11
|
+
|
|
12
|
+
if (!options) {
|
|
13
|
+
options = {};
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
QueryBuilder.super.call(this, schema, name, options);
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Set the datatype name
|
|
21
|
+
*
|
|
22
|
+
* @author Jelle De Loecker <jelle@develry.be>
|
|
23
|
+
* @since 0.1.6
|
|
24
|
+
* @version 0.1.6
|
|
25
|
+
*/
|
|
26
|
+
QueryBuilderField.setDatatype('object');
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* This field value is self-contained
|
|
30
|
+
*
|
|
31
|
+
* @author Jelle De Loecker <jelle@develry.be>
|
|
32
|
+
* @since 0.1.6
|
|
33
|
+
* @version 0.1.6
|
|
34
|
+
*/
|
|
35
|
+
QueryBuilderField.setSelfContained(true);
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Cast the given value to this field's type
|
|
39
|
+
*
|
|
40
|
+
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
41
|
+
* @since 0.1.6
|
|
42
|
+
* @version 0.1.6
|
|
43
|
+
*/
|
|
44
|
+
QueryBuilderField.setMethod(function cast(value, to_datasource) {
|
|
45
|
+
return value;
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Load remote data
|
|
50
|
+
*
|
|
51
|
+
* @author Jelle De Loecker <jelle@elevenways.be>
|
|
52
|
+
* @since 0.1.6
|
|
53
|
+
* @version 0.1.6
|
|
54
|
+
*
|
|
55
|
+
* @param {Object} config
|
|
56
|
+
* @param {HTMLElement} element
|
|
57
|
+
*/
|
|
58
|
+
QueryBuilderField.setMethod(function loadData(config, element) {
|
|
59
|
+
|
|
60
|
+
if (element) {
|
|
61
|
+
let form = element.queryParents('alchemy-form');
|
|
62
|
+
|
|
63
|
+
if (form) {
|
|
64
|
+
let doc = form.document;
|
|
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
|
+
});
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
return [];
|
|
91
|
+
});
|
|
@@ -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
|
+
});
|
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "alchemy-form",
|
|
3
3
|
"description": "Form plugin for Alchemy",
|
|
4
|
-
"version": "0.1.
|
|
4
|
+
"version": "0.1.6",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type" : "git",
|
|
7
7
|
"url" : "https://github.com/11ways/alchemy-form.git"
|
|
8
8
|
},
|
|
9
9
|
"peerDependencies": {
|
|
10
|
-
"alchemymvc" : "~1.
|
|
10
|
+
"alchemymvc" : "~1.2.0"
|
|
11
11
|
},
|
|
12
12
|
"license": "MIT",
|
|
13
13
|
"engines": {
|
|
@@ -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 %}
|
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
{%
|
|
2
|
-
{% each %}
|
|
1
|
+
{% each self.sub_fields as sub_field %}
|
|
3
2
|
<alchemy-field
|
|
4
3
|
#alchemy_field_schema=<% self %>
|
|
5
4
|
#schema=<% self.schema %>
|
|
6
5
|
field-name=<% sub_field.name %>
|
|
7
6
|
></alchemy-field>
|
|
8
|
-
{% /each %}
|
|
9
|
-
{% /with %}
|
|
7
|
+
{% /each %}
|
|
@@ -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,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>
|