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.
Files changed (97) hide show
  1. package/CHANGELOG.md +29 -0
  2. package/assets/stylesheets/form/alchemy_form.scss +2 -16
  3. package/assets/stylesheets/form/elements/_button.scss +52 -0
  4. package/assets/stylesheets/form/{alchemy_code_input.scss → elements/_code_input.scss} +1 -1
  5. package/assets/stylesheets/form/{alchemy_feedback_input.scss → elements/_feedback_input.scss} +6 -8
  6. package/assets/stylesheets/form/{alchemy_field.scss → elements/_field.scss} +1 -1
  7. package/assets/stylesheets/form/{alchemy_field_array.scss → elements/_field_array.scss} +2 -2
  8. package/assets/stylesheets/form/{alchemy_field_translatable.scss → elements/_field_translatable.scss} +1 -1
  9. package/assets/stylesheets/form/elements/_form.scss +16 -0
  10. package/assets/stylesheets/form/{alchemy_pager.scss → elements/_pager.scss} +1 -1
  11. package/assets/stylesheets/form/{query_builder.scss → elements/_query_builder.scss} +7 -7
  12. package/assets/stylesheets/form/{alchemy_select.scss → elements/_select.scss} +2 -2
  13. package/assets/stylesheets/form/elements/_state.scss +8 -0
  14. package/assets/stylesheets/form/{alchemy_table.scss → elements/_table.scss} +2 -2
  15. package/assets/stylesheets/form/elements/_tabs.scss +47 -0
  16. package/assets/stylesheets/form/{alchemy_toggle.scss → elements/_toggle.scss} +1 -1
  17. package/assets/stylesheets/form/elements/index.scss +14 -0
  18. package/controller/form_api_controller.js +0 -1
  19. package/element/00_form_base.js +16 -8
  20. package/element/05_feedback_input.js +4 -13
  21. package/element/10_alchemy_field_custom.js +13 -15
  22. package/element/10_dataprovider.js +282 -0
  23. package/element/15_alchemy_field_entry.js +8 -10
  24. package/element/20_query_builder_base.js +4 -13
  25. package/element/25_query_builder_data.js +2 -2
  26. package/element/30_tab_base.js +29 -0
  27. package/element/40_stateful.js +125 -0
  28. package/element/al_button.js +109 -0
  29. package/element/{code_input.js → al_code_input.js} +1 -10
  30. package/element/{alchemy_field.js → al_field.js} +82 -41
  31. package/element/{alchemy_field_array.js → al_field_array.js} +7 -18
  32. package/element/{alchemy_field_array_entry.js → al_field_array_entry.js} +7 -9
  33. package/element/{alchemy_field_schema.js → al_field_schema.js} +23 -11
  34. package/element/{alchemy_field_translatable.js → al_field_translatable.js} +6 -17
  35. package/element/{alchemy_field_translatable_entry.js → al_field_translatable_entry.js} +2 -4
  36. package/element/{alchemy_form.js → al_form.js} +7 -16
  37. package/element/{alchemy_label.js → al_label.js} +1 -10
  38. package/element/{number_input.js → al_number_input.js} +2 -2
  39. package/element/{alchemy_pager.js → al_pager.js} +49 -41
  40. package/element/{alchemy_password_input.js → al_password_input.js} +0 -0
  41. package/element/{query_builder.js → al_query_builder.js} +3 -12
  42. package/element/{query_builder_entry.js → al_query_builder_entry.js} +8 -7
  43. package/element/{query_builder_group.js → al_query_builder_group.js} +7 -7
  44. package/element/{query_builder_value.js → al_query_builder_value.js} +2 -2
  45. package/element/{query_builder_variable.js → al_query_builder_variable.js} +1 -1
  46. package/element/{alchemy_select.js → al_select.js} +35 -108
  47. package/element/{alchemy_select_item.js → al_select_item.js} +33 -13
  48. package/element/al_state.js +26 -0
  49. package/element/{string_input.js → al_string_input.js} +2 -2
  50. package/element/al_tab_button.js +138 -0
  51. package/element/al_tab_context.js +102 -0
  52. package/element/al_tab_list.js +66 -0
  53. package/element/al_tab_panel.js +44 -0
  54. package/element/{alchemy_table.js → al_table.js} +204 -185
  55. package/element/{alchemy_toggle.js → al_toggle.js} +1 -10
  56. package/helper/form_actions/00_form_action.js +15 -4
  57. package/helper/form_actions/url_action.js +3 -2
  58. package/helper/query_builder_ns.js +108 -0
  59. package/helper/query_builder_variable_definition/00_variable_definition.js +52 -1
  60. package/helper/query_builder_variable_definition/boolean_variable_definition.js +1 -1
  61. package/helper_field/query_builder_field.js +49 -28
  62. package/helper_field/query_builder_value.js +0 -45
  63. package/helper_field/query_builder_variable.js +0 -45
  64. package/package.json +2 -2
  65. package/view/form/elements/alchemy_button.hwk +1 -0
  66. package/view/form/elements/alchemy_field.hwk +4 -4
  67. package/view/form/elements/alchemy_field_array.hwk +2 -2
  68. package/view/form/elements/alchemy_field_schema.hwk +2 -2
  69. package/view/form/elements/alchemy_field_translatable.hwk +2 -2
  70. package/view/form/elements/alchemy_field_translatable_entry.hwk +2 -2
  71. package/view/form/elements/alchemy_select_item.hwk +1 -3
  72. package/view/form/elements/query_builder.hwk +1 -1
  73. package/view/form/elements/query_builder_entry.hwk +6 -6
  74. package/view/form/elements/query_builder_value.hwk +2 -2
  75. package/view/form/elements/query_builder_variable.hwk +2 -2
  76. package/view/form/inputs/edit/belongs_to.hwk +2 -2
  77. package/view/form/inputs/edit/boolean.hwk +2 -2
  78. package/view/form/inputs/edit/enum.hwk +2 -2
  79. package/view/form/inputs/edit/has_and_belongs_to_many.hwk +2 -2
  80. package/view/form/inputs/edit/html.hwk +2 -2
  81. package/view/form/inputs/edit/query_builder.hwk +2 -2
  82. package/view/form/inputs/edit/query_builder_assignment.hwk +2 -2
  83. package/view/form/inputs/edit/query_builder_value.hwk +2 -2
  84. package/view/form/inputs/edit/query_builder_variable.hwk +2 -2
  85. package/view/form/inputs/edit/schema.hwk +2 -2
  86. package/view/form/inputs/edit/sourcecode.hwk +2 -2
  87. package/view/form/inputs/edit_inline/boolean.hwk +2 -2
  88. package/view/form/inputs/view/string.hwk +6 -1
  89. package/view/form/inputs/view_inline/datetime.hwk +8 -4
  90. package/view/form/inputs/view_inline/enum.hwk +1 -0
  91. package/view/form/inputs/view_inline/string.hwk +6 -1
  92. package/view/form/select/qb_item.hwk +1 -0
  93. package/view/form/wrappers/default/default.hwk +2 -2
  94. package/helper/widgets/alchemy_field_widget.js +0 -137
  95. package/helper/widgets/alchemy_form_widget.js +0 -169
  96. package/helper/widgets/alchemy_table_widget.js +0 -53
  97. package/view/form/inputs/view_inline/file.hwk +0 -6
@@ -1 +1,6 @@
1
- <span class="alchemy-field-value">{{ value }}</span>
1
+ <div>
2
+ <span class="alchemy-field-value">{{ value }}</span>
3
+ {% if alchemy_field.config.options.suffix %}
4
+ <span class="alchemy-field-suffix">{{ alchemy_field.config.options.suffix }}</span>
5
+ {% /if %}
6
+ </div>
@@ -1,4 +1,8 @@
1
- <time
2
- class="alchemy-field-value"
3
- datetime={% value.toISOString() %}
4
- >{{ value.format('Y‑m‑d H:i') }}</time>
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 +1,6 @@
1
- <span class="alchemy-field-value">{{ value }}</span>
1
+ <div>
2
+ <span class="alchemy-field-value">{{ value }}</span>
3
+ {% if alchemy_field.config.options.suffix %}
4
+ <span class="alchemy-field-suffix">{{ alchemy_field.config.options.suffix }}</span>
5
+ {% /if %}
6
+ </div>
@@ -1,3 +1,4 @@
1
+ <% data = self.data %>
1
2
  <div class="qb-select-item qb-select-type-{% self.type %}">
2
3
  <div class="type-and-name">
3
4
  <span class="option-type" data-type={% data.type_name %}></span>
@@ -1,5 +1,5 @@
1
1
  <div class="form-field-info">
2
- <alchemy-label>
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
- </alchemy-label>
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
- });
@@ -1,6 +0,0 @@
1
- {% if value %}
2
- <img
3
- !Media={% value %}
4
- +media-route="Media::thumb"
5
- >
6
- {% /if %}