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.
Files changed (42) hide show
  1. package/CHANGELOG.md +23 -0
  2. package/assets/stylesheets/form/alchemy_field_array.scss +4 -0
  3. package/assets/stylesheets/form/alchemy_toggle.scss +2 -0
  4. package/assets/stylesheets/form/query_builder.scss +185 -0
  5. package/config/routes.js +8 -0
  6. package/controller/form_api_controller.js +51 -2
  7. package/element/20_query_builder_base.js +82 -0
  8. package/element/25_query_builder_data.js +139 -0
  9. package/element/alchemy_field.js +19 -2
  10. package/element/alchemy_select.js +40 -2
  11. package/element/alchemy_select_item.js +42 -1
  12. package/element/alchemy_table.js +123 -21
  13. package/element/query_builder.js +90 -0
  14. package/element/query_builder_entry.js +388 -0
  15. package/element/query_builder_group.js +248 -0
  16. package/element/query_builder_value.js +316 -0
  17. package/element/query_builder_variable.js +103 -0
  18. package/helper/form_actions/00_form_action.js +328 -0
  19. package/helper/form_actions/url_action.js +69 -0
  20. package/helper/query_builder_variable_definition/00_variable_definition.js +371 -0
  21. package/helper/query_builder_variable_definition/boolean_variable_definition.js +24 -0
  22. package/helper/query_builder_variable_definition/list_variable_definition.js +38 -0
  23. package/helper/query_builder_variable_definition/number_variable_definition.js +106 -0
  24. package/helper/query_builder_variable_definition/string_variable_definition.js +46 -0
  25. package/helper_field/query_builder_assignment.js +11 -0
  26. package/helper_field/query_builder_field.js +91 -0
  27. package/helper_field/query_builder_value.js +56 -0
  28. package/helper_field/query_builder_variable.js +56 -0
  29. package/package.json +1 -1
  30. package/view/form/elements/alchemy_field_array.hwk +3 -1
  31. package/view/form/elements/alchemy_field_array_entry.hwk +3 -1
  32. package/view/form/elements/alchemy_select_item.hwk +6 -1
  33. package/view/form/elements/query_builder.hwk +1 -0
  34. package/view/form/elements/query_builder_entry.hwk +33 -0
  35. package/view/form/elements/query_builder_group.hwk +64 -0
  36. package/view/form/elements/query_builder_value.hwk +10 -0
  37. package/view/form/elements/query_builder_variable.hwk +6 -0
  38. package/view/form/inputs/edit/query_builder.hwk +5 -0
  39. package/view/form/inputs/edit/query_builder_assignment.hwk +6 -0
  40. package/view/form/inputs/edit/query_builder_value.hwk +11 -0
  41. package/view/form/inputs/edit/query_builder_variable.hwk +10 -0
  42. 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
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "alchemy-form",
3
3
  "description": "Form plugin for Alchemy",
4
- "version": "0.1.4",
4
+ "version": "0.1.7",
5
5
  "repository": {
6
6
  "type" : "git",
7
7
  "url" : "https://github.com/11ways/alchemy-form.git"
@@ -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">Add entry</button>
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 %}
@@ -11,5 +11,7 @@
11
11
  <% include(view_files, variables) %>
12
12
  </div>
13
13
  <div class="button">
14
- <button class="remove">Remove</button>
14
+ <button class="remove">
15
+ {%t "remove-entry" name=alchemy_field.field_name title=alchemy_field.field_title %}
16
+ </button>
15
17
  </div>
@@ -1,2 +1,7 @@
1
1
  <% data = self.data %>
2
- {%= data.title or data.name or data.$pk or self.value %}
2
+
3
+ {% if self.custom_template %}
4
+ {% include self.custom_template %}
5
+ {% else %}
6
+ {{ data.title or data.name or data.$pk or self.value }}
7
+ {% /if %}
@@ -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,10 @@
1
+ <alchemy-select
2
+ class="qb-source-type"
3
+ #dataprovider={% self %}
4
+ value-item-template="form/select/qb_item"
5
+ option-item-template="form/select/qb_item"
6
+ ></alchemy-select>
7
+
8
+ <div class="qb-value-input-wrapper">
9
+
10
+ </div>
@@ -0,0 +1,6 @@
1
+ <alchemy-select
2
+ class="qb-variable"
3
+ #dataprovider={% self %}
4
+ value-item-template="form/select/qb_item"
5
+ option-item-template="form/select/qb_item"
6
+ ></alchemy-select>
@@ -0,0 +1,5 @@
1
+ <alchemy-query-builder
2
+ class="alchemy-field-value"
3
+ #value={% value %}
4
+ #dataprovider={% alchemy_field %}
5
+ ></alchemy-query-builder>
@@ -0,0 +1,6 @@
1
+ <alchemy-query-builder-entry
2
+ class="alchemy-field-value"
3
+ type="assignment"
4
+ #value={% value %}
5
+ #dataprovider={% alchemy_field %}
6
+ ></alchemy-query-builder-entry>
@@ -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>