voom-presenters 0.1.13 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.ruby-version +1 -1
- data/CHANGELOG.md +186 -0
- data/Gemfile.lock +37 -38
- data/HISTORY.md +61 -0
- data/README.md +23 -1
- data/app/demo/components/chips.pom +6 -0
- data/app/demo/components/{forms.pom → content.pom} +3 -3
- data/app/demo/components/date_fields.pom +1 -1
- data/app/demo/components/datetime_fields.pom +6 -0
- data/app/demo/components/drawers.pom +1 -1
- data/app/demo/components/file_inputs.pom +16 -0
- data/app/demo/components/footers.pom +1 -1
- data/app/demo/components/google_maps.pom +17 -0
- data/app/demo/components/headers.pom +1 -1
- data/app/demo/components/layouts.pom +36 -4
- data/app/demo/components/lists.pom +25 -0
- data/app/demo/components/nav/menu.pom +9 -2
- data/app/demo/components/nav/pattern_drawer.pom +5 -0
- data/app/demo/components/nav/pattern_menu.pom +12 -0
- data/app/demo/components/sliders.pom +49 -0
- data/app/demo/components/snackbar.pom +10 -0
- data/app/demo/components/steppers.pom +178 -0
- data/app/demo/components/tab_bars.pom +51 -0
- data/app/demo/components/tables.pom +85 -13
- data/app/demo/components/text_areas.pom +13 -0
- data/app/demo/components/text_fields.pom +20 -8
- data/app/demo/components/toggles.pom +50 -14
- data/app/demo/components/tooltips.pom +2 -6
- data/app/demo/events/actions/clear.pom +23 -0
- data/app/demo/events/actions/loads.pom +16 -6
- data/app/demo/events/actions/posts.pom +1 -1
- data/app/demo/events/actions/toggle_visiblity.pom +4 -3
- data/app/demo/events/nav/drawer.pom +2 -2
- data/app/demo/events/tagged_input.pom +37 -0
- data/app/demo/hello_world.pom +3 -0
- data/app/demo/markdown.pom +1 -0
- data/app/demo/namespaces.pom +89 -0
- data/app/demo/nav/top_nav.pom +12 -0
- data/app/demo/patterns.pom +19 -0
- data/app/demo/patterns/search_select.pom +104 -0
- data/app/demo/shared/context_list.pom +1 -1
- data/app/demo/styles.pom +21 -11
- data/component-status.yml +11 -11
- data/config.ru +2 -1
- data/lib/voom/container_methods.rb +1 -1
- data/lib/voom/presenters-engine.rb +29 -26
- data/lib/voom/presenters.rb +15 -9
- data/lib/voom/presenters/api/app.rb +18 -5
- data/lib/voom/presenters/api/router.rb +11 -49
- data/lib/voom/presenters/demo/echo.rb +5 -0
- data/lib/voom/presenters/dsl.rb +10 -4
- data/lib/voom/presenters/dsl/components/actions/base.rb +37 -0
- data/lib/voom/presenters/dsl/components/actions/clear.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/deletes.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/dialog.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/loads.rb +32 -0
- data/lib/voom/presenters/dsl/components/actions/navigates.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/posts.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/remove.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/replaces.rb +25 -0
- data/lib/voom/presenters/dsl/components/actions/snackbar.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/stepper.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/toggle_visibility.rb +17 -0
- data/lib/voom/presenters/dsl/components/actions/updates.rb +17 -0
- data/lib/voom/presenters/dsl/components/avatar.rb +4 -5
- data/lib/voom/presenters/dsl/components/badge.rb +1 -1
- data/lib/voom/presenters/dsl/components/base.rb +20 -11
- data/lib/voom/presenters/dsl/components/button.rb +12 -10
- data/lib/voom/presenters/dsl/components/card.rb +18 -19
- data/lib/voom/presenters/dsl/components/checkbox.rb +3 -1
- data/lib/voom/presenters/dsl/components/chip.rb +9 -10
- data/lib/voom/presenters/dsl/components/content.rb +21 -11
- data/lib/voom/presenters/dsl/components/date_field.rb +1 -1
- data/lib/voom/presenters/dsl/components/datetime_base.rb +1 -2
- data/lib/voom/presenters/dsl/components/datetime_field.rb +1 -1
- data/lib/voom/presenters/dsl/components/dialog.rb +10 -6
- data/lib/voom/presenters/dsl/components/drawer.rb +6 -4
- data/lib/voom/presenters/dsl/components/event.rb +55 -39
- data/lib/voom/presenters/dsl/components/event_base.rb +2 -2
- data/lib/voom/presenters/dsl/components/expansion_panel.rb +5 -5
- data/lib/voom/presenters/dsl/components/file_input.rb +22 -0
- data/lib/voom/presenters/dsl/components/footer.rb +1 -1
- data/lib/voom/presenters/dsl/components/form.rb +17 -15
- data/lib/voom/presenters/dsl/components/google_map.rb +40 -0
- data/lib/voom/presenters/dsl/components/grid.rb +58 -18
- data/lib/voom/presenters/dsl/components/header.rb +2 -5
- data/lib/voom/presenters/dsl/components/hidden_field.rb +2 -2
- data/lib/voom/presenters/dsl/components/icon.rb +4 -5
- data/lib/voom/presenters/dsl/components/icon_base.rb +3 -3
- data/lib/voom/presenters/dsl/components/icon_toggle.rb +2 -2
- data/lib/voom/presenters/dsl/components/image.rb +3 -3
- data/lib/voom/presenters/dsl/components/input.rb +2 -2
- data/lib/voom/presenters/dsl/components/list.rb +12 -10
- data/lib/voom/presenters/dsl/components/lists/action.rb +8 -9
- data/lib/voom/presenters/dsl/components/lists/actions.rb +8 -8
- data/lib/voom/presenters/dsl/components/lists/header.rb +2 -2
- data/lib/voom/presenters/dsl/components/lists/line.rb +14 -17
- data/lib/voom/presenters/dsl/components/lists/separator.rb +2 -2
- data/lib/voom/presenters/dsl/components/menu.rb +10 -12
- data/lib/voom/presenters/dsl/components/mixins/attaches.rb +9 -3
- data/lib/voom/presenters/dsl/components/mixins/avatar.rb +0 -1
- data/lib/voom/presenters/dsl/components/mixins/buttons.rb +1 -1
- data/lib/voom/presenters/dsl/components/mixins/chips.rb +1 -2
- data/lib/voom/presenters/dsl/components/mixins/common.rb +20 -14
- data/lib/voom/presenters/dsl/components/mixins/content.rb +1 -1
- data/lib/voom/presenters/dsl/components/mixins/date_time_fields.rb +0 -3
- data/lib/voom/presenters/dsl/components/mixins/dialogs.rb +1 -2
- data/lib/voom/presenters/dsl/components/mixins/event.rb +3 -3
- data/lib/voom/presenters/dsl/components/mixins/expansion_panels.rb +1 -1
- data/lib/voom/presenters/dsl/components/mixins/file_inputs.rb +16 -0
- data/lib/voom/presenters/dsl/components/mixins/google_maps.rb +15 -0
- data/lib/voom/presenters/dsl/components/mixins/grids.rb +1 -1
- data/lib/voom/presenters/dsl/components/mixins/icons.rb +0 -1
- data/lib/voom/presenters/dsl/components/mixins/menus.rb +1 -1
- data/lib/voom/presenters/dsl/components/mixins/selects.rb +0 -1
- data/lib/voom/presenters/dsl/components/mixins/sliders.rb +15 -0
- data/lib/voom/presenters/dsl/components/mixins/snackbars.rb +0 -1
- data/lib/voom/presenters/dsl/components/mixins/steppers.rb +15 -0
- data/lib/voom/presenters/dsl/components/mixins/tab_bars.rb +15 -0
- data/lib/voom/presenters/dsl/components/mixins/text_fields.rb +5 -3
- data/lib/voom/presenters/dsl/components/mixins/toggles.rb +1 -4
- data/lib/voom/presenters/dsl/components/mixins/tooltips.rb +0 -1
- data/lib/voom/presenters/dsl/components/mixins/typography.rb +43 -13
- data/lib/voom/presenters/dsl/components/page.rb +0 -1
- data/lib/voom/presenters/dsl/components/radio_button.rb +1 -1
- data/lib/voom/presenters/dsl/components/rich_text_area.rb +26 -0
- data/lib/voom/presenters/dsl/components/select.rb +4 -5
- data/lib/voom/presenters/dsl/components/slider.rb +39 -0
- data/lib/voom/presenters/dsl/components/snackbar.rb +2 -2
- data/lib/voom/presenters/dsl/components/stepper.rb +106 -0
- data/lib/voom/presenters/dsl/components/switch.rb +1 -1
- data/lib/voom/presenters/dsl/components/tab_bar.rb +53 -0
- data/lib/voom/presenters/dsl/components/table.rb +99 -27
- data/lib/voom/presenters/dsl/components/text_area.rb +4 -3
- data/lib/voom/presenters/dsl/components/text_field.rb +8 -12
- data/lib/voom/presenters/dsl/components/time_field.rb +1 -1
- data/lib/voom/presenters/dsl/components/toggle_base.rb +2 -2
- data/lib/voom/presenters/dsl/components/tooltip.rb +1 -2
- data/lib/voom/presenters/dsl/components/typography.rb +4 -5
- data/lib/voom/presenters/dsl/definer.rb +2 -2
- data/lib/voom/presenters/dsl/definition.rb +6 -4
- data/lib/voom/presenters/dsl/user_interface.rb +17 -21
- data/lib/voom/presenters/errors/parameter_validation.rb +1 -1
- data/lib/voom/presenters/helpers.rb +5 -5
- data/lib/voom/presenters/helpers/date.rb +3 -3
- data/lib/voom/presenters/helpers/rails.rb +7 -2
- data/lib/voom/presenters/helpers/rails/model_table.rb +14 -6
- data/lib/voom/presenters/helpers/route.rb +6 -0
- data/lib/voom/presenters/helpers/time.rb +1 -1
- data/lib/voom/presenters/namespace.rb +12 -0
- data/lib/voom/presenters/settings.rb +58 -37
- data/lib/voom/presenters/version.rb +1 -1
- data/lib/voom/presenters/web_client/app.rb +50 -20
- data/lib/voom/presenters/web_client/markdown_render.rb +24 -11
- data/lib/voom/presenters/web_client/router.rb +17 -52
- data/lib/voom/serializer.rb +2 -2
- data/lib/voom/trace.rb +1 -1
- data/presenters.gemspec +2 -1
- data/public/style-bundle.js +2 -2
- data/scripts/bump.sh +1 -0
- data/scripts/changelog.sh +5 -0
- data/scripts/deploy-demo.sh +1 -0
- data/scripts/release.sh +1 -1
- data/scripts/tag.sh +5 -0
- data/views/mdc/.babelrc +8 -0
- data/views/mdc/.eslintrc.yml +23 -0
- data/views/mdc/assets/js/app.js +19 -6
- data/views/mdc/assets/js/components/base-component.js +25 -2
- data/views/mdc/assets/js/components/base-container.js +47 -0
- data/views/mdc/assets/js/components/button.js +3 -10
- data/views/mdc/assets/js/components/cards.js +11 -0
- data/views/mdc/assets/js/components/checkboxes.js +30 -7
- data/views/mdc/assets/js/components/chips.js +38 -5
- data/views/mdc/assets/js/components/content.js +13 -0
- data/views/mdc/assets/js/components/data-tables.js +38 -0
- data/views/mdc/assets/js/components/datetime.js +61 -21
- data/views/mdc/assets/js/components/dialogs.js +25 -19
- data/views/mdc/assets/js/components/events.js +13 -3
- data/views/mdc/assets/js/components/events/base.js +13 -3
- data/views/mdc/assets/js/components/events/errors.js +1 -1
- data/views/mdc/assets/js/components/events/posts.js +53 -13
- data/views/mdc/assets/js/components/events/removes.js +20 -0
- data/views/mdc/assets/js/components/events/replaces.js +35 -36
- data/views/mdc/assets/js/components/events/stepper.js +23 -0
- data/views/mdc/assets/js/components/events/toggle_visibility.js +15 -11
- data/views/mdc/assets/js/components/file-inputs.js +29 -0
- data/views/mdc/assets/js/components/forms.js +8 -59
- data/views/mdc/assets/js/components/grid.js +20 -0
- data/views/mdc/assets/js/components/hidden-fields.js +33 -0
- data/views/mdc/assets/js/components/icon-toggles.js +7 -14
- data/views/mdc/assets/js/components/initialize.js +20 -1
- data/views/mdc/assets/js/components/lists.js +1 -1
- data/views/mdc/assets/js/components/menus.js +12 -13
- data/views/mdc/assets/js/components/mixins/visibility-observer.js +34 -0
- data/views/mdc/assets/js/components/radios.js +39 -0
- data/views/mdc/assets/js/components/rich-text-area.js +43 -0
- data/views/mdc/assets/js/components/selects.js +24 -23
- data/views/mdc/assets/js/components/sliders.js +56 -0
- data/views/mdc/assets/js/components/snackbar.js +14 -23
- data/views/mdc/assets/js/components/steppers.js +48 -0
- data/views/mdc/assets/js/components/switches.js +24 -23
- data/views/mdc/assets/js/components/tab-bars.js +14 -0
- data/views/mdc/assets/js/components/text-fields.js +37 -35
- data/views/mdc/assets/js/config.js +27 -0
- data/views/mdc/assets/js/mdl-stepper.js +1108 -0
- data/views/mdc/assets/js/utils/compatibility.js +9 -0
- data/views/mdc/assets/js/utils/config.js +73 -0
- data/views/mdc/assets/js/utils/config.test.js +59 -0
- data/views/mdc/assets/js/utils/urls.js +5 -2
- data/views/mdc/assets/scss/app.scss +11 -3
- data/views/mdc/assets/scss/components/button.scss +17 -2
- data/views/mdc/assets/scss/components/card.scss +8 -3
- data/views/mdc/assets/scss/components/checkbox.scss +0 -4
- data/views/mdc/assets/scss/components/content.scss +11 -0
- data/views/mdc/assets/scss/components/data-table.scss +80 -0
- data/views/mdc/assets/scss/components/datetime.scss +6 -0
- data/views/mdc/assets/scss/components/fab.scss +2 -1
- data/views/mdc/assets/scss/components/file-input.scss +22 -0
- data/views/mdc/assets/scss/components/grid.scss +59 -3
- data/views/mdc/assets/scss/components/image.scss +6 -0
- data/views/mdc/assets/scss/components/list.scss +13 -0
- data/views/mdc/assets/scss/components/menu.scss +1 -0
- data/views/mdc/assets/scss/components/radio.scss +4 -0
- data/views/mdc/assets/scss/components/rich-text-area.scss +37 -0
- data/views/mdc/assets/scss/components/slider.scss +1 -0
- data/views/mdc/assets/scss/components/snackbar.scss +1 -5
- data/views/mdc/assets/scss/components/stepper.scss +235 -0
- data/views/mdc/assets/scss/components/switch.scss +4 -5
- data/views/mdc/assets/scss/components/tab-bars.scss +4 -0
- data/views/mdc/assets/scss/components/textfield.scss +8 -1
- data/views/mdc/assets/scss/components/typography.scss +4 -0
- data/views/mdc/assets/scss/components/vendor/flatpickr.min.css +2 -2
- data/views/mdc/assets/scss/components/vendor/quill.snow.css +945 -0
- data/views/mdc/assets/scss/styles.scss +3 -2
- data/views/mdc/assets/scss/theme.scss +6 -0
- data/views/mdc/body/header.erb +1 -0
- data/views/mdc/body/snackbar.erb +1 -1
- data/views/mdc/components/actions/clear.rb +11 -0
- data/views/mdc/components/actions/delete.rb +11 -0
- data/views/mdc/components/actions/dialog.rb +11 -0
- data/views/mdc/components/actions/loads.rb +11 -0
- data/views/mdc/components/actions/navigates.rb +11 -0
- data/views/mdc/components/actions/post.rb +17 -0
- data/views/mdc/components/actions/remove.rb +10 -0
- data/views/mdc/components/actions/replaces.rb +12 -0
- data/views/mdc/components/actions/snackbar.rb +10 -0
- data/views/mdc/components/actions/stepper.rb +10 -0
- data/views/mdc/components/actions/toggle_visibility.rb +10 -0
- data/views/mdc/components/actions/update.rb +10 -0
- data/views/mdc/components/button.erb +9 -6
- data/views/mdc/components/buttons/button.erb +10 -5
- data/views/mdc/components/buttons/fab.erb +8 -2
- data/views/mdc/components/buttons/icon.erb +9 -2
- data/views/mdc/components/buttons/image.erb +9 -4
- data/views/mdc/components/{display.erb → caption.erb} +0 -0
- data/views/mdc/components/card.erb +6 -3
- data/views/mdc/components/checkbox.erb +21 -9
- data/views/mdc/components/chip.erb +12 -3
- data/views/mdc/components/content.erb +6 -1
- data/views/mdc/components/datetime.erb +21 -13
- data/views/mdc/components/dialog.erb +4 -1
- data/views/mdc/components/event.erb +5 -9
- data/views/mdc/components/file_input.erb +13 -0
- data/views/mdc/components/form.erb +19 -5
- data/views/mdc/components/google_map.erb +9 -0
- data/views/mdc/components/grid.erb +18 -4
- data/views/mdc/components/headline.erb +2 -0
- data/views/mdc/components/hidden_field.erb +6 -1
- data/views/mdc/components/icon_toggle.erb +1 -1
- data/views/mdc/components/list.erb +5 -2
- data/views/mdc/components/list/actions/switch.erb +1 -1
- data/views/mdc/components/list/line.erb +7 -6
- data/views/mdc/components/menu.erb +8 -12
- data/views/mdc/components/{subheading.erb → overline.erb} +0 -0
- data/views/mdc/components/radio_button.erb +20 -10
- data/views/mdc/components/rich_text_area.erb +19 -0
- data/views/mdc/components/select.erb +7 -3
- data/views/mdc/components/slider.erb +41 -0
- data/views/mdc/components/snackbar.erb +2 -6
- data/views/mdc/components/stepper.erb +47 -0
- data/views/mdc/components/stepper/step.erb +33 -0
- data/views/mdc/components/{title.erb → subtitle.erb} +0 -0
- data/views/mdc/components/switch.erb +27 -12
- data/views/mdc/components/tab_bar.erb +29 -0
- data/views/mdc/components/table.erb +4 -2
- data/views/mdc/components/table/checkbox.erb +17 -0
- data/views/mdc/components/table/header.erb +13 -4
- data/views/mdc/components/table/pagination.erb +14 -23
- data/views/mdc/components/table/row.erb +3 -1
- data/views/mdc/components/text_area.erb +17 -7
- data/views/mdc/components/text_field.erb +31 -13
- data/views/mdc/components/typography.erb +2 -2
- data/views/mdc/layout.erb +33 -31
- data/views/mdc/package-lock.json +11019 -6996
- data/views/mdc/package.json +46 -27
- data/views/mdc/webpack.config.js +1 -0
- metadata +112 -13
- data/app/demo/events/actions/autocomplete.pom +0 -32
- data/lib/voom/presenters/dsl/components/action.rb +0 -35
- data/views/mdc/assets/js/components/events/autocomplete.js +0 -96
- data/views/mdc/assets/js/material.js +0 -3996
- data/views/mdc/assets/scss/components/table-pagination.scss +0 -65
- data/views/mdc/components/modal.erb +0 -15
- data/views/mdc/components/static.erb +0 -7
@@ -0,0 +1,33 @@
|
|
1
|
+
import {VBaseComponent, hookupComponents} from './base-component';
|
2
|
+
|
3
|
+
export function initHiddenFields() {
|
4
|
+
console.log('\tHiddenFields');
|
5
|
+
hookupComponents('.v-hidden-field', VHiddenField, null);
|
6
|
+
}
|
7
|
+
|
8
|
+
export class VHiddenField extends VBaseComponent {
|
9
|
+
constructor(element, mdcComponent) {
|
10
|
+
super(element, mdcComponent);
|
11
|
+
}
|
12
|
+
|
13
|
+
// Called to collect data for submission
|
14
|
+
prepareSubmit(params) {
|
15
|
+
params.push([this.name(), this.value()]);
|
16
|
+
}
|
17
|
+
|
18
|
+
name(){
|
19
|
+
return this.element.name;
|
20
|
+
}
|
21
|
+
|
22
|
+
value(){
|
23
|
+
return this.element.value;
|
24
|
+
}
|
25
|
+
|
26
|
+
clear(){
|
27
|
+
this.setValue('');
|
28
|
+
}
|
29
|
+
|
30
|
+
setValue(value){
|
31
|
+
this.element.value = value;
|
32
|
+
}
|
33
|
+
}
|
@@ -1,21 +1,14 @@
|
|
1
1
|
import {MDCIconToggle} from '@material/icon-toggle';
|
2
|
+
import {hookupComponents, VBaseComponent} from './base-component';
|
3
|
+
import {eventHandlerMixin} from './mixins/event-handler';
|
2
4
|
|
3
5
|
export function initIconToggles() {
|
4
6
|
console.log('\tIcon Toggles');
|
7
|
+
hookupComponents('.v-icon-toggle', VIconToggle, MDCIconToggle);
|
8
|
+
}
|
5
9
|
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
if (!component.mdcComponent) {
|
10
|
-
component.mdcComponent = new MDCIconToggle(component);
|
11
|
-
}
|
10
|
+
export class VIconToggle extends eventHandlerMixin(VBaseComponent) {
|
11
|
+
constructor(element, mdcComponent) {
|
12
|
+
super(element, mdcComponent);
|
12
13
|
}
|
13
14
|
}
|
14
|
-
|
15
|
-
// TODO: Add event handler
|
16
|
-
// var addToFavorites = document.getElementById('add-to-favorites');
|
17
|
-
// var favoritedStatus = document.getElementById('favorited-status');
|
18
|
-
// addToFavorites.addEventListener('MDCIconToggle:change', function(evt) {
|
19
|
-
// var newStatus = evt.detail.isOn ? 'yes' : 'no';
|
20
|
-
// favoritedStatus.textContent = newStatus;
|
21
|
-
// });
|
@@ -13,6 +13,16 @@ import {initForms} from './forms';
|
|
13
13
|
import {initSnackbar} from './snackbar';
|
14
14
|
import {initCheckboxes} from './checkboxes';
|
15
15
|
import {initSwitches} from './switches';
|
16
|
+
import {initRichTextArea} from './rich-text-area';
|
17
|
+
import {initSteppers} from './steppers';
|
18
|
+
import {initRadios} from './radios';
|
19
|
+
import {initSliders} from './sliders';
|
20
|
+
import {initHiddenFields} from './hidden-fields';
|
21
|
+
import {initContent} from './content';
|
22
|
+
import {initGrid} from './grid';
|
23
|
+
import {initTabBars} from './tab-bars';
|
24
|
+
import {initTables} from './data-tables';
|
25
|
+
import {initFileInputs} from './file-inputs';
|
16
26
|
|
17
27
|
export function initialize(){
|
18
28
|
console.log('Initializing');
|
@@ -30,7 +40,16 @@ export function initialize(){
|
|
30
40
|
initSnackbar();
|
31
41
|
initCheckboxes();
|
32
42
|
initSwitches();
|
43
|
+
initRichTextArea();
|
44
|
+
initSteppers();
|
45
|
+
initRadios();
|
46
|
+
initSliders();
|
47
|
+
initHiddenFields();
|
48
|
+
initContent();
|
49
|
+
initGrid();
|
50
|
+
initTabBars();
|
51
|
+
initTables();
|
52
|
+
initFileInputs();
|
33
53
|
// This needs to be last, because it relies on the components installed above.
|
34
54
|
initEvents();
|
35
|
-
// componentHandler.upgradeAllRegistered();
|
36
55
|
}
|
@@ -46,7 +46,7 @@ function toggleSelectTotalHeader(component, count, show = false) {
|
|
46
46
|
|
47
47
|
function toggleSelectTotalInput(component, selectTotal = false) {
|
48
48
|
if (component.dataset.totalLines > 0) {
|
49
|
-
component.querySelector('#select-total').checked = selectTotal
|
49
|
+
component.querySelector('#select-total').checked = selectTotal;
|
50
50
|
component.querySelector('#list-item-select-all-toggle-on').classList.add('hidden');
|
51
51
|
component.querySelector('#list-item-select-all-toggle-off').classList.add('hidden');
|
52
52
|
component.querySelector('#list-item-select-all-toggle-' + (selectTotal ? 'on' : 'off')).classList.remove('hidden');
|
@@ -1,11 +1,13 @@
|
|
1
1
|
import {MDCMenu} from '@material/menu';
|
2
2
|
import {Corner} from '@material/menu';
|
3
|
+
import {hookupComponents, VBaseComponent} from "./base-component";
|
4
|
+
import {eventHandlerMixin} from "./mixins/event-handler";
|
3
5
|
|
4
6
|
|
5
7
|
function createMenuHandler(menu, element) {
|
6
8
|
return function () {
|
7
9
|
let offset = parseInt(element.dataset.rightOffset);
|
8
|
-
let placement = element.dataset.placement === 'contextual' ? Corner.TOP_LEFT : Corner.BOTTOM_LEFT
|
10
|
+
let placement = element.dataset.placement === 'contextual' ? Corner.TOP_LEFT : Corner.BOTTOM_LEFT;
|
9
11
|
menu.setAnchorMargin({left: offset});
|
10
12
|
menu.setAnchorCorner(placement);
|
11
13
|
menu.open = !menu.open;
|
@@ -14,20 +16,17 @@ function createMenuHandler(menu, element) {
|
|
14
16
|
|
15
17
|
export function initMenus() {
|
16
18
|
console.log('\tMenus');
|
19
|
+
hookupComponents('.v-menu', VMenu, MDCMenu);
|
20
|
+
}
|
17
21
|
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
var component = components[i];
|
22
|
-
if (!component.mdcComponent) {
|
23
|
-
component.mdcComponent = new MDCMenu(component);
|
24
|
-
var anchor = component.closest('.mdc-menu-anchor');
|
25
|
-
if (anchor) {
|
26
|
-
var menulink = anchor.querySelector('.v-menu-click');
|
27
|
-
menulink.addEventListener('click', createMenuHandler(component.mdcComponent, component));
|
28
|
-
}
|
22
|
+
export class VMenu extends eventHandlerMixin(VBaseComponent) {
|
23
|
+
constructor(element, mdcComponent) {
|
24
|
+
super(element, mdcComponent);
|
29
25
|
|
30
|
-
|
26
|
+
var anchor = element.closest('.mdc-menu-anchor');
|
27
|
+
if (anchor) {
|
28
|
+
var menulink = anchor.querySelector('.v-menu-click');
|
29
|
+
menulink.addEventListener('click', createMenuHandler(mdcComponent, element));
|
31
30
|
}
|
32
31
|
}
|
33
32
|
}
|
@@ -0,0 +1,34 @@
|
|
1
|
+
export let visibilityObserverMixin = Base => class extends Base {
|
2
|
+
|
3
|
+
recalcWhenVisible(vComponent) {
|
4
|
+
vComponent.hidden_on_create = vComponent.element.offsetParent === null;
|
5
|
+
if(vComponent.hidden_on_create){
|
6
|
+
// If the component is hidden in DOM for any number of reasons (parent is hidden) then the
|
7
|
+
// Text Field may no render correctly. In this case we observe the DOM watching for a point at which the
|
8
|
+
// element become visible in the DOM and at that point using the MDCComponent to properly re-render that
|
9
|
+
// element
|
10
|
+
vComponent.mutationObserver = new MutationObserver(function(mutations) {
|
11
|
+
if(this.vComponent.hidden_on_create) {
|
12
|
+
if(this.vComponent.element.offsetParent !== null){
|
13
|
+
// Parent is now visible. Re-run the MDC layout and disconnect from the observer
|
14
|
+
this.vComponent.hidden_on_create = false;
|
15
|
+
this.vComponent.mdcComponent.layout();
|
16
|
+
// I changed this to addtionally force a resize event on the element after mdcComponent.layout();
|
17
|
+
// method. In some scenarios with the MDCSlider going from hidden to visible calling layout
|
18
|
+
// didn't work. Firing the 'resize' event did.
|
19
|
+
var event = document.createEvent('HTMLEvents');
|
20
|
+
event.initEvent('resize', true, false);
|
21
|
+
this.vComponent.element.dispatchEvent(event);
|
22
|
+
this.disconnect();
|
23
|
+
}
|
24
|
+
}
|
25
|
+
});
|
26
|
+
vComponent.mutationObserver.vComponent = vComponent;
|
27
|
+
vComponent.mutationObserver.observe(document.documentElement, {
|
28
|
+
attributes: true,
|
29
|
+
subtree: true
|
30
|
+
});
|
31
|
+
}
|
32
|
+
|
33
|
+
}
|
34
|
+
};
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import {VBaseComponent, hookupComponents} from './base-component';
|
2
|
+
import {eventHandlerMixin} from "./mixins/event-handler";
|
3
|
+
import {MDCRadio} from "@material/radio";
|
4
|
+
|
5
|
+
export function initRadios() {
|
6
|
+
console.log('\tRadios');
|
7
|
+
hookupComponents('.v-radio', VRadio, MDCRadio);
|
8
|
+
}
|
9
|
+
|
10
|
+
export class VRadio extends eventHandlerMixin(VBaseComponent) {
|
11
|
+
constructor(element, mdcComponent) {
|
12
|
+
super(element, mdcComponent);
|
13
|
+
this.input = element.querySelector('input');
|
14
|
+
}
|
15
|
+
|
16
|
+
prepareSubmit(params) {
|
17
|
+
if(this.input.checked) {
|
18
|
+
params.push([this.name(), this.value()]);
|
19
|
+
}
|
20
|
+
}
|
21
|
+
|
22
|
+
name(){
|
23
|
+
return this.input.name;
|
24
|
+
}
|
25
|
+
|
26
|
+
value(){
|
27
|
+
return this.input.value;
|
28
|
+
}
|
29
|
+
|
30
|
+
clear(){
|
31
|
+
this.setValue('');
|
32
|
+
}
|
33
|
+
|
34
|
+
setValue(value){
|
35
|
+
this.input.value = value;
|
36
|
+
}
|
37
|
+
|
38
|
+
|
39
|
+
}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
import Quill from "quill";
|
2
|
+
|
3
|
+
var toolbarOptions = [
|
4
|
+
['bold', 'italic', 'underline', 'strike'], // toggled buttons
|
5
|
+
['blockquote', 'code-block'],
|
6
|
+
|
7
|
+
[{ 'header': 1 }, { 'header': 2 }], // custom button values
|
8
|
+
[{ 'list': 'ordered'}, { 'list': 'bullet' }],
|
9
|
+
[{ 'script': 'sub'}, { 'script': 'super' }], // superscript/subscript
|
10
|
+
[{ 'indent': '-1'}, { 'indent': '+1' }], // outdent/indent
|
11
|
+
[{ 'direction': 'rtl' }], // text direction
|
12
|
+
|
13
|
+
[{ 'size': ['small', false, 'large', 'huge'] }], // custom dropdown
|
14
|
+
[{ 'header': [1, 2, 3, 4, 5, 6, false] }],
|
15
|
+
|
16
|
+
//[{ 'color': [] }, { 'background': [] }], // dropdown with defaults from theme
|
17
|
+
//[{ 'font': [] }],
|
18
|
+
[{ 'align': [] }],
|
19
|
+
['link', 'image'],
|
20
|
+
['clean'] // remove formatting button
|
21
|
+
];
|
22
|
+
|
23
|
+
export function initRichTextArea() {
|
24
|
+
console.log('\tRich Text Area');
|
25
|
+
let components = document.querySelectorAll('.v-rich-text-area');
|
26
|
+
for (let i = 0; i < components.length; i++) {
|
27
|
+
let component = components[i];
|
28
|
+
let form = component.closest('form');
|
29
|
+
if (!component.vComponent) {
|
30
|
+
component.vComponent = new Quill(component, {
|
31
|
+
modules: {
|
32
|
+
toolbar: toolbarOptions
|
33
|
+
},
|
34
|
+
theme: 'snow',
|
35
|
+
placeholder: component.dataset.placeholder
|
36
|
+
});
|
37
|
+
let input = document.querySelector('input[name=' + component.dataset.name + ']');
|
38
|
+
component.vComponent.on('text-change', function(){
|
39
|
+
input.value = component.vComponent.root.innerHTML;
|
40
|
+
});
|
41
|
+
}
|
42
|
+
}
|
43
|
+
}
|
@@ -1,45 +1,46 @@
|
|
1
1
|
import {MDCSelect} from '@material/select';
|
2
|
-
import {VBaseComponent} from './base-component';
|
2
|
+
import {VBaseComponent, hookupComponents} from './base-component';
|
3
3
|
import {eventHandlerMixin} from './mixins/event-handler';
|
4
4
|
|
5
5
|
export function initSelects() {
|
6
6
|
console.log('\tSelects');
|
7
|
-
|
8
|
-
for (var i = 0; i < components.length; i++) {
|
9
|
-
var component = components[i];
|
10
|
-
if (!component.vComponent) {
|
11
|
-
let vSelect = new VSelect(component, MDCSelect.attachTo(component));
|
12
|
-
component.vComponent = vSelect;
|
13
|
-
var selectInput = component.querySelector('select');
|
14
|
-
selectInput.vComponent = vSelect;
|
15
|
-
}
|
16
|
-
}
|
7
|
+
hookupComponents('.v-select', VSelect, MDCSelect);
|
17
8
|
}
|
18
9
|
|
19
10
|
|
20
11
|
export class VSelect extends eventHandlerMixin(VBaseComponent) {
|
21
12
|
constructor(element, mdcComponent) {
|
22
|
-
super(element);
|
13
|
+
super(element, mdcComponent);
|
23
14
|
this.select = element.querySelector('select');
|
24
|
-
this.
|
15
|
+
this.select.vComponent = this;
|
25
16
|
}
|
26
17
|
|
27
|
-
prepareSubmit(
|
28
|
-
|
29
|
-
if (!form) {
|
30
|
-
params.push([this.select.name, this.select.value]);
|
31
|
-
}
|
18
|
+
prepareSubmit(params) {
|
19
|
+
params.push([this.name(), this.value()]);
|
32
20
|
}
|
33
21
|
|
34
|
-
|
35
|
-
return
|
22
|
+
name() {
|
23
|
+
return this.select.name;
|
36
24
|
}
|
37
25
|
|
38
|
-
|
39
|
-
|
26
|
+
value() {
|
27
|
+
return this.select.options.length === 0 ? null : this.select.options[this.select.selectedIndex].value;
|
40
28
|
}
|
41
29
|
|
42
|
-
|
30
|
+
clear() {
|
31
|
+
let before = this.select.selectedIndex;
|
32
|
+
this.select.selectedIndex = 0;
|
33
|
+
if (before !== 0) {
|
34
|
+
var event = new InputEvent('input', {
|
35
|
+
view: window,
|
36
|
+
bubbles: true,
|
37
|
+
cancelable: true
|
38
|
+
});
|
39
|
+
this.select .dispatchEvent(event);
|
40
|
+
}
|
41
|
+
}
|
43
42
|
|
43
|
+
setValue(value) {
|
44
|
+
this.select.value = value;
|
44
45
|
}
|
45
46
|
}
|
@@ -0,0 +1,56 @@
|
|
1
|
+
import {VBaseComponent, hookupComponents} from './base-component';
|
2
|
+
import {eventHandlerMixin} from "./mixins/event-handler";
|
3
|
+
import {MDCSlider} from '@material/slider';
|
4
|
+
import {visibilityObserverMixin} from './mixins/visibility-observer';
|
5
|
+
import {VEvents} from './events';
|
6
|
+
|
7
|
+
export function initSliders() {
|
8
|
+
console.log('\tSliders');
|
9
|
+
hookupComponents('.v-slider', VSlider, MDCSlider);
|
10
|
+
}
|
11
|
+
|
12
|
+
export class VSlider extends visibilityObserverMixin(eventHandlerMixin(VBaseComponent)) {
|
13
|
+
constructor(element, mdcComponent) {
|
14
|
+
super(element, mdcComponent);
|
15
|
+
this.recalcWhenVisible(this);
|
16
|
+
}
|
17
|
+
|
18
|
+
|
19
|
+
prepareSubmit(params) {
|
20
|
+
params.push([this.name(), this.value()]);
|
21
|
+
}
|
22
|
+
|
23
|
+
name() {
|
24
|
+
return this.element.getAttribute('data-name')
|
25
|
+
}
|
26
|
+
|
27
|
+
value() {
|
28
|
+
return this.mdcComponent.value
|
29
|
+
}
|
30
|
+
|
31
|
+
clear() {
|
32
|
+
this.setValue(0);
|
33
|
+
}
|
34
|
+
|
35
|
+
setValue(value) {
|
36
|
+
this.mdcComponent.value = value;
|
37
|
+
}
|
38
|
+
|
39
|
+
initEventListener(eventName, eventHandler) {
|
40
|
+
if (eventName === 'change') {
|
41
|
+
eventName = 'MDCSlider:change';
|
42
|
+
}
|
43
|
+
super.initEventListener(eventName, eventHandler);
|
44
|
+
}
|
45
|
+
|
46
|
+
|
47
|
+
createEventHandler(actionsData) {
|
48
|
+
return function (event) {
|
49
|
+
// The MDC slider was firing duplicate change events - this prevents that
|
50
|
+
if (!this.lastEvent || (event.timeStamp - this.lastEvent.timeStamp) > 10.0) {
|
51
|
+
new VEvents(actionsData, event).call();
|
52
|
+
}
|
53
|
+
this.lastEvent = event;
|
54
|
+
};
|
55
|
+
}
|
56
|
+
}
|
@@ -1,32 +1,23 @@
|
|
1
1
|
import {MDCSnackbar, MDCSnackbarFoundation} from '@material/snackbar';
|
2
|
+
import {VBaseComponent, hookupComponents} from './base-component';
|
3
|
+
|
4
|
+
|
5
|
+
export function initSnackbar() {
|
6
|
+
console.log('\tSnackbar');
|
7
|
+
hookupComponents('.v-snackbar', VSnackbar, MDCSnackbar);
|
8
|
+
}
|
2
9
|
|
3
10
|
// This class displays a page level message
|
4
|
-
export class VSnackbar {
|
5
|
-
constructor(element,
|
6
|
-
|
7
|
-
|
11
|
+
export class VSnackbar extends VBaseComponent {
|
12
|
+
constructor(element, mdcComponent) {
|
13
|
+
super(element, mdcComponent);
|
14
|
+
element.classList.remove('v-hidden'); // defer causes default snackbar to flash without this
|
8
15
|
}
|
9
16
|
|
10
17
|
display(message) {
|
11
18
|
const dataObj = {
|
12
|
-
|
13
|
-
// actionText: 'Undo',
|
14
|
-
// actionHandler: function () {
|
15
|
-
// console.log('my undo function');
|
16
|
-
// }
|
19
|
+
message: message,
|
17
20
|
};
|
18
|
-
this.
|
21
|
+
this.mdcComponent.show(dataObj);
|
19
22
|
}
|
20
|
-
}
|
21
|
-
|
22
|
-
export function initSnackbar() {
|
23
|
-
console.log('\tSnackbar');
|
24
|
-
var components = document.querySelectorAll('.mdc-snackbar');
|
25
|
-
for (var i = 0; i < components.length; i++) {
|
26
|
-
var component = components[i];
|
27
|
-
if (!component.vComponent) {
|
28
|
-
let vSnackbar= new VSnackbar(component, MDCSnackbar.attachTo(component));
|
29
|
-
component.vComponent = vSnackbar;
|
30
|
-
}
|
31
|
-
}
|
32
|
-
}
|
23
|
+
}
|