headmin 0.2.6 → 0.3.2
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.
- checksums.yaml +4 -4
- data/CHANGELOG.md +29 -3
- data/Gemfile.lock +14 -3
- data/README.md +64 -57
- data/app/assets/config/headmin_manifest.js +2 -0
- data/app/assets/javascripts/headmin/config/i18n.js +11 -0
- data/{src/js → app/assets/javascripts}/headmin/controllers/blocks_controller.js +0 -1
- data/app/assets/javascripts/headmin/controllers/date_range_controller.js +32 -0
- data/app/assets/javascripts/headmin/controllers/dropzone_controller.js +33 -0
- data/app/assets/javascripts/headmin/controllers/file_preview_controller.js +244 -0
- data/{src/js → app/assets/javascripts}/headmin/controllers/filter_controller.js +12 -6
- data/{src/js → app/assets/javascripts}/headmin/controllers/filters_controller.js +0 -0
- data/app/assets/javascripts/headmin/controllers/flatpickr_controller.js +39 -0
- data/app/assets/javascripts/headmin/controllers/hello_controller.js +7 -0
- data/app/assets/javascripts/headmin/controllers/notification_controller.js +8 -0
- data/{src/js → app/assets/javascripts}/headmin/controllers/popup_controller.js +0 -1
- data/app/assets/javascripts/headmin/controllers/redactorx_controller.js +13 -0
- data/{src/js → app/assets/javascripts}/headmin/controllers/repeater_controller.js +0 -1
- data/app/assets/javascripts/headmin/controllers/select_controller.js +48 -0
- data/{src/js → app/assets/javascripts}/headmin/controllers/table_actions_controller.js +7 -37
- data/{src/js → app/assets/javascripts}/headmin/controllers/table_controller.js +23 -3
- data/app/assets/javascripts/headmin/index.js +41 -0
- data/app/assets/javascripts/headmin.js +15934 -0
- data/{src/scss → app/assets/stylesheets}/headmin/filter.scss +0 -0
- data/{src/scss → app/assets/stylesheets}/headmin/filters.scss +0 -0
- data/{src/scss → app/assets/stylesheets}/headmin/form.scss +55 -2
- data/{src/scss → app/assets/stylesheets}/headmin/general.scss +0 -0
- data/{src/scss → app/assets/stylesheets}/headmin/layout/body.scss +0 -0
- data/{src/scss → app/assets/stylesheets}/headmin/layout/sidebar.scss +0 -0
- data/{src/scss → app/assets/stylesheets}/headmin/layout.scss +0 -0
- data/{src/scss → app/assets/stylesheets}/headmin/login.scss +0 -0
- data/{src/scss/vendor/bootstrap/variables.scss → app/assets/stylesheets/headmin/overrides/bootstrap.scss} +0 -0
- data/{src/scss/vendor/redactorx/override.css → app/assets/stylesheets/headmin/overrides/redactorx.css} +0 -0
- data/{src/scss → app/assets/stylesheets}/headmin/popup.scss +0 -0
- data/app/assets/stylesheets/headmin/syntax.scss +349 -0
- data/{src/scss → app/assets/stylesheets}/headmin/table.scss +0 -0
- data/app/assets/stylesheets/headmin/thumbnail.scss +20 -0
- data/app/assets/stylesheets/headmin/utilities.scss +68 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_accordion.scss +118 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_alert.scss +57 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_badge.scss +29 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_breadcrumb.scss +28 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_button-group.scss +139 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_buttons.scss +111 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_card.scss +216 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_carousel.scss +229 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_close.scss +40 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_containers.scss +41 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_dropdown.scss +240 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_forms.scss +9 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_functions.scss +302 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_grid.scss +33 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_helpers.scss +9 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_images.scss +42 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_list-group.scss +174 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_mixins.scss +43 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_modal.scss +209 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_nav.scss +139 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_navbar.scss +335 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_offcanvas.scss +83 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_pagination.scss +64 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_placeholders.scss +51 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_popover.scss +158 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_progress.scss +48 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_reboot.scss +625 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_root.scss +54 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_spinners.scss +69 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_tables.scss +155 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_toasts.scss +51 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_tooltip.scss +115 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_transitions.scss +27 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_type.scss +104 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_utilities.scss +630 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/_variables.scss +1641 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/bootstrap-grid.scss +67 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/bootstrap-reboot.scss +13 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/bootstrap-utilities.scss +18 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/bootstrap.scss +53 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_floating-labels.scss +63 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_form-check.scss +152 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_form-control.scss +219 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_form-range.scss +91 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_form-select.scss +72 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_form-text.scss +11 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_input-group.scss +121 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_labels.scss +36 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/forms/_validation.scss +12 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_clearfix.scss +3 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_colored-links.scss +12 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_position.scss +30 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_ratio.scss +26 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_stacks.scss +15 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_stretched-link.scss +15 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_text-truncation.scss +7 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_visually-hidden.scss +8 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/helpers/_vr.scss +8 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_alert.scss +11 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_backdrop.scss +14 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_border-radius.scss +78 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_box-shadow.scss +18 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_breakpoints.scss +127 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_buttons.scss +133 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_caret.scss +64 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_clearfix.scss +9 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_color-scheme.scss +7 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_container.scss +9 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_deprecate.scss +10 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_forms.scss +144 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_gradients.scss +47 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_grid.scss +151 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_image.scss +16 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_list-group.scss +24 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_lists.scss +7 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_pagination.scss +31 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_reset-text.scss +17 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_resize.scss +6 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_table-variants.scss +21 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_text-truncate.scss +8 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_transition.scss +26 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_utilities.scss +89 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/mixins/_visually-hidden.scss +29 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/utilities/_api.scss +47 -0
- data/app/assets/stylesheets/headmin/vendor/bootstrap/scss/vendor/_rfs.scss +354 -0
- data/app/assets/stylesheets/headmin/vendor/flatpickr.css +903 -0
- data/{src/scss/vendor/redactorx → app/assets/stylesheets/headmin/vendor}/redactorx.css +0 -0
- data/app/assets/stylesheets/headmin/vendor/tom-select-bootstrap.css +537 -0
- data/app/assets/stylesheets/headmin.css +13454 -0
- data/app/assets/stylesheets/headmin.scss +65 -0
- data/app/helpers/headmin/admin_helper.rb +1 -0
- data/app/helpers/headmin/bootstrap_helper.rb +25 -3
- data/app/helpers/headmin/documentation_helper.rb +35 -0
- data/app/helpers/headmin/form_helper.rb +4 -0
- data/app/helpers/headmin/request_helper.rb +3 -8
- data/app/models/headmin/documentation_renderer.rb +32 -0
- data/app/models/headmin/form/base.rb +79 -0
- data/app/models/headmin/form/text.rb +53 -0
- data/app/services/block_service.rb +1 -1
- data/app/views/examples/admin.html.erb +1 -1
- data/app/views/headmin/_blocks.html.erb +2 -2
- data/app/views/headmin/_breadcrumbs.html.erb +1 -1
- data/app/views/headmin/_card.html.erb +10 -6
- data/app/views/headmin/_dropdown.html.erb +1 -1
- data/app/views/headmin/_filters.html.erb +22 -10
- data/app/views/headmin/_form.html.erb +14 -14
- data/app/views/headmin/_heading.html.erb +1 -1
- data/app/views/headmin/_notifications.html.erb +1 -1
- data/app/views/headmin/_pagination.html.erb +3 -5
- data/app/views/headmin/_popup.html.erb +10 -4
- data/app/views/headmin/_table.html.erb +10 -4
- data/app/views/headmin/_thumbnail.html.erb +45 -0
- data/app/views/headmin/dropdown/_devise.html.erb +2 -2
- data/app/views/headmin/dropdown/_list.html.erb +3 -6
- data/app/views/headmin/filters/_date.html.erb +9 -13
- data/app/views/headmin/filters/_flatpickr.html.erb +57 -0
- data/app/views/headmin/filters/_search.html.erb +5 -5
- data/app/views/headmin/filters/_select.html.erb +6 -6
- data/app/views/headmin/filters/filter/_button.html.erb +7 -7
- data/app/views/headmin/filters/filter/_template.html.erb +1 -1
- data/app/views/headmin/forms/_actions.html.erb +1 -1
- data/app/views/headmin/forms/_base.html.erb +100 -46
- data/app/views/headmin/forms/_blocks.html.erb +4 -4
- data/app/views/headmin/forms/_checkbox.html.erb +3 -3
- data/app/views/headmin/forms/_date.html.erb +30 -34
- data/app/views/headmin/forms/_date_range.html.erb +42 -0
- data/app/views/headmin/forms/_email.html.erb +35 -26
- data/app/views/headmin/forms/_file.html.erb +186 -34
- data/app/views/headmin/forms/_flatpickr.html.erb +34 -0
- data/app/views/headmin/forms/_flatpickr_range.html.erb +50 -0
- data/app/views/headmin/forms/_hidden.html.erb +24 -0
- data/app/views/headmin/forms/_image.html.erb +11 -45
- data/app/views/headmin/forms/_label.html.erb +18 -12
- data/app/views/headmin/forms/_number.html.erb +40 -37
- data/app/views/headmin/forms/_password.html.erb +37 -58
- data/app/views/headmin/forms/_redactorx.html.erb +8 -7
- data/app/views/headmin/forms/_repeater.html.erb +6 -6
- data/app/views/headmin/forms/_select.html.erb +43 -45
- data/app/views/headmin/forms/_text.html.erb +94 -59
- data/app/views/headmin/forms/_textarea.html.erb +37 -26
- data/app/views/headmin/forms/_url.html.erb +35 -26
- data/app/views/headmin/forms/_validation.html.erb +3 -3
- data/app/views/headmin/forms/_video.html.erb +21 -0
- data/app/views/headmin/forms/fields/_base.html.erb +3 -3
- data/app/views/headmin/forms/fields/_file.html.erb +2 -2
- data/app/views/headmin/forms/fields/_group.html.erb +3 -3
- data/app/views/headmin/forms/fields/_image.html.erb +2 -2
- data/app/views/headmin/forms/fields/_list.html.erb +3 -3
- data/app/views/headmin/forms/fields/_text.html.erb +2 -2
- data/app/views/headmin/forms/repeater/_row.html.erb +1 -1
- data/app/views/headmin/heading/_title.html.erb +1 -1
- data/app/views/headmin/layout/_body.html.erb +1 -1
- data/app/views/headmin/layout/_content.html.erb +1 -1
- data/app/views/headmin/layout/_footer.html.erb +1 -1
- data/app/views/headmin/layout/_header.html.erb +1 -1
- data/app/views/headmin/layout/_main.html.erb +12 -6
- data/app/views/headmin/layout/_sidebar.html.erb +3 -3
- data/app/views/headmin/layout/sidebar/_bottom.html.erb +1 -1
- data/app/views/headmin/layout/sidebar/_nav.html.erb +1 -1
- data/app/views/headmin/nav/_dropdown.html.erb +34 -0
- data/app/views/headmin/nav/_item.html.erb +22 -13
- data/app/views/headmin/table/_actions.html.erb +3 -5
- data/app/views/headmin/table/_body.html.erb +1 -1
- data/app/views/headmin/table/_foot.html.erb +1 -1
- data/app/views/headmin/table/_footer.html.erb +1 -1
- data/app/views/headmin/table/_head.html.erb +1 -1
- data/app/views/headmin/table/_header.html.erb +1 -1
- data/app/views/headmin/table/actions/_action.html.erb +4 -4
- data/app/views/headmin/table/actions/_delete.html.erb +1 -1
- data/app/views/headmin/table/actions/_export.html.erb +1 -1
- data/app/views/headmin/table/body/_row.html.erb +15 -7
- data/config/importmap.rb +2 -0
- data/config/locales/en.yml +0 -3
- data/config/locales/headmin/forms/en.yml +5 -0
- data/config/locales/headmin/forms/nl.yml +5 -0
- data/config/locales/headmin/popup/en.yml +4 -0
- data/config/locales/headmin/popup/nl.yml +4 -0
- data/config/locales/headmin/thumbnail/en.yml +4 -0
- data/config/locales/headmin/thumbnail/nl.yml +4 -0
- data/config/locales/nl.yml +0 -3
- data/esbuild-css.js +25 -0
- data/esbuild-js.js +11 -0
- data/headmin.gemspec +4 -1
- data/lib/headmin/engine.rb +15 -0
- data/lib/headmin/version.rb +1 -1
- data/lib/headmin.rb +1 -1
- data/package.json +18 -34
- data/src/js/headmin.js +1 -1
- data/src/scss/headmin.scss +1 -61
- data/yarn.lock +393 -5177
- metadata +191 -34
- data/.nvmrc +0 -1
- data/app/controllers/concerns/headmin/ckeditor.rb +0 -27
- data/app/views/headmin/forms/_ckeditor.html.erb +0 -42
- data/dist/css/headmin.css +0 -12354
- data/dist/js/headmin.js +0 -1080
- data/src/js/headmin/headmin.js +0 -141
- data/src/scss/headmin/utilities.scss +0 -19
- data/webpack.config.js +0 -30
@@ -0,0 +1,39 @@
|
|
1
|
+
import {Controller} from "@hotwired/stimulus"
|
2
|
+
import flatpickr from "flatpickr";
|
3
|
+
import {Dutch} from "flatpickr/dist/esm/l10n/nl.js"
|
4
|
+
import I18n from "../config/i18n";
|
5
|
+
|
6
|
+
export default class extends Controller {
|
7
|
+
static get targets() {
|
8
|
+
return ["input"]
|
9
|
+
}
|
10
|
+
|
11
|
+
connect() {
|
12
|
+
const options = {...this.defaultOptions(), ...this.options()}
|
13
|
+
flatpickr(this.inputTarget, options);
|
14
|
+
}
|
15
|
+
|
16
|
+
options() {
|
17
|
+
return JSON.parse(this.inputTarget.getAttribute('data-flatpickr-options'))
|
18
|
+
}
|
19
|
+
|
20
|
+
defaultOptions() {
|
21
|
+
return {
|
22
|
+
allowInput: true,
|
23
|
+
dateFormat: 'd/m/Y',
|
24
|
+
locale: this.getLocale(I18n.locale)
|
25
|
+
}
|
26
|
+
}
|
27
|
+
|
28
|
+
getLocale(locale) {
|
29
|
+
const locales = this.locales()
|
30
|
+
return locales[locale]
|
31
|
+
}
|
32
|
+
|
33
|
+
locales() {
|
34
|
+
return {
|
35
|
+
en: null,
|
36
|
+
nl: Dutch
|
37
|
+
}
|
38
|
+
}
|
39
|
+
}
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import {Controller} from "@hotwired/stimulus"
|
2
|
+
|
3
|
+
export default class extends Controller {
|
4
|
+
connect() {
|
5
|
+
if (typeof RedactorX == 'undefined') {
|
6
|
+
console.error("RedactorX is a paid module and is not included in Headmin. Please purchase it and import it as a JS module")
|
7
|
+
return false;
|
8
|
+
}
|
9
|
+
|
10
|
+
const options = JSON.parse(this.element.getAttribute('data-redactor-options'))
|
11
|
+
RedactorX(this.element, options);
|
12
|
+
}
|
13
|
+
}
|
@@ -99,7 +99,6 @@ export default class extends Controller {
|
|
99
99
|
}
|
100
100
|
|
101
101
|
replaceIdsWithTimestamps(template) {
|
102
|
-
console.log(template)
|
103
102
|
const regex = new RegExp(template.dataset.templateIdRegex, "g")
|
104
103
|
return template.innerHTML.replace(regex, new Date().getTime())
|
105
104
|
}
|
@@ -0,0 +1,48 @@
|
|
1
|
+
import {Controller} from "@hotwired/stimulus"
|
2
|
+
import TomSelect from "tom-select";
|
3
|
+
import I18n from "../config/i18n";
|
4
|
+
|
5
|
+
export default class extends Controller {
|
6
|
+
connect() {
|
7
|
+
if (this.element.hasAttribute('multiple')) {
|
8
|
+
this.initTomSelect()
|
9
|
+
}
|
10
|
+
}
|
11
|
+
|
12
|
+
defaultOptions(locale) {
|
13
|
+
const defaultOptions = {
|
14
|
+
en: {
|
15
|
+
render: {
|
16
|
+
option_create: function (data, escape) {
|
17
|
+
return '<div class="create">Add <strong>' + escape(data.input) + '</strong>…</div>'
|
18
|
+
},
|
19
|
+
no_results: function (data, escape) {
|
20
|
+
return '<div class="no-results">No results found</div>'
|
21
|
+
}
|
22
|
+
}
|
23
|
+
},
|
24
|
+
nl: {
|
25
|
+
render: {
|
26
|
+
option_create: function (data, escape) {
|
27
|
+
return '<div class="create">Voeg <strong>' + escape(data.input) + '</strong> toe …</div>'
|
28
|
+
},
|
29
|
+
no_results: function (data, escape) {
|
30
|
+
return '<div class="no-results">Geen resultaten gevonden</div>'
|
31
|
+
}
|
32
|
+
}
|
33
|
+
}
|
34
|
+
}
|
35
|
+
return defaultOptions[locale]
|
36
|
+
}
|
37
|
+
|
38
|
+
hasTags() {
|
39
|
+
return this.element.dataset['tags'] === "true"
|
40
|
+
}
|
41
|
+
|
42
|
+
initTomSelect() {
|
43
|
+
const defaultOptions = this.defaultOptions(I18n.locale)
|
44
|
+
const options = {create: this.hasTags()}
|
45
|
+
|
46
|
+
new TomSelect(this.element, {...defaultOptions, ...options})
|
47
|
+
}
|
48
|
+
}
|
@@ -1,21 +1,15 @@
|
|
1
1
|
import {Controller} from "@hotwired/stimulus"
|
2
2
|
|
3
3
|
export default class extends Controller {
|
4
|
-
static get values() {
|
5
|
-
return {
|
6
|
-
count: {type: Number, default: 0}
|
7
|
-
}
|
8
|
-
}
|
9
|
-
|
10
4
|
static get targets() {
|
11
5
|
return ["wrapper", "form", "select", "method", "button", "idInputTemplate", "id", "counter"]
|
12
6
|
}
|
13
7
|
|
14
8
|
connect() {
|
15
9
|
this.wrapperTarget.addEventListener('idSelectionChanged', (event) => {
|
16
|
-
|
17
|
-
this.
|
18
|
-
this.
|
10
|
+
this.updateIdFields(event.detail.ids)
|
11
|
+
this.updateCounter(event.detail.count)
|
12
|
+
this.toggleCounter(event.detail.count)
|
19
13
|
})
|
20
14
|
|
21
15
|
}
|
@@ -30,56 +24,32 @@ export default class extends Controller {
|
|
30
24
|
updateIdFields(ids) {
|
31
25
|
this.removeIds()
|
32
26
|
if (ids instanceof Array) {
|
33
|
-
this.countValue = ids.length
|
34
27
|
ids.forEach((id) => {
|
35
28
|
this.addId(id)
|
36
29
|
})
|
37
30
|
} else {
|
38
|
-
this.countValue = Infinity
|
39
31
|
this.addId('')
|
40
32
|
}
|
41
33
|
}
|
42
34
|
|
43
|
-
updateCounter() {
|
35
|
+
updateCounter(count) {
|
44
36
|
let htmlString = ''
|
45
|
-
switch (
|
37
|
+
switch (count) {
|
46
38
|
case 0:
|
47
39
|
htmlString = this.counterTarget.getAttribute('data-items-zero')
|
48
40
|
break;
|
49
41
|
case 1:
|
50
42
|
htmlString = this.counterTarget.getAttribute('data-items-one')
|
51
43
|
break;
|
52
|
-
case Infinity:
|
53
|
-
htmlString = this.counterTarget.getAttribute('data-items-other')
|
54
|
-
htmlString = htmlString.replace(/<b>[\s\S]*?<\/b>/, '<b>' + this.totalCount() + '<\/b>');
|
55
|
-
break;
|
56
44
|
default:
|
57
45
|
htmlString = this.counterTarget.getAttribute('data-items-other')
|
58
|
-
let count = this.countValue === Infinity ? this.totalCount() : this.countValue
|
59
46
|
htmlString = htmlString.replace(/<b>[\s\S]*?<\/b>/, `<b>${count}<\/b>`);
|
60
47
|
}
|
61
48
|
this.counterTarget.innerHTML = htmlString;
|
62
49
|
}
|
63
50
|
|
64
|
-
|
65
|
-
|
66
|
-
}
|
67
|
-
|
68
|
-
updateCountValueWithIds(ids) {
|
69
|
-
if (ids instanceof Array) {
|
70
|
-
this.countValue = ids.length
|
71
|
-
} else {
|
72
|
-
this.countValue = Infinity
|
73
|
-
}
|
74
|
-
}
|
75
|
-
|
76
|
-
countValueChanged() {
|
77
|
-
this.updateCounter()
|
78
|
-
this.toggle()
|
79
|
-
}
|
80
|
-
|
81
|
-
toggle() {
|
82
|
-
if (this.countValue > 0) {
|
51
|
+
toggleCounter(count) {
|
52
|
+
if (count > 0) {
|
83
53
|
this.wrapperTarget.classList.remove('d-none')
|
84
54
|
} else {
|
85
55
|
this.wrapperTarget.classList.add('d-none')
|
@@ -4,11 +4,14 @@ import Rails from "@rails/ujs";
|
|
4
4
|
|
5
5
|
export default class extends Controller {
|
6
6
|
static get values() {
|
7
|
-
return {
|
7
|
+
return {
|
8
|
+
url: String,
|
9
|
+
count: Number
|
10
|
+
}
|
8
11
|
}
|
9
12
|
|
10
13
|
static get targets() {
|
11
|
-
return ["table", "body", "actions", "idCheckbox", "idsCheckbox"]
|
14
|
+
return ["table", "body", "actions", "idCheckbox", "idsCheckbox", "row"]
|
12
15
|
}
|
13
16
|
|
14
17
|
connect() {
|
@@ -52,13 +55,30 @@ export default class extends Controller {
|
|
52
55
|
'idSelectionChanged',
|
53
56
|
{
|
54
57
|
detail: {
|
55
|
-
ids: this.ids()
|
58
|
+
ids: this.ids(),
|
59
|
+
count: this.selectedIdsCount()
|
56
60
|
}
|
57
61
|
}
|
58
62
|
)
|
59
63
|
)
|
60
64
|
}
|
61
65
|
|
66
|
+
selectedIdsCount() {
|
67
|
+
if (this.ids() instanceof Array) {
|
68
|
+
return this.ids().length
|
69
|
+
} else {
|
70
|
+
return this.totalCount()
|
71
|
+
}
|
72
|
+
}
|
73
|
+
|
74
|
+
totalCount() {
|
75
|
+
if (this.countValue === 0) {
|
76
|
+
return this.rowTargets.length
|
77
|
+
} else {
|
78
|
+
return this.countValue
|
79
|
+
}
|
80
|
+
}
|
81
|
+
|
62
82
|
ids() {
|
63
83
|
if (this.idsCheckboxTarget.checked) {
|
64
84
|
return null
|
@@ -0,0 +1,41 @@
|
|
1
|
+
import {Application} from "@hotwired/stimulus"
|
2
|
+
import BlocksController from "./controllers/blocks_controller"
|
3
|
+
import DateRangeController from "./controllers/date_range_controller"
|
4
|
+
import DropzoneController from "./controllers/dropzone_controller"
|
5
|
+
import FilePreviewController from "./controllers/file_preview_controller"
|
6
|
+
import FilterController from "./controllers/filter_controller"
|
7
|
+
import FiltersController from "./controllers/filters_controller"
|
8
|
+
import FlatpickrController from "./controllers/flatpickr_controller"
|
9
|
+
import HelloController from "./controllers/hello_controller"
|
10
|
+
import NotificationController from "./controllers/notification_controller"
|
11
|
+
import PopupController from "./controllers/popup_controller"
|
12
|
+
import RedactorxController from "./controllers/redactorx_controller"
|
13
|
+
import RepeaterController from "./controllers/repeater_controller"
|
14
|
+
import SelectController from "./controllers/select_controller"
|
15
|
+
import TableActionsController from "./controllers/table_actions_controller"
|
16
|
+
import TableController from "./controllers/table_controller"
|
17
|
+
import Rails from "@rails/ujs";
|
18
|
+
|
19
|
+
export class Headmin {
|
20
|
+
static start() {
|
21
|
+
window.Stimulus = window.Stimulus || Application.start()
|
22
|
+
Stimulus.register("blocks", BlocksController)
|
23
|
+
Stimulus.register("date_range", DateRangeController)
|
24
|
+
Stimulus.register("dropzone", DropzoneController)
|
25
|
+
Stimulus.register("file-preview", FilePreviewController)
|
26
|
+
Stimulus.register("filter", FilterController)
|
27
|
+
Stimulus.register("filters", FiltersController)
|
28
|
+
Stimulus.register("flatpickr", FlatpickrController)
|
29
|
+
Stimulus.register("hello", HelloController)
|
30
|
+
Stimulus.register("notification", NotificationController)
|
31
|
+
Stimulus.register("popup", PopupController)
|
32
|
+
Stimulus.register("redactorx", RedactorxController)
|
33
|
+
Stimulus.register("repeater", RepeaterController)
|
34
|
+
Stimulus.register("select", SelectController)
|
35
|
+
Stimulus.register("table", TableController)
|
36
|
+
Stimulus.register("table-actions", TableActionsController)
|
37
|
+
|
38
|
+
// Init Rails UJS
|
39
|
+
Rails.start()
|
40
|
+
}
|
41
|
+
}
|