@jetbrains/ring-ui 4.1.0-beta.9 → 4.1.4
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 +13 -0
- package/README.md +22 -16
- package/babel.config.js +3 -2
- package/components/alert/alert.js +9 -3
- package/components/alert/container.css +1 -1
- package/components/alert-service/alert-service.examples.css +18 -0
- package/components/alert-service/alert-service.examples.js +21 -0
- package/components/alert-service/alert-service.js +10 -3
- package/components/analytics/analytics__fus-plugin.js +1 -1
- package/components/auth/auth.test.js +14 -7
- package/components/auth/auth__core.js +64 -33
- package/components/auth-dialog/auth-dialog.js +1 -0
- package/components/avatar/avatar.css +4 -1
- package/components/avatar/avatar.examples.js +3 -2
- package/components/avatar/avatar.js +31 -6
- package/components/avatar/fallback-avatar.js +136 -0
- package/components/avatar-editor-ng/avatar-editor-ng.css +2 -2
- package/components/avatar-editor-ng/avatar-editor-ng.js +2 -1
- package/components/avatar-editor-ng/{avatar-editor-ng.html → avatar-editor-ng__template.js} +2 -2
- package/components/button/button.css +2 -2
- package/components/button/button.js +4 -1
- package/components/button-group/button-group.js +1 -1
- package/components/button-group/caption.js +1 -1
- package/components/button-ng/button-ng.js +1 -1
- package/components/button-set-ng/button-set-ng.js +3 -1
- package/components/checkbox/checkbox.css +1 -1
- package/components/code/code.js +1 -1
- package/components/confirm/confirm.js +1 -0
- package/components/confirm-service/confirm-service.js +5 -5
- package/components/content-layout/content-layout.css +1 -1
- package/components/data-list/data-list.css +1 -1
- package/components/date-picker/date-input.js +5 -4
- package/components/date-picker/date-picker.css +34 -22
- package/components/date-picker/date-picker.examples.js +1 -1
- package/components/date-picker/date-picker.js +16 -14
- package/components/date-picker/date-popup.js +22 -7
- package/components/date-picker/month-names.js +8 -5
- package/components/date-picker/month.js +6 -2
- package/components/date-picker/weekdays.js +10 -2
- package/components/dialog/dialog.examples.js +3 -1
- package/components/dialog/dialog.js +5 -2
- package/components/dialog/dialog.test.js +1 -1
- package/components/dialog/dialog__body-scroll-preventer.js +2 -2
- package/components/dialog-ng/dialog-ng.js +7 -8
- package/components/dialog-ng/{dialog-ng.html → dialog-ng__template.js} +2 -2
- package/components/dropdown/anchor.js +1 -0
- package/components/dropdown/dropdown.examples.js +36 -1
- package/components/dropdown-menu/dropdown-menu.examples.js +47 -0
- package/components/dropdown-menu/dropdown-menu.js +117 -0
- package/components/dropdown-menu/dropdown-menu.test.js +76 -0
- package/components/error-bubble/error-bubble-legacy.css +1 -1
- package/components/error-bubble/error-bubble.css +1 -1
- package/components/error-bubble/error-bubble.examples.js +1 -1
- package/components/error-page/error-page.css +2 -2
- package/components/footer-ng/footer-ng.js +13 -3
- package/components/form/form.css +2 -2
- package/components/form-ng/form-ng.js +3 -1
- package/components/global/global.css +1 -1
- package/components/global/theme.js +1 -1
- package/components/global/variables.css +8 -1
- package/components/grid/grid.css +10 -9
- package/components/header/header.css +1 -1
- package/components/header/header.examples.js +7 -8
- package/components/header/profile.js +10 -11
- package/components/http/http.js +1 -1
- package/components/icon/icon.css +5 -4
- package/components/island/island.css +4 -3
- package/components/island-legacy/island-legacy.css +3 -1
- package/components/list/list.js +6 -1
- package/components/list/list__custom.js +9 -3
- package/components/list/list__item.js +8 -2
- package/components/list/list__link.js +2 -1
- package/components/loader-inline/loader-inline.css +1 -1
- package/components/loader-screen/loader-screen.css +1 -1
- package/components/message/message.css +1 -1
- package/components/message/message.examples.js +8 -5
- package/components/pager/pager.js +5 -3
- package/components/permissions/permissions.js +1 -1
- package/components/progress-bar/progress-bar.css +1 -1
- package/components/progress-bar/progress-bar.examples.js +3 -3
- package/components/progress-bar/progress-bar.js +5 -2
- package/components/progress-bar/progress-bar.test.js +12 -13
- package/components/progress-bar-ng/progress-bar-ng.examples.js +3 -3
- package/components/query-assist/query-assist.css +13 -3
- package/components/query-assist/query-assist.examples.js +3 -1
- package/components/query-assist/query-assist.js +56 -12
- package/components/query-assist/query-assist.test.js +37 -5
- package/components/save-field-ng/save-field-ng.css +0 -3
- package/components/save-field-ng/save-field-ng.js +3 -1
- package/components/save-field-ng/{save-field-ng.html → save-field-ng__template.js} +2 -2
- package/components/select/select.css +12 -7
- package/components/select/select.examples.js +13 -0
- package/components/select/select.js +30 -43
- package/components/select/select.test.js +4 -5
- package/components/shortcuts-hint-ng/shortcuts-hint-ng.css +1 -1
- package/components/shortcuts-hint-ng/shortcuts-hint-ng.js +1 -1
- package/components/shortcuts-hint-ng/{shortcuts-hint-ng.html → shortcuts-hint-ng__template.js} +2 -2
- package/components/sidebar/sidebar.css +1 -0
- package/components/sidebar-ng/sidebar-ng.js +6 -2
- package/components/sidebar-ng/{sidebar-ng__button.html → sidebar-ng__button-template.js} +2 -2
- package/components/sidebar-ng/{sidebar-ng.html → sidebar-ng__template.js} +2 -2
- package/components/table/row.js +2 -1
- package/components/table/table.css +2 -1
- package/components/table-legacy/table-legacy.css +2 -2
- package/components/table-legacy/table-legacy__toolbar.css +2 -2
- package/components/table-legacy-ng/table-legacy-ng.js +38 -5
- package/components/table-legacy-ng/table-legacy-ng__pager.js +7 -1
- package/components/tabs/collapsible-tab.js +2 -2
- package/components/tabs/collapsible-tabs.js +4 -8
- package/components/tabs/dumb-tabs.js +1 -0
- package/components/tabs/tab-link.js +4 -2
- package/components/tabs/tabs.css +27 -0
- package/components/tabs-ng/tabs-ng.js +4 -2
- package/components/tabs-ng/{tabs-ng.html → tabs-ng__template.js} +6 -2
- package/components/tag/tag.css +5 -2
- package/components/tag/tag.examples.js +3 -0
- package/components/tag/tag.js +19 -16
- package/components/tags-input/tag-input.examples.js +1 -1
- package/components/tags-input/tags-input.js +5 -2
- package/components/template-ng/template-ng.js +1 -1
- package/components/tooltip/tooltip.js +7 -2
- package/components/user-agreement/user-agreement.css +1 -1
- package/components/user-agreement/user-agreement.examples.js +7 -4
- package/components/user-agreement/user-agreement.js +1 -0
- package/dist/_helpers/_rollupPluginBabelHelpers.js +1 -94
- package/dist/_helpers/anchor.js +6 -6
- package/dist/_helpers/badge.js +1 -1
- package/dist/_helpers/button-group.js +3 -0
- package/dist/_helpers/button-set.js +3 -0
- package/dist/_helpers/button-toolbar.js +3 -0
- package/dist/_helpers/button__classes.js +1 -1
- package/dist/_helpers/card.js +6 -8
- package/dist/_helpers/checkbox.js +3 -0
- package/dist/_helpers/date-picker.js +1 -1
- package/dist/_helpers/dialog__body-scroll-preventer.js +3 -2
- package/dist/_helpers/error-message.js +3 -0
- package/dist/_helpers/footer.js +121 -0
- package/dist/_helpers/grid.js +1 -1
- package/dist/_helpers/group.js +3 -0
- package/dist/_helpers/header.js +1 -1
- package/dist/_helpers/icon.js +3 -0
- package/dist/_helpers/inject-styles.js +1 -1
- package/dist/_helpers/input.js +3 -0
- package/dist/_helpers/island.js +1 -1
- package/dist/_helpers/link.js +3 -0
- package/dist/_helpers/list.js +1 -1
- package/dist/_helpers/loader-screen.js +3 -0
- package/dist/_helpers/panel.js +3 -0
- package/dist/_helpers/query-assist__suggestions.js +1 -1
- package/dist/_helpers/radio.js +3 -0
- package/dist/_helpers/select__filter.js +6 -8
- package/dist/_helpers/services-link.js +6 -8
- package/dist/_helpers/sidebar.js +6 -8
- package/dist/_helpers/table.js +1 -1
- package/dist/_helpers/tabs.js +1 -1
- package/dist/_helpers/title.js +1 -1
- package/dist/alert/alert.js +15 -9
- package/dist/alert/container.js +7 -9
- package/dist/alert-service/alert-service.js +24 -13
- package/dist/analytics/analytics.js +2 -2
- package/dist/analytics/analytics__custom-plugin.js +1 -1
- package/dist/analytics/analytics__fus-plugin.js +2 -2
- package/dist/analytics/analytics__ga-plugin.js +1 -1
- package/dist/analytics/analytics__plugin-utils.js +1 -1
- package/dist/analytics-ng/analytics-ng.js +94 -0
- package/dist/auth/auth.js +7 -4
- package/dist/auth/auth__core.js +86 -48
- package/dist/auth/background-flow.js +1 -2
- package/dist/auth/down-notification.js +6 -3
- package/dist/auth/iframe-flow.js +5 -2
- package/dist/auth/landing-entry.js +1 -1
- package/dist/auth/landing.js +5 -2
- package/dist/auth/request-builder.js +1 -1
- package/dist/auth/response-parser.js +1 -1
- package/dist/auth/storage.js +3 -2
- package/dist/auth/token-validator.js +1 -1
- package/dist/auth/window-flow.js +1 -1
- package/dist/auth-dialog/auth-dialog.js +5 -3
- package/dist/auth-dialog-service/auth-dialog-service.js +6 -5
- package/dist/auth-ng/auth-ng.js +203 -0
- package/dist/auth-ng/auth-ng.mock.js +33 -0
- package/dist/autofocus-ng/autofocus-ng.js +50 -0
- package/dist/avatar/avatar.js +36 -30
- package/dist/avatar/fallback-avatar.js +141 -0
- package/dist/avatar-editor-ng/avatar-editor-ng.js +164 -0
- package/dist/avatar-editor-ng/avatar-editor-ng__template.js +30 -0
- package/dist/avatar-ng/avatar-ng.js +18 -0
- package/dist/badge/badge.js +6 -8
- package/dist/badge-ng/badge-ng.js +16 -0
- package/dist/breadcrumb-ng/breadcrumb-ng.js +61 -0
- package/dist/button/button.js +16 -10
- package/dist/button-group/button-group.js +4 -4
- package/dist/button-group/caption.js +24 -5
- package/dist/button-group-ng/button-group-ng.js +38 -0
- package/dist/button-ng/button-ng.js +223 -0
- package/dist/button-set/button-set.js +3 -4
- package/dist/button-set-ng/button-set-ng.js +19 -0
- package/dist/button-toolbar/button-toolbar.js +3 -4
- package/dist/button-toolbar-ng/button-toolbar-ng.js +23 -0
- package/dist/caret/caret.js +1 -1
- package/dist/checkbox/checkbox.js +9 -11
- package/dist/checkbox-ng/checkbox-ng.js +55 -0
- package/dist/code/code.js +136 -0
- package/dist/compiler-ng/compiler-ng.js +53 -0
- package/dist/confirm/confirm.js +6 -3
- package/dist/confirm-ng/confirm-ng.js +66 -0
- package/dist/confirm-service/confirm-service.js +12 -10
- package/dist/content-layout/content-layout.js +6 -8
- package/dist/contenteditable/contenteditable.js +13 -16
- package/dist/data-list/data-list.js +10 -7
- package/dist/data-list/data-list.mock.js +2 -2
- package/dist/data-list/item.js +5 -3
- package/dist/data-list/selection.js +1 -1
- package/dist/data-list/title.js +3 -1
- package/dist/data-list-ng/data-list-ng.js +59 -0
- package/dist/date-picker/consts.js +1 -2
- package/dist/date-picker/date-input.js +10 -6
- package/dist/date-picker/date-picker.js +38 -29
- package/dist/date-picker/date-popup.js +51 -28
- package/dist/date-picker/day.js +2 -2
- package/dist/date-picker/formats.js +1 -1
- package/dist/date-picker/month-names.js +16 -9
- package/dist/date-picker/month-slider.js +2 -2
- package/dist/date-picker/month.js +13 -7
- package/dist/date-picker/months.js +3 -3
- package/dist/date-picker/weekdays.js +12 -4
- package/dist/date-picker/years.js +2 -2
- package/dist/dialog/dialog.js +13 -10
- package/dist/dialog/dialog__body-scroll-preventer.js +1 -1
- package/dist/dialog-ng/dialog-ng.js +601 -0
- package/dist/dialog-ng/dialog-ng__template.js +71 -0
- package/dist/docked-panel-ng/docked-panel-ng.js +170 -0
- package/dist/dropdown/anchor.js +2 -1
- package/dist/dropdown/dropdown.js +8 -10
- package/dist/dropdown-menu/dropdown-menu.js +175 -0
- package/dist/error-bubble/error-bubble.js +7 -9
- package/dist/error-message/error-message.js +4 -4
- package/dist/error-message-ng/error-message-ng.js +53 -0
- package/dist/footer/footer.js +6 -122
- package/dist/footer-ng/footer-ng.js +75 -0
- package/dist/form-ng/form-ng.js +169 -0
- package/dist/global/angular-component-factory.js +1 -2
- package/dist/global/compose.js +1 -1
- package/dist/global/composeRefs.js +1 -1
- package/dist/global/conic-gradient.js +3 -5
- package/dist/global/create-stateful-context.js +1 -1
- package/dist/global/data-tests.js +1 -1
- package/dist/global/focus-sensor-hoc.js +9 -11
- package/dist/global/fuzzy-highlight.js +1 -1
- package/dist/global/get-event-key.js +1 -1
- package/dist/global/get-uid.js +1 -1
- package/dist/global/linear-function.js +1 -2
- package/dist/global/listeners.js +1 -1
- package/dist/global/memoize.js +1 -1
- package/dist/global/normalize-indent.js +1 -1
- package/dist/global/promise-with-timeout.js +1 -1
- package/dist/global/radial-gradient-mask.js +1 -1
- package/dist/global/react-dom-renderer.js +1 -1
- package/dist/global/rerender-hoc.js +3 -5
- package/dist/global/ring-angular-component.js +1 -1
- package/dist/global/schedule-raf.js +1 -1
- package/dist/global/sniffer.js +1 -1
- package/dist/global/supports-css.js +1 -1
- package/dist/global/theme.js +6 -8
- package/dist/global/trivial-template-tag.js +1 -1
- package/dist/global/variables_dark.js +1 -1
- package/dist/grid/col.js +6 -8
- package/dist/grid/grid.js +5 -7
- package/dist/grid/row.js +6 -8
- package/dist/group/group.js +7 -10
- package/dist/group-ng/group-ng.js +11 -0
- package/dist/header/header.js +29 -26
- package/dist/header/logo.js +8 -9
- package/dist/header/profile.js +37 -32
- package/dist/header/services-link.js +1 -0
- package/dist/header/services.js +10 -9
- package/dist/header/smart-profile.js +27 -24
- package/dist/header/smart-services.js +10 -9
- package/dist/header/tray-icon.js +12 -12
- package/dist/header/tray.js +6 -8
- package/dist/heading/heading.js +9 -12
- package/dist/http/http.js +37 -37
- package/dist/http/http.mock.js +4 -4
- package/dist/hub-source/hub-source.js +1 -1
- package/dist/hub-source/hub-source__users-groups.js +1 -1
- package/dist/icon/icon.js +8 -8
- package/dist/icon/icon__svg.js +81 -6
- package/dist/icon/index.js +2 -1
- package/dist/icon-ng/icon-ng.js +89 -0
- package/dist/input/input.js +9 -12
- package/dist/input-ng/input-ng.js +166 -0
- package/dist/island/adaptive-island-hoc.js +1 -2
- package/dist/island/content.js +6 -8
- package/dist/island/header.js +6 -8
- package/dist/island/island.js +6 -9
- package/dist/island-legacy/content-legacy.js +6 -8
- package/dist/island-legacy/header-legacy.js +6 -8
- package/dist/island-legacy/island-legacy.js +6 -8
- package/dist/island-ng/island-content-ng.js +56 -0
- package/dist/island-ng/island-header-ng.js +32 -0
- package/dist/island-ng/island-ng-class-fixer.js +9 -0
- package/dist/island-ng/island-ng.js +31 -0
- package/dist/link/clickableLink.js +6 -8
- package/dist/link/link.js +7 -11
- package/dist/link-ng/link-ng.js +25 -0
- package/dist/list/list.js +25 -13
- package/dist/list/list__custom.js +13 -10
- package/dist/list/list__hint.js +1 -1
- package/dist/list/list__item.js +20 -13
- package/dist/list/list__link.js +11 -12
- package/dist/list/list__separator.js +1 -1
- package/dist/list/list__title.js +1 -1
- package/dist/list/list__users-groups-source.js +11 -7
- package/dist/loader/loader.js +6 -8
- package/dist/loader/loader__core.js +2 -2
- package/dist/loader-inline/inject-styles.js +1 -1
- package/dist/loader-inline/loader-inline.js +6 -8
- package/dist/loader-inline-ng/loader-inline-ng.js +42 -0
- package/dist/loader-ng/loader-ng.js +43 -0
- package/dist/loader-screen/loader-screen.js +7 -10
- package/dist/loader-screen-ng/loader-screen-ng.js +99 -0
- package/dist/login-dialog/login-dialog.js +5 -3
- package/dist/login-dialog/service.js +7 -5
- package/dist/markdown/code.js +30 -0
- package/dist/markdown/heading.js +23 -0
- package/dist/markdown/link.js +30 -0
- package/dist/markdown/markdown.js +73 -0
- package/dist/message/message.js +5 -4
- package/dist/message-bundle-ng/message-bundle-ng.js +111 -0
- package/dist/old-browsers-message/old-browsers-message.js +0 -1
- package/dist/old-browsers-message/old-browsers-message__stop.js +0 -1
- package/dist/old-browsers-message/white-list.js +4 -5
- package/dist/pager/pager.js +18 -9
- package/dist/pager-ng/pager-ng.js +96 -0
- package/dist/panel/panel.js +7 -10
- package/dist/panel-ng/panel-ng.js +16 -0
- package/dist/permissions/permissions.js +1 -1
- package/dist/permissions/permissions__cache.js +1 -1
- package/dist/permissions-ng/permissions-ng.js +274 -0
- package/dist/place-under-ng/place-under-ng.js +157 -0
- package/dist/popup/popup.js +8 -8
- package/dist/popup/popup.target.js +4 -5
- package/dist/popup/position.js +1 -2
- package/dist/popup-menu/popup-menu.js +21 -14
- package/dist/progress-bar/progress-bar.js +12 -10
- package/dist/progress-bar-ng/progress-bar-ng.js +15 -0
- package/dist/promised-click-ng/promised-click-ng.js +126 -0
- package/dist/proxy-attrs/proxy-attrs.js +1 -1
- package/dist/query-assist/query-assist.js +97 -28
- package/dist/query-assist/query-assist__suggestions.js +5 -1
- package/dist/query-assist-ng/query-assist-ng.js +82 -0
- package/dist/radio/radio.js +7 -5
- package/dist/radio/radio__item.js +10 -15
- package/dist/radio-ng/radio-ng.js +63 -0
- package/dist/save-field-ng/save-field-ng.js +335 -0
- package/dist/save-field-ng/save-field-ng__template.js +34 -0
- package/dist/select/select.js +50 -49
- package/dist/select/select__filter.js +6 -1
- package/dist/select/select__popup.js +8 -3
- package/dist/select-ng/select-ng.js +621 -0
- package/dist/select-ng/select-ng__lazy.js +150 -0
- package/dist/select-ng/select-ng__options.js +145 -0
- package/dist/shortcuts/core.js +2 -2
- package/dist/shortcuts/shortcuts-hoc.js +6 -8
- package/dist/shortcuts/shortcuts.js +6 -6
- package/dist/shortcuts-hint-ng/shortcuts-hint-ng.js +120 -0
- package/dist/shortcuts-hint-ng/shortcuts-hint-ng__template.js +50 -0
- package/dist/shortcuts-ng/shortcuts-ng.js +261 -0
- package/dist/sidebar-ng/sidebar-ng.js +111 -0
- package/dist/sidebar-ng/sidebar-ng__button-template.js +20 -0
- package/dist/sidebar-ng/sidebar-ng__template.js +12 -0
- package/dist/storage/storage.js +3 -2
- package/dist/storage/storage__fallback.js +1 -1
- package/dist/storage/storage__local.js +3 -2
- package/dist/style.css +1 -1
- package/dist/tab-trap/tab-trap.js +7 -9
- package/dist/table/cell.js +2 -2
- package/dist/table/disable-hover-hoc.js +2 -2
- package/dist/table/header-cell.js +8 -9
- package/dist/table/header.js +5 -3
- package/dist/table/multitable.js +1 -1
- package/dist/table/row-with-focus-sensor.js +5 -3
- package/dist/table/row.js +11 -10
- package/dist/table/selection-adapter.js +1 -1
- package/dist/table/selection-shortcuts-hoc.js +8 -6
- package/dist/table/selection.js +1 -1
- package/dist/table/smart-table.js +14 -8
- package/dist/table/table.js +10 -11
- package/dist/table-legacy-ng/table-legacy-ng.js +501 -0
- package/dist/table-legacy-ng/table-legacy-ng__pager.js +122 -0
- package/dist/table-legacy-ng/table-legacy-ng__selection-navigate-actions.js +123 -0
- package/dist/table-legacy-ng/table-legacy-ng__selection.js +179 -0
- package/dist/table-legacy-ng/table-legacy-ng__toolbar.js +56 -0
- package/dist/table-ng/smart-table-ng.js +65 -0
- package/dist/table-ng/table-ng.js +64 -0
- package/dist/tabs/collapsible-more.js +9 -6
- package/dist/tabs/collapsible-tab.js +7 -7
- package/dist/tabs/collapsible-tabs.js +18 -19
- package/dist/tabs/dumb-tabs.js +12 -9
- package/dist/tabs/smart-tabs.js +11 -9
- package/dist/tabs/tab-link.js +13 -7
- package/dist/tabs/tab.js +1 -1
- package/dist/tabs/tabs.js +5 -1
- package/dist/tabs-ng/tabs-ng.js +193 -0
- package/dist/tabs-ng/tabs-ng__template.js +40 -0
- package/dist/tag/tag.js +20 -14
- package/dist/tags-input/tags-input.js +14 -10
- package/dist/tags-input-ng/tags-input-ng.js +89 -0
- package/dist/tags-list/tags-list.js +8 -9
- package/dist/template-ng/template-ng.js +70 -0
- package/dist/text/text.js +7 -9
- package/dist/theme-ng/theme-ng.js +44 -0
- package/dist/title-ng/title-ng.js +114 -0
- package/dist/toggle/toggle.js +8 -11
- package/dist/toggle-ng/toggle-ng.js +16 -0
- package/dist/tooltip/tooltip.js +14 -12
- package/dist/tooltip-ng/tooltip-ng.js +98 -0
- package/dist/user-agreement/service.js +409 -0
- package/dist/user-agreement/toolbox.eula.js +162 -0
- package/dist/user-agreement/user-agreement.js +167 -0
- package/dist/user-card/card.js +3 -0
- package/dist/user-card/smart-user-card-tooltip.js +14 -14
- package/dist/user-card/tooltip.js +9 -7
- package/dist/user-card/user-card.js +5 -2
- package/dist/user-card-ng/user-card-ng.js +59 -0
- package/package.json +81 -79
- package/webpack.config.js +14 -10
- package/components/button-set-ng/button-set-ng.html +0 -1
- package/components/footer-ng/footer-ng.html +0 -13
- package/components/form-ng/form-ng__error-bubble.html +0 -3
- package/components/table-legacy-ng/table-legacy-ng.html +0 -4
- package/components/table-legacy-ng/table-legacy-ng__column.html +0 -12
- package/components/table-legacy-ng/table-legacy-ng__header.html +0 -4
- package/components/table-legacy-ng/table-legacy-ng__pager.html +0 -7
- package/components/table-legacy-ng/table-legacy-ng__row.html +0 -12
- package/components/table-legacy-ng/table-legacy-ng__title.html +0 -9
- package/dist/_helpers/caption.js +0 -25
- package/dist/_helpers/icon__svg.js +0 -83
package/dist/radio/radio.js
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { _ as _defineProperty
|
|
1
|
+
import { _ as _defineProperty } from '../_helpers/_rollupPluginBabelHelpers.js';
|
|
2
2
|
import React, { Component } from 'react';
|
|
3
3
|
import PropTypes from 'prop-types';
|
|
4
4
|
import getUID from '../global/get-uid.js';
|
|
5
5
|
import RadioItem, { RadioContext } from './radio__item.js';
|
|
6
6
|
import 'classnames';
|
|
7
|
+
import '../_helpers/radio.js';
|
|
7
8
|
|
|
8
9
|
/**
|
|
9
10
|
* @name Radio
|
|
@@ -18,9 +19,10 @@ class Radio extends Component {
|
|
|
18
19
|
|
|
19
20
|
render() {
|
|
20
21
|
return /*#__PURE__*/React.createElement(RadioContext.Provider, {
|
|
21
|
-
value:
|
|
22
|
-
name: this.uid
|
|
23
|
-
|
|
22
|
+
value: {
|
|
23
|
+
name: this.uid,
|
|
24
|
+
...this.props
|
|
25
|
+
}
|
|
24
26
|
}, this.props.children);
|
|
25
27
|
}
|
|
26
28
|
|
|
@@ -36,4 +38,4 @@ _defineProperty(Radio, "propTypes", {
|
|
|
36
38
|
|
|
37
39
|
_defineProperty(Radio, "Item", RadioItem);
|
|
38
40
|
|
|
39
|
-
export default
|
|
41
|
+
export { Radio as default };
|
|
@@ -1,10 +1,9 @@
|
|
|
1
|
-
import { _ as _defineProperty, a as
|
|
1
|
+
import { _ as _defineProperty, a as _extends } from '../_helpers/_rollupPluginBabelHelpers.js';
|
|
2
2
|
import React, { createContext, Component, forwardRef } from 'react';
|
|
3
3
|
import PropTypes from 'prop-types';
|
|
4
4
|
import classNames from 'classnames';
|
|
5
5
|
import getUID from '../global/get-uid.js';
|
|
6
|
-
|
|
7
|
-
var modules_df92307a = {"unit":"8px","radio-size":"16px","radio":"radio_radio__ebe39b0d","circle":"radio_circle__ebe39b0d","input":"radio_input__ebe39b0d","focus":"radio_focus__ebe39b0d","label":"radio_label__ebe39b0d"};
|
|
6
|
+
import { m as modules_df92307a } from '../_helpers/radio.js';
|
|
8
7
|
|
|
9
8
|
const RadioContext = /*#__PURE__*/createContext({});
|
|
10
9
|
class Radio extends Component {
|
|
@@ -23,13 +22,11 @@ class Radio extends Component {
|
|
|
23
22
|
}
|
|
24
23
|
|
|
25
24
|
render() {
|
|
26
|
-
const
|
|
27
|
-
{
|
|
25
|
+
const {
|
|
28
26
|
className,
|
|
29
|
-
children
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
27
|
+
children,
|
|
28
|
+
...restProps
|
|
29
|
+
} = this.props;
|
|
33
30
|
const classes = classNames(modules_df92307a.radio, className);
|
|
34
31
|
return /*#__PURE__*/React.createElement("label", {
|
|
35
32
|
ref: this.labelRef,
|
|
@@ -64,10 +61,9 @@ const RadioItem = /*#__PURE__*/forwardRef(function RadioItem(props, ref) {
|
|
|
64
61
|
return /*#__PURE__*/React.createElement(RadioContext.Consumer, null, _ref => {
|
|
65
62
|
let {
|
|
66
63
|
value,
|
|
67
|
-
onChange
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
64
|
+
onChange,
|
|
65
|
+
...restContext
|
|
66
|
+
} = _ref;
|
|
71
67
|
return /*#__PURE__*/React.createElement(Radio, _extends({
|
|
72
68
|
ref: ref
|
|
73
69
|
}, restContext, {
|
|
@@ -78,5 +74,4 @@ const RadioItem = /*#__PURE__*/forwardRef(function RadioItem(props, ref) {
|
|
|
78
74
|
});
|
|
79
75
|
RadioItem.propTypes = Radio.propTypes;
|
|
80
76
|
|
|
81
|
-
export default
|
|
82
|
-
export { Radio, RadioContext };
|
|
77
|
+
export { Radio, RadioContext, RadioItem as default };
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import angular from 'angular';
|
|
2
|
+
import { m as modules_df92307a } from '../_helpers/radio.js';
|
|
3
|
+
import proxyAttrs from '../proxy-attrs/proxy-attrs.js';
|
|
4
|
+
import getUID from '../global/get-uid.js';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* @name Radio Ng
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
const angularModule = angular.module('Ring.radio', []);
|
|
11
|
+
angularModule.directive('rgRadio', function rgCheckboxDirective() {
|
|
12
|
+
return {
|
|
13
|
+
restrict: 'E',
|
|
14
|
+
transclude: true,
|
|
15
|
+
replace: true,
|
|
16
|
+
template: proxyAttrs(`
|
|
17
|
+
<label class="${modules_df92307a.radio}" data-test="ring-radio">
|
|
18
|
+
<input
|
|
19
|
+
type="radio"
|
|
20
|
+
class=${modules_df92307a.input}
|
|
21
|
+
|
|
22
|
+
data-proxy-ng-disabled
|
|
23
|
+
data-proxy-ng-model
|
|
24
|
+
data-proxy-ng-change
|
|
25
|
+
data-proxy-name
|
|
26
|
+
data-proxy-value
|
|
27
|
+
data-proxy-ng-value
|
|
28
|
+
/>
|
|
29
|
+
<span class="${modules_df92307a.circle}"></span><span
|
|
30
|
+
class="${modules_df92307a.label}" ng-transclude></span>
|
|
31
|
+
</label>
|
|
32
|
+
|
|
33
|
+
`),
|
|
34
|
+
link: function link(scope, iElement) {
|
|
35
|
+
const element = iElement[0];
|
|
36
|
+
const input = element.querySelector('input[type="radio"]');
|
|
37
|
+
|
|
38
|
+
function applyPassedID() {
|
|
39
|
+
const {
|
|
40
|
+
id
|
|
41
|
+
} = element;
|
|
42
|
+
element.setAttribute('for', id);
|
|
43
|
+
input.setAttribute('id', id);
|
|
44
|
+
element.removeAttribute('id');
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
function generateID() {
|
|
48
|
+
const id = getUID('ring-radio-item-');
|
|
49
|
+
element.setAttribute('for', id);
|
|
50
|
+
input.setAttribute('id', id);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
if (element.id) {
|
|
54
|
+
applyPassedID();
|
|
55
|
+
} else {
|
|
56
|
+
generateID();
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
});
|
|
61
|
+
var radioNg = angularModule.name;
|
|
62
|
+
|
|
63
|
+
export { radioNg as default };
|
|
@@ -0,0 +1,335 @@
|
|
|
1
|
+
import angular from 'angular';
|
|
2
|
+
import '../loader-inline/loader-inline.js';
|
|
3
|
+
import ButtonSet from '../button-set-ng/button-set-ng.js';
|
|
4
|
+
import MessageBundle from '../message-bundle-ng/message-bundle-ng.js';
|
|
5
|
+
import Form from '../form-ng/form-ng.js';
|
|
6
|
+
import ShortcutsNg from '../shortcuts-ng/shortcuts-ng.js';
|
|
7
|
+
import ButtonNG from '../button-ng/button-ng.js';
|
|
8
|
+
import PromisedClick from '../promised-click-ng/promised-click-ng.js';
|
|
9
|
+
import template from './save-field-ng__template.js';
|
|
10
|
+
import '../_helpers/_rollupPluginBabelHelpers.js';
|
|
11
|
+
import 'react';
|
|
12
|
+
import 'classnames';
|
|
13
|
+
import 'prop-types';
|
|
14
|
+
import '../global/theme.js';
|
|
15
|
+
import '../global/data-tests.js';
|
|
16
|
+
import '../_helpers/inject-styles.js';
|
|
17
|
+
import '../global/conic-gradient.js';
|
|
18
|
+
import 'conic-gradient';
|
|
19
|
+
import '../global/memoize.js';
|
|
20
|
+
import '../global/supports-css.js';
|
|
21
|
+
import '../global/inject-styles.js';
|
|
22
|
+
import '../global/radial-gradient-mask.js';
|
|
23
|
+
import '../global/get-uid.js';
|
|
24
|
+
import '../_helpers/button-set.js';
|
|
25
|
+
import '@jetbrains/angular-elastic';
|
|
26
|
+
import '../global/dom.js';
|
|
27
|
+
import '../shortcuts/core.js';
|
|
28
|
+
import 'combokeys';
|
|
29
|
+
import '../global/sniffer.js';
|
|
30
|
+
import 'sniffr';
|
|
31
|
+
import '../global/ring-angular-component.js';
|
|
32
|
+
import '../icon-ng/icon-ng.js';
|
|
33
|
+
import '../icon/icon__constants.js';
|
|
34
|
+
import '../template-ng/template-ng.js';
|
|
35
|
+
import '../_helpers/icon.js';
|
|
36
|
+
import '../_helpers/button__classes.js';
|
|
37
|
+
|
|
38
|
+
const angularModule = angular.module('Ring.save-field', [MessageBundle,
|
|
39
|
+
/**
|
|
40
|
+
* for error-bubble
|
|
41
|
+
*/
|
|
42
|
+
Form, ShortcutsNg, ButtonNG, ButtonSet, PromisedClick]);
|
|
43
|
+
angularModule.constant('rgSaveFieldShortcutsMode', {
|
|
44
|
+
id: 'ring-save-field',
|
|
45
|
+
shortcuts: [{
|
|
46
|
+
key: 'ctrl+enter',
|
|
47
|
+
action: 'comboSubmit'
|
|
48
|
+
}, {
|
|
49
|
+
key: 'enter',
|
|
50
|
+
action: 'submit'
|
|
51
|
+
}, {
|
|
52
|
+
key: 'esc',
|
|
53
|
+
action: 'cancel'
|
|
54
|
+
}, {
|
|
55
|
+
key: 'up',
|
|
56
|
+
action: 'noop'
|
|
57
|
+
}, {
|
|
58
|
+
key: 'down',
|
|
59
|
+
action: 'noop'
|
|
60
|
+
}]
|
|
61
|
+
});
|
|
62
|
+
angularModule.directive('rgSaveField', ["RingMessageBundle", "$timeout", "$q", "$compile", "$parse", function rgSaveFieldDirective(RingMessageBundle, $timeout, $q, $compile, $parse) {
|
|
63
|
+
const MULTI_LINE_SPLIT_PATTERN = /(\r\n|\n|\r)/gm;
|
|
64
|
+
const MULTI_LINE_LIST_MODE = 'list';
|
|
65
|
+
const CUSTOM_ERROR_ID = 'customError';
|
|
66
|
+
const ERROR_DESCRIPTION = 'error_description';
|
|
67
|
+
const ERROR_DEVELOPER_MSG = 'error_developer_message';
|
|
68
|
+
return {
|
|
69
|
+
require: 'rgSaveField',
|
|
70
|
+
transclude: true,
|
|
71
|
+
template,
|
|
72
|
+
scope: {
|
|
73
|
+
api: '=?',
|
|
74
|
+
value: '=',
|
|
75
|
+
workingValue: '=',
|
|
76
|
+
onSave: '&',
|
|
77
|
+
afterSave: '&?',
|
|
78
|
+
validate: '&?',
|
|
79
|
+
parseElement: '&?',
|
|
80
|
+
formatElement: '&?',
|
|
81
|
+
multiline: '@'
|
|
82
|
+
},
|
|
83
|
+
link: function link(scope, iElem, iAttrs, ctrl) {
|
|
84
|
+
const placeholder = angular.element(iElem[0].querySelector('.ring-save-field__transclude-placeholder'));
|
|
85
|
+
$compile(angular.element('<div rg-error-bubble="saveFieldForm"></div>'))(scope, errorBubble => {
|
|
86
|
+
placeholder.append(errorBubble);
|
|
87
|
+
});
|
|
88
|
+
const customError = {
|
|
89
|
+
message: ''
|
|
90
|
+
};
|
|
91
|
+
let isTextarea = false;
|
|
92
|
+
const draftMode = iAttrs.workingValue;
|
|
93
|
+
const valueField = draftMode ? 'workingValue' : 'value';
|
|
94
|
+
|
|
95
|
+
function submitChanges() {
|
|
96
|
+
if (!scope.saveFieldForm.$valid || scope.loading || angular.equals(scope.initial, scope[valueField])) {
|
|
97
|
+
return false;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
function afterSaveCall() {
|
|
101
|
+
return $q.when(scope.afterSave({
|
|
102
|
+
value: scope[valueField]
|
|
103
|
+
}));
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
function success() {
|
|
107
|
+
scope.initial = angular.copy(scope[valueField]);
|
|
108
|
+
scope.saveFieldForm.$setPristine();
|
|
109
|
+
scope.done = true;
|
|
110
|
+
|
|
111
|
+
if (draftMode) {
|
|
112
|
+
scope.value = scope.workingValue;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
$timeout(() => {
|
|
116
|
+
scope.done = false;
|
|
117
|
+
}, 1000); //eslint-disable-line no-magic-numbers
|
|
118
|
+
|
|
119
|
+
if (scope.afterSave) {
|
|
120
|
+
if (draftMode) {
|
|
121
|
+
return $timeout(afterSaveCall); // we need digest to sync value before calling after save
|
|
122
|
+
} else {
|
|
123
|
+
return afterSaveCall();
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
return undefined;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
function error(err) {
|
|
131
|
+
let message;
|
|
132
|
+
|
|
133
|
+
if (typeof err === 'string') {
|
|
134
|
+
message = err;
|
|
135
|
+
} else if (typeof err === 'object') {
|
|
136
|
+
const errorData = err.data || err;
|
|
137
|
+
message = errorData[ERROR_DESCRIPTION] || errorData[ERROR_DEVELOPER_MSG];
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
customError.message = message;
|
|
141
|
+
scope.saveFieldForm.$setValidity(CUSTOM_ERROR_ID, false, customError);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
scope.cancelBlur();
|
|
145
|
+
scope.loading = true;
|
|
146
|
+
let onsave = ctrl.getSave();
|
|
147
|
+
|
|
148
|
+
if (onsave) {
|
|
149
|
+
onsave = $q.when(onsave(scope[valueField]));
|
|
150
|
+
} else {
|
|
151
|
+
onsave = $q.when(scope.onSave({
|
|
152
|
+
value: scope[valueField]
|
|
153
|
+
}));
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
return onsave.then(success, error).then(() => {
|
|
157
|
+
scope.loading = false;
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
function resetValue() {
|
|
162
|
+
if (scope.loading) {
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
scope.$evalAsync(() => {
|
|
167
|
+
scope[valueField] = scope.initial ? scope.initial : '';
|
|
168
|
+
scope.saveFieldForm.$setValidity(CUSTOM_ERROR_ID, true, customError);
|
|
169
|
+
scope.saveFieldForm.$setPristine();
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
function addMultilineProcessing(controlName) {
|
|
174
|
+
const stopWatch = scope.$watch(`saveFieldForm.${controlName}`, control => {
|
|
175
|
+
if (!control || !control.$formatters || !control.$parsers) {
|
|
176
|
+
return;
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
control.$formatters.push(value => {
|
|
180
|
+
if (!value) {
|
|
181
|
+
return value;
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
let formattedValue;
|
|
185
|
+
|
|
186
|
+
if (iAttrs.formatElement) {
|
|
187
|
+
formattedValue = value.map(element => scope.formatElement({
|
|
188
|
+
element
|
|
189
|
+
}));
|
|
190
|
+
} else {
|
|
191
|
+
formattedValue = value;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
return formattedValue.join('\n');
|
|
195
|
+
});
|
|
196
|
+
control.$parsers.push(value => {
|
|
197
|
+
let array = value && value.split(MULTI_LINE_SPLIT_PATTERN) || [];
|
|
198
|
+
|
|
199
|
+
function notEmpty(val) {
|
|
200
|
+
return val && val.trim() && val !== '\n';
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
array = array.filter(notEmpty);
|
|
204
|
+
|
|
205
|
+
if (iAttrs.parseElement) {
|
|
206
|
+
array = array.map(element => scope.parseElement({
|
|
207
|
+
element: element.trim()
|
|
208
|
+
}));
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
return array;
|
|
212
|
+
});
|
|
213
|
+
stopWatch();
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
scope.cancelBlur = () => {
|
|
218
|
+
$timeout(() => {
|
|
219
|
+
|
|
220
|
+
}, 10);
|
|
221
|
+
};
|
|
222
|
+
|
|
223
|
+
if (draftMode) {
|
|
224
|
+
scope.$watch('value', value => {
|
|
225
|
+
scope.workingValue = angular.copy(value);
|
|
226
|
+
scope.initial = value;
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
scope.$watch(valueField, value => {
|
|
231
|
+
let promise = null;
|
|
232
|
+
|
|
233
|
+
if (scope.saveFieldForm.$pristine) {
|
|
234
|
+
scope.initial = value;
|
|
235
|
+
} else if (scope.initial && angular.equals(scope.initial, value)) {
|
|
236
|
+
resetValue();
|
|
237
|
+
} else if (scope.validate) {
|
|
238
|
+
promise = scope.validate({
|
|
239
|
+
value
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
|
|
243
|
+
$q.when(promise).then(error => {
|
|
244
|
+
if (error) {
|
|
245
|
+
return $q.reject(error);
|
|
246
|
+
} else {
|
|
247
|
+
customError.message = '';
|
|
248
|
+
scope.saveFieldForm.$setValidity(CUSTOM_ERROR_ID, true, customError);
|
|
249
|
+
return undefined;
|
|
250
|
+
}
|
|
251
|
+
}).catch(error => {
|
|
252
|
+
customError.message = error;
|
|
253
|
+
scope.saveFieldForm.$setValidity(CUSTOM_ERROR_ID, false, customError);
|
|
254
|
+
});
|
|
255
|
+
});
|
|
256
|
+
let inputNode = iElem[0].querySelector('input, .ring-save-field__input');
|
|
257
|
+
|
|
258
|
+
if (!inputNode) {
|
|
259
|
+
inputNode = iElem[0].querySelector('textarea');
|
|
260
|
+
isTextarea = !!inputNode;
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
if (inputNode) {
|
|
264
|
+
inputNode.classList.add('ring-js-shortcuts');
|
|
265
|
+
inputNode.addEventListener('focus', () => {
|
|
266
|
+
scope.$evalAsync(() => {
|
|
267
|
+
scope.focus = true;
|
|
268
|
+
});
|
|
269
|
+
});
|
|
270
|
+
inputNode.addEventListener('blur', () => {
|
|
271
|
+
scope.$evalAsync(() => {
|
|
272
|
+
scope.focus = false;
|
|
273
|
+
});
|
|
274
|
+
});
|
|
275
|
+
|
|
276
|
+
if (isTextarea && scope.multiline === MULTI_LINE_LIST_MODE) {
|
|
277
|
+
addMultilineProcessing(inputNode.name);
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
scope.wording = {
|
|
282
|
+
save: RingMessageBundle.form_save(),
|
|
283
|
+
saved: RingMessageBundle.form_saved(),
|
|
284
|
+
cancel: RingMessageBundle.form_cancel()
|
|
285
|
+
};
|
|
286
|
+
scope.keyMap = {
|
|
287
|
+
comboSubmit: e => {
|
|
288
|
+
if (isTextarea) {
|
|
289
|
+
e.preventDefault();
|
|
290
|
+
submitChanges();
|
|
291
|
+
}
|
|
292
|
+
},
|
|
293
|
+
submit: e => {
|
|
294
|
+
if (!isTextarea) {
|
|
295
|
+
e.preventDefault();
|
|
296
|
+
submitChanges();
|
|
297
|
+
}
|
|
298
|
+
},
|
|
299
|
+
cancel: resetValue,
|
|
300
|
+
noop: angular.noop
|
|
301
|
+
};
|
|
302
|
+
scope.api = {
|
|
303
|
+
save: submitChanges,
|
|
304
|
+
cancel: resetValue
|
|
305
|
+
};
|
|
306
|
+
scope.submitChanges = ctrl.submitChanges = submitChanges;
|
|
307
|
+
scope.cancelChanges = ctrl.cancelChanges = resetValue;
|
|
308
|
+
scope.focus = false;
|
|
309
|
+
scope.$on('$destroy', () => {
|
|
310
|
+
// 1) Bindings are already disabled by this time, so replacing scope.value = ... has no effect
|
|
311
|
+
// 2) We can't use scope.value.someField because we don't know anything about scope.value, it's passed from the outside
|
|
312
|
+
// 3) Probably we can use controllerAs to add one more object layer (ctrl.value) so the JS linking would work
|
|
313
|
+
// but errorBubble works with scope only, so a large refactoring of rgSaveField and other components is needed.
|
|
314
|
+
// This is the simplest solution:
|
|
315
|
+
if (iAttrs.value) {
|
|
316
|
+
$parse(iAttrs.value).assign(scope.$parent, scope.initial);
|
|
317
|
+
}
|
|
318
|
+
});
|
|
319
|
+
},
|
|
320
|
+
|
|
321
|
+
controller() {
|
|
322
|
+
let onSave = null;
|
|
323
|
+
|
|
324
|
+
this.setSave = cb => {
|
|
325
|
+
onSave = cb;
|
|
326
|
+
};
|
|
327
|
+
|
|
328
|
+
this.getSave = () => onSave;
|
|
329
|
+
}
|
|
330
|
+
|
|
331
|
+
};
|
|
332
|
+
}]);
|
|
333
|
+
var saveFieldNg = angularModule.name;
|
|
334
|
+
|
|
335
|
+
export { saveFieldNg as default };
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
var template = `<div class="ring-save-field" ng-form="saveFieldForm" rg-shortcuts="ring-save-field" shortcuts-map="keyMap" shortcuts-focus="focus">
|
|
2
|
+
<span class="ring-save-field__transclude-placeholder" ng-transclude=""></span>
|
|
3
|
+
|
|
4
|
+
<rg-button
|
|
5
|
+
ng-show="saveFieldForm.$dirty && saveFieldForm.$valid"
|
|
6
|
+
mode="primary"
|
|
7
|
+
class="ring-save-field__button ng-hide"
|
|
8
|
+
ng-mousedown="cancelBlur()"
|
|
9
|
+
|
|
10
|
+
rg-promised-click="submitChanges($event)"
|
|
11
|
+
promised-mode="loader"
|
|
12
|
+
>
|
|
13
|
+
{{wording.save}}
|
|
14
|
+
</rg-button>
|
|
15
|
+
|
|
16
|
+
<rg-button
|
|
17
|
+
ng-show="saveFieldForm.$dirty && !loading"
|
|
18
|
+
class="ring-save-field__button ng-hide"
|
|
19
|
+
ng-click="cancelChanges($event)"
|
|
20
|
+
ng-mousedown="cancelBlur()"
|
|
21
|
+
>
|
|
22
|
+
{{wording.cancel}}
|
|
23
|
+
</rg-button>
|
|
24
|
+
|
|
25
|
+
<rg-button
|
|
26
|
+
ng-show="done"
|
|
27
|
+
ng-disabled="true"
|
|
28
|
+
class="ring-save-field__button ng-hide"
|
|
29
|
+
>
|
|
30
|
+
{{wording.saved}}
|
|
31
|
+
</rg-button>
|
|
32
|
+
</div>`;
|
|
33
|
+
|
|
34
|
+
export { template as default };
|