@bizdoc/core 1.14.12 → 1.14.15
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/assets/bizdoc-schema.json +146 -125
- package/assets/themes/brown.min.css +6 -6
- package/assets/themes/dark.min.css +6 -6
- package/assets/themes/deep-purple-light-blue.min.css +7 -7
- package/assets/themes/deep-purple-teal.min.css +7 -7
- package/assets/themes/default.min.css +7 -7
- package/assets/themes/green.min.css +6 -6
- package/assets/themes/indigo.min.css +6 -6
- package/esm2020/lib/admin/admin-dismiss.service.mjs +17 -11
- package/esm2020/lib/admin/admin-menu.component.mjs +3 -3
- package/esm2020/lib/admin/core/ace.input.mjs +3 -3
- package/esm2020/lib/admin/core/color-picker.input.mjs +5 -5
- package/esm2020/lib/admin/core/search.input.mjs +3 -3
- package/esm2020/lib/admin/diff/configuration-diff.component.mjs +3 -3
- package/esm2020/lib/admin/document-trace/document-trace.component.mjs +3 -3
- package/esm2020/lib/admin/document-trace/reassign.dialog.mjs +3 -3
- package/esm2020/lib/admin/document-trace/trace-element.component.mjs +3 -3
- package/esm2020/lib/admin/form/form.resolve.service.mjs +3 -3
- package/esm2020/lib/admin/form/form.service.mjs +3 -3
- package/esm2020/lib/admin/form/workflow/node.component.mjs +65 -33
- package/esm2020/lib/admin/form/workflow/role-node.component.mjs +3 -3
- package/esm2020/lib/admin/form/workflow/workflow.component.mjs +316 -168
- package/esm2020/lib/admin/indices/manage-cube-index.component.mjs +3 -3
- package/esm2020/lib/admin/patterns/patterns.component.mjs +3 -3
- package/esm2020/lib/admin/permissions/permissions.component.mjs +3 -3
- package/esm2020/lib/admin/positions/positions-popup.component.mjs +3 -3
- package/esm2020/lib/admin/positions/positions.component.mjs +8 -7
- package/esm2020/lib/admin/profiler/outofoffice.component.mjs +3 -3
- package/esm2020/lib/admin/profiler/profiler.component.mjs +10 -9
- package/esm2020/lib/admin/utility-wrapper.component.mjs +3 -3
- package/esm2020/lib/admin/utility.pane.component.mjs +3 -3
- package/esm2020/lib/app.component.mjs +9 -16
- package/esm2020/lib/bizdoc.module.mjs +15 -11
- package/esm2020/lib/browse/browse-items.component.mjs +3 -3
- package/esm2020/lib/browse/browse.mobile.component.mjs +3 -3
- package/esm2020/lib/browse/browse.pane.component.mjs +3 -3
- package/esm2020/lib/browse/expanded-item/expanded-item.component.mjs +3 -3
- package/esm2020/lib/browse/filter/filter.component.mjs +3 -3
- package/esm2020/lib/browse/folders-menu.component.mjs +3 -3
- package/esm2020/lib/chat/chat-info.mjs +3 -3
- package/esm2020/lib/chat/chat.mobile.component.mjs +3 -3
- package/esm2020/lib/chat/chat.service.mjs +3 -3
- package/esm2020/lib/chat/contacts.component.mjs +6 -6
- package/esm2020/lib/chat/contacts.pane.component.mjs +3 -3
- package/esm2020/lib/chat/conversation.component.mjs +3 -3
- package/esm2020/lib/chat/conversation.pane.component.mjs +3 -3
- package/esm2020/lib/compose/action/action-picker.component.mjs +3 -3
- package/esm2020/lib/compose/action/action.dialog.mjs +3 -3
- package/esm2020/lib/compose/action/action.pane.dialog.exp.mjs +3 -3
- package/esm2020/lib/compose/action/assign-action.component.mjs +3 -3
- package/esm2020/lib/compose/action/moveto-action.component.mjs +3 -3
- package/esm2020/lib/compose/action/return-action.component.mjs +3 -3
- package/esm2020/lib/compose/attachments/attachments.component.mjs +3 -3
- package/esm2020/lib/compose/attachments/preview/attachment-preview.component.mjs +3 -3
- package/esm2020/lib/compose/attachments/progress-button.directive.mjs +3 -3
- package/esm2020/lib/compose/can-deactivate-changes.service.mjs +3 -3
- package/esm2020/lib/compose/comments/Comments.pane.component.mjs +3 -3
- package/esm2020/lib/compose/comments/comment.component.mjs +3 -3
- package/esm2020/lib/compose/comments/comments.component.mjs +3 -3
- package/esm2020/lib/compose/comments/edit-comment.component.mjs +3 -3
- package/esm2020/lib/compose/comments/edits.component.mjs +3 -3
- package/esm2020/lib/compose/comments/quick-comment.component.exp.mjs +3 -3
- package/esm2020/lib/compose/comments/votes.component.mjs +3 -3
- package/esm2020/lib/compose/compose-resolve.service.mjs +6 -6
- package/esm2020/lib/compose/compose.mobile.component.mjs +3 -3
- package/esm2020/lib/compose/compose.pane.component.mjs +3 -3
- package/esm2020/lib/compose/copy/copy.dialog.mjs +3 -3
- package/esm2020/lib/compose/dismiss.service.mjs +5 -5
- package/esm2020/lib/compose/document-resolver.service.mjs +3 -3
- package/esm2020/lib/compose/document.component.mjs +3 -3
- package/esm2020/lib/compose/document.mobile.component.mjs +3 -3
- package/esm2020/lib/compose/document.pane.component.mjs +3 -3
- package/esm2020/lib/compose/events/events.component.mjs +3 -3
- package/esm2020/lib/compose/form-selector/form-selector.sheet.mjs +3 -3
- package/esm2020/lib/compose/form.component.mjs +5 -5
- package/esm2020/lib/compose/new-menu.component.mjs +3 -3
- package/esm2020/lib/compose/privilage.directive.mjs +6 -6
- package/esm2020/lib/compose/recipient-resolver.service.mjs +3 -3
- package/esm2020/lib/compose/state.component.mjs +3 -3
- package/esm2020/lib/compose/tag/tags.component.mjs +3 -3
- package/esm2020/lib/compose/trace/flow.component.mjs +5 -4
- package/esm2020/lib/compose/trace/people.component.mjs +3 -3
- package/esm2020/lib/compose/trace/trace.base.mjs +3 -3
- package/esm2020/lib/compose/trace/trace.component.mjs +3 -3
- package/esm2020/lib/compose/trace/trace.pane.component.mjs +3 -3
- package/esm2020/lib/compose/version-compare/version-compare.component.mjs +3 -3
- package/esm2020/lib/compose/version-compare/version-compare.directive.mjs +9 -9
- package/esm2020/lib/compose/version-compare/version.pane.component.mjs +3 -3
- package/esm2020/lib/core/NgComponentOutlet.mjs +3 -3
- package/esm2020/lib/core/account.service.mjs +3 -3
- package/esm2020/lib/core/animated-icon/animated-icon.directive.mjs +3 -3
- package/esm2020/lib/core/avatar/avatar.component.mjs +3 -3
- package/esm2020/lib/core/component-factory-resolver.mjs +3 -3
- package/esm2020/lib/core/controls/address.input.mjs +3 -3
- package/esm2020/lib/core/controls/auto-complete.input.mjs +3 -3
- package/esm2020/lib/core/controls/combination-picker-body.mjs +3 -3
- package/esm2020/lib/core/controls/combination-picker.mjs +3 -3
- package/esm2020/lib/core/controls/combination-pool.mjs +3 -3
- package/esm2020/lib/core/controls/file.input.mjs +3 -3
- package/esm2020/lib/core/controls/select.input.mjs +3 -3
- package/esm2020/lib/core/controls/time-picker.mjs +3 -3
- package/esm2020/lib/core/controls/timespan.input.mjs +3 -3
- package/esm2020/lib/core/datasource.service.mjs +3 -3
- package/esm2020/lib/core/guide/guide.component.mjs +3 -3
- package/esm2020/lib/core/guide/guide.service.mjs +3 -3
- package/esm2020/lib/core/guide/help-tip.component.mjs +14 -14
- package/esm2020/lib/core/http.interceptor.mjs +3 -3
- package/esm2020/lib/core/hub.service.mjs +3 -3
- package/esm2020/lib/core/identity/identity.component.mjs +3 -3
- package/esm2020/lib/core/info/attachment-info.service.mjs +3 -3
- package/esm2020/lib/core/info/document-info.service.mjs +3 -3
- package/esm2020/lib/core/info/location-info.component.mjs +3 -3
- package/esm2020/lib/core/info/map-info.mjs +3 -3
- package/esm2020/lib/core/layout/autocomplete.field.mjs +3 -3
- package/esm2020/lib/core/layout/checkbox.field.mjs +3 -3
- package/esm2020/lib/core/layout/checkbox.mjs +3 -3
- package/esm2020/lib/core/layout/date-range.field.mjs +3 -3
- package/esm2020/lib/core/layout/date.field.mjs +3 -3
- package/esm2020/lib/core/layout/expression.field.mjs +3 -3
- package/esm2020/lib/core/layout/file.field.mjs +3 -3
- package/esm2020/lib/core/layout/html.field.mjs +3 -3
- package/esm2020/lib/core/layout/input.base.mjs +3 -3
- package/esm2020/lib/core/layout/input.field.mjs +3 -3
- package/esm2020/lib/core/layout/layout.component.mjs +3 -3
- package/esm2020/lib/core/layout/numeric.field.mjs +3 -3
- package/esm2020/lib/core/layout/select.field.mjs +3 -3
- package/esm2020/lib/core/layout/switch.field.mjs +3 -3
- package/esm2020/lib/core/layout/textarea.field.mjs +3 -3
- package/esm2020/lib/core/layout/timespan.field.mjs +3 -3
- package/esm2020/lib/core/lottie-animation.mjs +3 -3
- package/esm2020/lib/core/mailbox.service.mjs +36 -42
- package/esm2020/lib/core/none.component.mjs +3 -3
- package/esm2020/lib/core/pipes/action.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/calendar.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/date-format.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/daterange.pipe.mjs +6 -6
- package/esm2020/lib/core/pipes/difference.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/duration-format.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/duration.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/form.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/join.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/role.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/sanitize-html.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/sort.pipe.mjs +6 -6
- package/esm2020/lib/core/pipes/state.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/time-ago.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/translate.pipe.mjs +6 -6
- package/esm2020/lib/core/pipes/type-value.pipe.mjs +3 -3
- package/esm2020/lib/core/pipes/user-name.pipe.mjs +3 -3
- package/esm2020/lib/core/popup/popup.component.mjs +3 -3
- package/esm2020/lib/core/popup/popup.service.mjs +3 -3
- package/esm2020/lib/core/popup/tooltip.directive.mjs +6 -6
- package/esm2020/lib/core/prompt/ask/ask.dialog.mjs +3 -3
- package/esm2020/lib/core/prompt/mask/mask.component.mjs +3 -3
- package/esm2020/lib/core/prompt.service.mjs +3 -3
- package/esm2020/lib/core/router.mjs +6 -6
- package/esm2020/lib/core/save-changes.dialog.mjs +18 -0
- package/esm2020/lib/core/session.service.mjs +13 -6
- package/esm2020/lib/core/slots/router.directive.mjs +3 -3
- package/esm2020/lib/core/slots/router.service.mjs +4 -4
- package/esm2020/lib/core/slots/slots.component.mjs +3 -3
- package/esm2020/lib/core/tagging/documents.component.mjs +3 -3
- package/esm2020/lib/core/tagging/edit-input.component.mjs +3 -3
- package/esm2020/lib/core/tagging/emoji.component.mjs +3 -3
- package/esm2020/lib/core/tagging/tagging-item.directive.mjs +3 -3
- package/esm2020/lib/core/tagging/tagging.component-base.mjs +3 -3
- package/esm2020/lib/core/tagging/tagging.directive.mjs +3 -3
- package/esm2020/lib/core/tagging/tagging.pipe.mjs +3 -3
- package/esm2020/lib/core/tagging/users.component.mjs +3 -3
- package/esm2020/lib/core/translate.service.mjs +3 -3
- package/esm2020/lib/core/translations.mjs +5 -5
- package/esm2020/lib/core/window-title.service.mjs +3 -3
- package/esm2020/lib/cube/accum/accum.component.mjs +5 -5
- package/esm2020/lib/cube/chart/chart.component.mjs +5 -5
- package/esm2020/lib/cube/cube-info.service.mjs +3 -3
- package/esm2020/lib/cube/cube-menu.component.mjs +3 -3
- package/esm2020/lib/cube/cube-view.component.mjs +3 -3
- package/esm2020/lib/cube/cube.service.mjs +3 -3
- package/esm2020/lib/cube/explore/document-item.component.mjs +3 -3
- package/esm2020/lib/cube/explore/explore-item.component.mjs +3 -3
- package/esm2020/lib/cube/explore/explore-items.component.mjs +3 -3
- package/esm2020/lib/cube/explore/explore.pane.component.mjs +3 -3
- package/esm2020/lib/cube/explore/item-resolver.service.mjs +6 -6
- package/esm2020/lib/cube/explore/item.pane.component.mjs +3 -3
- package/esm2020/lib/cube/filter/filter-tags.component.exp.mjs +3 -3
- package/esm2020/lib/cube/filter/filter.component.mjs +3 -3
- package/esm2020/lib/cube/grid/grid.component.mjs +3 -3
- package/esm2020/lib/cube/grid/spreadsheet.component.mjs +3 -3
- package/esm2020/lib/cube/matrix/matrix.base.mjs +3 -3
- package/esm2020/lib/cube/matrix/matrix.mobile.component.mjs +3 -3
- package/esm2020/lib/cube/matrix/matrix.pane.component.mjs +3 -3
- package/esm2020/lib/cube/matrix/popup.component.mjs +3 -3
- package/esm2020/lib/cube/matrix/table.component.mjs +3 -3
- package/esm2020/lib/cube/parallel/parallel.component.mjs +3 -3
- package/esm2020/lib/cube/pivot/pivot.component.mjs +25 -7
- package/esm2020/lib/cube/sum/sum.component.mjs +3 -3
- package/esm2020/lib/cube/view-base.mjs +3 -3
- package/esm2020/lib/cube/view.mobile.component.mjs +3 -3
- package/esm2020/lib/cube/view.pane.component.mjs +3 -3
- package/esm2020/lib/dashboard/actions/actions.widget.mjs +3 -3
- package/esm2020/lib/dashboard/cube/accum-cube.widget.mjs +3 -3
- package/esm2020/lib/dashboard/cube/compare.widget.mjs +3 -3
- package/esm2020/lib/dashboard/cube/cube-analysis.base.mjs +3 -3
- package/esm2020/lib/dashboard/cube/cube-analysis.widget.mjs +3 -3
- package/esm2020/lib/dashboard/cube/cube-chart.widget.mjs +3 -3
- package/esm2020/lib/dashboard/cube/documents.widget.mjs +3 -3
- package/esm2020/lib/dashboard/cube/filter/filter.component.mjs +3 -3
- package/esm2020/lib/dashboard/dashboard.component.mjs +3 -3
- package/esm2020/lib/dashboard/dashboard.pane.component.mjs +3 -3
- package/esm2020/lib/dashboard/recents/recents.widget.mjs +3 -3
- package/esm2020/lib/dashboard/score/activity.widget.mjs +3 -3
- package/esm2020/lib/dashboard/score/compare-groups.widget.mjs +3 -3
- package/esm2020/lib/dashboard/score/peers-performance.widget.mjs +3 -3
- package/esm2020/lib/dashboard/score/pending-results.widget.mjs +3 -3
- package/esm2020/lib/dashboard/score/personal-score.widget.mjs +3 -3
- package/esm2020/lib/dashboard/widget-item.component.mjs +3 -3
- package/esm2020/lib/desktop.module.mjs +7 -6
- package/esm2020/lib/home/about/about.dialog.mjs +3 -3
- package/esm2020/lib/home/home-base.component.mjs +3 -3
- package/esm2020/lib/home/home.desktop.component.mjs +3 -3
- package/esm2020/lib/home/home.mobile.component.mjs +3 -3
- package/esm2020/lib/home/notifications/notifications.component.mjs +3 -3
- package/esm2020/lib/home/options/options.component.mjs +3 -3
- package/esm2020/lib/home/outofoffice/outofoffice.component.mjs +3 -3
- package/esm2020/lib/home/search.service.mjs +8 -8
- package/esm2020/lib/home/sign/sign.component.mjs +3 -3
- package/esm2020/lib/home/tools.component.mjs +28 -21
- package/esm2020/lib/impersonate/impersonate.component.mjs +3 -3
- package/esm2020/lib/mobile.module.mjs +15 -5
- package/esm2020/lib/modules/chart.module.mjs +4 -4
- package/esm2020/lib/modules/circular-gauge.module.mjs +4 -4
- package/esm2020/lib/modules/datepicker.intl.mjs +3 -3
- package/esm2020/lib/modules/dayjs.module.mjs +4 -4
- package/esm2020/lib/modules/diagram.module.mjs +4 -4
- package/esm2020/lib/modules/gantt.module.mjs +4 -4
- package/esm2020/lib/modules/grid.module.mjs +4 -4
- package/esm2020/lib/modules/material.module.mjs +4 -4
- package/esm2020/lib/modules/paginator.intl.mjs +3 -3
- package/esm2020/lib/modules/pivot.module.mjs +4 -4
- package/esm2020/lib/modules/schedule.module.mjs +4 -4
- package/esm2020/lib/modules/spreadsheet.module.mjs +4 -4
- package/esm2020/lib/modules/stepper.intl.mjs +3 -3
- package/esm2020/lib/modules/texteditor.module.mjs +4 -4
- package/esm2020/lib/notifications/filter.component.mjs +3 -3
- package/esm2020/lib/notifications/notifications-table.component.mjs +3 -3
- package/esm2020/lib/notifications/notifications.mobile.component.mjs +3 -3
- package/esm2020/lib/notifications/notifications.pane.component.mjs +3 -3
- package/esm2020/lib/notifications/notifications.service.mjs +3 -3
- package/esm2020/lib/notifications/types/commented.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/cube-anomaly.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/escalated.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/liked.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/long-running-task.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/notification-base.mjs +3 -3
- package/esm2020/lib/notifications/types/nudge.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/state-changed.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/tagged.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/text.notification.mjs +3 -3
- package/esm2020/lib/notifications/types/upcoming-event.notification.mjs +3 -3
- package/esm2020/lib/options/options.component.mjs +3 -3
- package/esm2020/lib/options/options.service.mjs +3 -3
- package/esm2020/lib/reports/arguments-component.mjs +3 -3
- package/esm2020/lib/reports/cube/documents.component.mjs +3 -3
- package/esm2020/lib/reports/cube/grid-documents.component.mjs +3 -3
- package/esm2020/lib/reports/cube/table-documents.component.mjs +3 -3
- package/esm2020/lib/reports/cube/usage-args.component.mjs +3 -3
- package/esm2020/lib/reports/cube/usage-base.mjs +3 -3
- package/esm2020/lib/reports/cube/usage-chart.component.mjs +3 -3
- package/esm2020/lib/reports/cube/usage-pivot.component.mjs +3 -3
- package/esm2020/lib/reports/cube/usage.component.mjs +3 -3
- package/esm2020/lib/reports/report-viewer.component.mjs +3 -3
- package/esm2020/lib/reports/report.mobile.component.mjs +3 -3
- package/esm2020/lib/reports/report.pane.component.mjs +3 -3
- package/esm2020/lib/reports/reports-menu.component.mjs +3 -3
- package/esm2020/lib/reports/substitution/substitution.component.mjs +3 -3
- package/esm2020/lib/reports/table/table-view.component.mjs +3 -3
- package/esm2020/lib/reports/tasks/tasks.component.mjs +3 -3
- package/esm2020/lib/routes.desktop.mjs +1 -8
- package/esm2020/lib/scheduler/schedule.component.mjs +3 -3
- package/esm2020/lib/scheduler/scheduler.mobile.component.mjs +3 -3
- package/esm2020/lib/scheduler/scheduler.pane.component.mjs +3 -3
- package/esm2020/lib/shared.module.mjs +179 -126
- package/esm2020/lib/system.module.mjs +13 -9
- package/esm2020/lib/views/cube/chart.component.mjs +4 -4
- package/esm2020/lib/views/cube/cube-base.mjs +3 -3
- package/esm2020/lib/views/cube/explore.component.mjs +3 -3
- package/esm2020/lib/views/cube/matrix.component.mjs +3 -3
- package/esm2020/lib/views/cube/parallel.component.mjs +3 -3
- package/esm2020/lib/views/cube/pivot.component.mjs +3 -3
- package/esm2020/lib/views/cube/sum.component.mjs +3 -3
- package/esm2020/lib/views/cube/view.component.mjs +3 -3
- package/esm2020/lib/views/timeline/timeline.component.exp.mjs +3 -3
- package/esm2020/lib/views/view-item.component.mjs +3 -3
- package/esm2020/lib/views/views.component.mjs +3 -3
- package/esm2020/lib/views/views.mobile.component.mjs +3 -3
- package/esm2020/lib/views/views.pane.component.mjs +3 -3
- package/esm2020/public-api.mjs +3 -3
- package/fesm2015/bizdoc-core.mjs +1872 -1601
- package/fesm2015/bizdoc-core.mjs.map +1 -1
- package/fesm2020/bizdoc-core.mjs +1869 -1597
- package/fesm2020/bizdoc-core.mjs.map +1 -1
- package/lib/admin/admin-dismiss.service.d.ts +3 -3
- package/lib/admin/core/color-picker.input.d.ts +1 -1
- package/lib/admin/form/workflow/node.component.d.ts +8 -7
- package/lib/admin/form/workflow/workflow.component.d.ts +13 -12
- package/lib/admin/positions/positions.component.d.ts +1 -0
- package/lib/admin/profiler/profiler.component.d.ts +1 -0
- package/lib/app.component.d.ts +1 -3
- package/lib/bizdoc.module.d.ts +10 -9
- package/lib/{compose → core}/save-changes.dialog.d.ts +0 -0
- package/lib/core/session.service.d.ts +3 -1
- package/lib/core/slots/router.service.d.ts +1 -1
- package/lib/cube/pivot/pivot.component.d.ts +2 -0
- package/lib/home/search.service.d.ts +1 -0
- package/lib/home/tools.component.d.ts +4 -3
- package/lib/shared.module.d.ts +162 -162
- package/lib/system.module.d.ts +1 -1
- package/package.json +17 -17
- package/public-api.d.ts +2 -2
- package/esm2020/lib/compose/save-changes.dialog.mjs +0 -18
@@ -1,9 +1,10 @@
|
|
1
1
|
import { Component, ViewChild, HostListener } from '@angular/core';
|
2
|
-
import { Subject } from 'rxjs';
|
2
|
+
import { first, Subject } from 'rxjs';
|
3
3
|
import { takeUntil } from 'rxjs/operators';
|
4
|
-
import { DiagramConstraints, SelectorConstraints,
|
4
|
+
import { DiagramConstraints, SelectorConstraints, NodeConstraints, Diagram, UndoRedo, Node, DiagramTools, ConnectorConstraints, SymbolPalette, BpmnDiagrams, ConnectorEditing, ConnectorBridging, Snapping, Connector, PortConstraints, PortVisibility } from '@syncfusion/ej2-angular-diagrams';
|
5
5
|
import { WorkflowNodeComponent } from './node.component';
|
6
6
|
import { OpenPolicy } from '../../../core/configuration';
|
7
|
+
import { MATERIAL_PALETTES } from '../../../core/colors';
|
7
8
|
import * as i0 from "@angular/core";
|
8
9
|
import * as i1 from "../../../core/prompt.service";
|
9
10
|
import * as i2 from "../form.service";
|
@@ -23,15 +24,12 @@ import * as i15 from "@angular/flex-layout/flex";
|
|
23
24
|
import * as i16 from "../../../core/pipes/translate.pipe";
|
24
25
|
Diagram.Inject(UndoRedo, ConnectorBridging, ConnectorEditing, Snapping);
|
25
26
|
SymbolPalette.Inject(BpmnDiagrams);
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
];
|
33
|
-
return ports;
|
34
|
-
}
|
27
|
+
const ports = [
|
28
|
+
{ id: 'port1', shape: 'Circle', offset: { x: 0, y: 0.5 }, visibility: PortVisibility.Connect | PortVisibility.Hover, constraints: PortConstraints.Default | PortConstraints.Draw },
|
29
|
+
{ id: 'port2', shape: 'Circle', offset: { x: 0.5, y: 1 }, visibility: PortVisibility.Connect | PortVisibility.Hover, constraints: PortConstraints.Default | PortConstraints.Draw },
|
30
|
+
{ id: 'port3', shape: 'Circle', offset: { x: 1, y: 0.5 }, visibility: PortVisibility.Connect | PortVisibility.Hover, constraints: PortConstraints.Default | PortConstraints.Draw },
|
31
|
+
{ id: 'port4', shape: 'Circle', offset: { x: 0.5, y: 0 }, visibility: PortVisibility.Connect | PortVisibility.Hover, constraints: PortConstraints.Default | PortConstraints.Draw }
|
32
|
+
];
|
35
33
|
function showPaletteIcon() {
|
36
34
|
const paletteSpace = document.getElementById('palette-space');
|
37
35
|
const isMobile = window.matchMedia('(max-width:550px)').matches;
|
@@ -53,26 +51,6 @@ function paletteIconClick() {
|
|
53
51
|
}
|
54
52
|
}
|
55
53
|
}
|
56
|
-
//Defines the tool
|
57
|
-
class DrawTool extends ConnectorDrawingTool {
|
58
|
-
constructor(diagram, segments) {
|
59
|
-
super(diagram.commandHandler, 'ConnectorSourceEnd', null);
|
60
|
-
this.diagram = diagram;
|
61
|
-
this.segments = segments;
|
62
|
-
}
|
63
|
-
mouseMove(args) {
|
64
|
-
if (this.diagram.selectedItems.nodes.length) {
|
65
|
-
this.diagram.drawingObject = {
|
66
|
-
type: this.segments || 'Bezier',
|
67
|
-
sourceID: this.diagram.selectedItems.nodes[0].id
|
68
|
-
};
|
69
|
-
this.inAction = true;
|
70
|
-
}
|
71
|
-
const ok = super.mouseMove(args);
|
72
|
-
return ok;
|
73
|
-
}
|
74
|
-
}
|
75
|
-
const LINK_PATH = 'M346.7,714.6l368.1-368.1c17.9-17.9,17.9-47.1,0-64.9c-17.9-17.9-47.1-17.9-64.9,0l-368,368c-17.9,17.9-17.9,47.1,0,64.9C299.6,732.5,328.9,732.5,346.7,714.6z M468.2,651c6.4,9,7.6,18.5,7.6,23.8c0,6.3-1.5,18.6-11.8,28.9L271,896.5c-10.3,10.3-22.5,11.8-28.9,11.8c-6.3,0-18.6-1.5-28.9-11.8L103.5,786.8c-10.3-10.3-11.8-22.5-11.8-28.9c0-6.4,1.5-18.6,11.8-28.9l192.9-192.9c10.3-10.3,22.5-11.8,28.9-11.8c4.5,0,11.8,0.8,19.3,4.8l58.6-58.6c-48-39.6-119.6-36.9-164.5,7.9L45.7,671.3c-47.7,47.7-47.7,125.5,0,173.2l109.7,109.7c47.7,47.7,125.5,47.7,173.2,0l192.9-192.9c46-46,47.6-120.4,4.6-168.4L468.2,651z M954.2,155.5L844.5,45.8C796.9-1.9,719-1.9,671.3,45.8L478.4,238.7c-44.8,44.8-47.5,116.5-7.9,164.5l58.6-58.6c-4-7.6-4.8-14.9-4.8-19.3c0-6.3,1.5-18.6,11.8-28.9l192.9-192.9c10.3-10.3,22.5-11.8,28.9-11.8c6.3,0,18.6,1.5,28.9,11.8l109.7,109.7c10.3,10.3,11.8,22.5,11.8,28.9c0,6.3-1.5,18.6-11.8,28.9L703.7,464c-10.3,10.3-22.5,11.8-28.9,11.8c-5.3,0-14.8-1.1-23.8-7.6l-58,58c48,43,122.3,41.5,168.4-4.6l192.9-192.9C1001.9,281.1,1001.9,203.1,954.2,155.5z';
|
76
54
|
/** workflow component*/
|
77
55
|
export class WorkflowComponent {
|
78
56
|
/** workflow ctor */
|
@@ -83,7 +61,7 @@ export class WorkflowComponent {
|
|
83
61
|
this._router = _router;
|
84
62
|
this._session = _session;
|
85
63
|
this._translate = _translate;
|
86
|
-
this.
|
64
|
+
this.fontSizes = [9, 11, 12, 13, 15, 21, 31, 41];
|
87
65
|
this.connectorType = 'Bezier';
|
88
66
|
this.alignment = 'Center';
|
89
67
|
this.fontSize = 12;
|
@@ -91,71 +69,53 @@ export class WorkflowComponent {
|
|
91
69
|
this.dirty = false;
|
92
70
|
this.palettes = [];
|
93
71
|
this.diagramConstraints = DiagramConstraints.Default | DiagramConstraints.Bridging | DiagramConstraints.UserInteraction | DiagramConstraints.Zoom;
|
94
|
-
this.diagramTool = DiagramTools.Default;
|
95
|
-
//Defines the user handle collection for nodes in diagram
|
96
|
-
this._userHandles = [
|
97
|
-
{
|
98
|
-
name: 'connect',
|
99
|
-
pathData: LINK_PATH,
|
100
|
-
visible: true,
|
101
|
-
offset: 0,
|
102
|
-
side: 'Right',
|
103
|
-
displacement: 20,
|
104
|
-
margin: { top: 0, bottom: 0, left: 0, right: 0 }
|
105
|
-
}
|
106
|
-
];
|
107
72
|
//SymbolPalette Properties
|
108
73
|
this.symbolMargin = { left: 10, right: 10, top: 10, bottom: 10 };
|
109
|
-
this.snapSettings = {
|
110
|
-
|
74
|
+
this.snapSettings = {
|
75
|
+
snapLineColor: this._session.getAccent(100)
|
76
|
+
};
|
77
|
+
this.selectedItems = {
|
78
|
+
constraints: SelectorConstraints.All & ~SelectorConstraints.Rotate,
|
79
|
+
};
|
111
80
|
this.scrollSettings = {
|
112
81
|
minZoom: .5,
|
113
|
-
maxZoom: 2.5
|
114
|
-
};
|
115
|
-
this._rulerColor = this._session.getAccent(100);
|
116
|
-
this.rulerSettings = {
|
117
|
-
horizontalRuler: { markerColor: this._rulerColor },
|
118
|
-
verticalRuler: { markerColor: this._rulerColor }
|
82
|
+
maxZoom: 2.5,
|
119
83
|
};
|
84
|
+
this.rulerSettings = {};
|
120
85
|
this._destroy = new Subject();
|
121
|
-
this.
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
obj.width = 145;
|
138
|
-
}
|
139
|
-
else {
|
140
|
-
const ratio = 100 / obj.width;
|
141
|
-
obj.width = 100;
|
142
|
-
obj.height *= ratio;
|
86
|
+
this._nodedestroy = new Subject();
|
87
|
+
this.nodeDefaults = (obj) => {
|
88
|
+
switch (obj.shape.type) {
|
89
|
+
case 'SwimLane':
|
90
|
+
break;
|
91
|
+
case 'Text':
|
92
|
+
if (obj.id !== 'version')
|
93
|
+
obj.constraints = NodeConstraints.Default & ~NodeConstraints.InConnect & ~NodeConstraints.OutConnect;
|
94
|
+
break;
|
95
|
+
default:
|
96
|
+
if (obj.addInfo && obj.addInfo['nodeType']) {
|
97
|
+
obj.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;
|
98
|
+
obj.style.strokeColor = this._session.theme.dark ? 'white' : 'black';
|
99
|
+
obj.ports = ports;
|
100
|
+
}
|
101
|
+
break;
|
143
102
|
}
|
144
|
-
obj.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;
|
145
|
-
obj.ports = getPorts();
|
146
103
|
return obj;
|
147
104
|
};
|
148
105
|
this.connDefaults = (obj) => {
|
149
|
-
obj.constraints = ConnectorConstraints.Default | ConnectorConstraints.Bridging
|
106
|
+
obj.constraints = ConnectorConstraints.Default | ConnectorConstraints.Bridging;
|
150
107
|
obj.style.strokeColor = this._session.theme.dark ? 'white' : 'black';
|
108
|
+
if (!obj.type)
|
109
|
+
obj.type = this.connectorType;
|
110
|
+
return obj;
|
151
111
|
};
|
112
|
+
this._tools = localStorage.getItem('diagram_tools') === '1';
|
152
113
|
this._palettes();
|
153
114
|
}
|
154
|
-
|
155
|
-
|
156
|
-
|
157
|
-
|
158
|
-
return tool;
|
115
|
+
get tools() { return this._tools; }
|
116
|
+
set tools(val) {
|
117
|
+
localStorage.setItem('diagram_tools', val ? '1' : '0');
|
118
|
+
this._tools = val;
|
159
119
|
}
|
160
120
|
ngAfterViewInit() {
|
161
121
|
}
|
@@ -163,11 +123,15 @@ export class WorkflowComponent {
|
|
163
123
|
this.symbolPalette = new SymbolPalette({
|
164
124
|
expandMode: 'Multiple',
|
165
125
|
palettes: this.palettes,
|
166
|
-
width: "100%",
|
167
|
-
|
126
|
+
width: "100%",
|
127
|
+
height: "100%",
|
128
|
+
enableRtl: false,
|
129
|
+
enableAnimation: false,
|
130
|
+
symbolHeight: 80,
|
131
|
+
symbolWidth: 80,
|
168
132
|
symbolMargin: this.symbolMargin,
|
169
133
|
getSymbolInfo: this.getSymbolInfo.bind(this),
|
170
|
-
getNodeDefaults: this.getSymbolDefaults.bind(this)
|
134
|
+
getNodeDefaults: this.getSymbolDefaults.bind(this),
|
171
135
|
});
|
172
136
|
this.symbolPalette.appendTo(this.symbolPaletteEl.nativeElement);
|
173
137
|
this.diagram = new Diagram({
|
@@ -175,15 +139,13 @@ export class WorkflowComponent {
|
|
175
139
|
snapSettings: this.snapSettings,
|
176
140
|
getConnectorDefaults: this.connDefaults.bind(this),
|
177
141
|
constraints: this.diagramConstraints,
|
178
|
-
tool: this.diagramTool,
|
179
142
|
getNodeDefaults: this.nodeDefaults.bind(this),
|
180
|
-
getCustomTool: this.getTool.bind(this),
|
181
143
|
scrollSettings: this.scrollSettings,
|
182
144
|
selectedItems: this.selectedItems,
|
183
145
|
rulerSettings: this.rulerSettings,
|
184
146
|
dragEnter: this.dragEnter.bind(this),
|
185
147
|
connectionChange: this.change.bind(this),
|
186
|
-
collectionChange: this.
|
148
|
+
collectionChange: this.collectionChange.bind(this),
|
187
149
|
propertyChange: this.propertyChange.bind(this),
|
188
150
|
selectionChange: this.selectionChange.bind(this),
|
189
151
|
}, this.diagramEl.nativeElement);
|
@@ -204,7 +166,6 @@ export class WorkflowComponent {
|
|
204
166
|
this.diagram.fitToPage();
|
205
167
|
this.dirty = false;
|
206
168
|
});
|
207
|
-
this._pane.resized.pipe(takeUntil(this._destroy)).subscribe(() => this.diagram.refresh());
|
208
169
|
}
|
209
170
|
_palettes() {
|
210
171
|
this._session.profile.nodes.forEach(n => {
|
@@ -215,6 +176,8 @@ export class WorkflowComponent {
|
|
215
176
|
nodeType: n.name,
|
216
177
|
title: n.title
|
217
178
|
},
|
179
|
+
width: 145,
|
180
|
+
height: 145,
|
218
181
|
};
|
219
182
|
node.node = n.name;
|
220
183
|
let palette = this.palettes.find(p => p.title === (n.palette || ''));
|
@@ -224,8 +187,131 @@ export class WorkflowComponent {
|
|
224
187
|
}
|
225
188
|
palette.symbols.push(node);
|
226
189
|
});
|
227
|
-
|
228
|
-
|
190
|
+
this.palettes.push({
|
191
|
+
id: 'design',
|
192
|
+
title: this._translate.get('Design'),
|
193
|
+
symbols: [{
|
194
|
+
id: 'Link22',
|
195
|
+
type: 'Straight',
|
196
|
+
sourcePoint: { x: 0, y: 0 },
|
197
|
+
targetPoint: { x: 60, y: 60 },
|
198
|
+
targetDecorator: {
|
199
|
+
shape: 'Arrow',
|
200
|
+
style: { strokeColor: '#757575', fill: '#757575' },
|
201
|
+
},
|
202
|
+
style: {
|
203
|
+
strokeWidth: 1,
|
204
|
+
strokeDashArray: '4 4',
|
205
|
+
strokeColor: '#757575',
|
206
|
+
}
|
207
|
+
},
|
208
|
+
{
|
209
|
+
id: 'text', shape: { type: 'Text', content: 'T' },
|
210
|
+
style: {
|
211
|
+
fill: 'transparent'
|
212
|
+
},
|
213
|
+
constraints: NodeConstraints.Default & ~NodeConstraints.InConnect & ~NodeConstraints.OutConnect,
|
214
|
+
addInfo: { title: this._translate.get('Text') }
|
215
|
+
}]
|
216
|
+
});
|
217
|
+
const color = MATERIAL_PALETTES['grey'][200];
|
218
|
+
this.palettes.push({
|
219
|
+
id: 'swimlaneShapes',
|
220
|
+
expanded: true,
|
221
|
+
title: this._translate.get('Swimlane Shapes'),
|
222
|
+
symbols: [
|
223
|
+
{
|
224
|
+
id: 'swimlane',
|
225
|
+
addInfo: {
|
226
|
+
title: this._translate.get('Horizontal')
|
227
|
+
},
|
228
|
+
shape: {
|
229
|
+
header: {
|
230
|
+
annotation: { content: 'Plan' }
|
231
|
+
},
|
232
|
+
type: 'SwimLane',
|
233
|
+
lanes: [
|
234
|
+
{
|
235
|
+
id: 'lane1',
|
236
|
+
header: {
|
237
|
+
annotation: { content: 'Lane' },
|
238
|
+
style: { fill: color }
|
239
|
+
}
|
240
|
+
}
|
241
|
+
],
|
242
|
+
orientation: 'Horizontal',
|
243
|
+
isLane: true
|
244
|
+
},
|
245
|
+
height: 60,
|
246
|
+
width: 140,
|
247
|
+
offsetX: 70,
|
248
|
+
offsetY: 30,
|
249
|
+
}, {
|
250
|
+
id: 'vswimlane',
|
251
|
+
addInfo: {
|
252
|
+
title: this._translate.get('Vertical')
|
253
|
+
},
|
254
|
+
shape: {
|
255
|
+
type: 'SwimLane',
|
256
|
+
header: {
|
257
|
+
annotation: { content: 'Plan' }
|
258
|
+
},
|
259
|
+
lanes: [
|
260
|
+
{
|
261
|
+
id: 'lane1',
|
262
|
+
header: {
|
263
|
+
annotation: { content: 'Lane' },
|
264
|
+
style: { fill: color }
|
265
|
+
}
|
266
|
+
}
|
267
|
+
],
|
268
|
+
orientation: 'Vertical', isLane: true
|
269
|
+
},
|
270
|
+
height: 140,
|
271
|
+
width: 60,
|
272
|
+
offsetX: 70,
|
273
|
+
offsetY: 30,
|
274
|
+
}, {
|
275
|
+
id: 'vphase',
|
276
|
+
addInfo: {
|
277
|
+
title: this._translate.get('Phase')
|
278
|
+
},
|
279
|
+
shape: {
|
280
|
+
type: 'SwimLane',
|
281
|
+
phases: [
|
282
|
+
{
|
283
|
+
style: { strokeWidth: 1, strokeDashArray: '3,3', strokeColor: color },
|
284
|
+
header: {
|
285
|
+
annotation: { text: 'Phase' }
|
286
|
+
}
|
287
|
+
}
|
288
|
+
],
|
289
|
+
orientation: 'Vertical', isPhase: true
|
290
|
+
},
|
291
|
+
height: 60,
|
292
|
+
width: 140,
|
293
|
+
style: { strokeColor: color }
|
294
|
+
}, {
|
295
|
+
id: 'hphase',
|
296
|
+
addInfo: {
|
297
|
+
title: this._translate.get('Phase')
|
298
|
+
},
|
299
|
+
shape: {
|
300
|
+
type: 'SwimLane',
|
301
|
+
phases: [{
|
302
|
+
style: { strokeWidth: 1, strokeDashArray: '3,3', strokeColor: color },
|
303
|
+
header: {
|
304
|
+
annotation: { text: 'Phase' }
|
305
|
+
}
|
306
|
+
}],
|
307
|
+
orientation: 'Horizontal', isPhase: true
|
308
|
+
},
|
309
|
+
height: 60,
|
310
|
+
width: 140,
|
311
|
+
style: { strokeColor: color }
|
312
|
+
}
|
313
|
+
]
|
314
|
+
});
|
229
315
|
}
|
230
316
|
_versionNode(version) {
|
231
317
|
return {
|
@@ -246,15 +332,14 @@ export class WorkflowComponent {
|
|
246
332
|
};
|
247
333
|
}
|
248
334
|
getSymbolInfo(symbol) {
|
249
|
-
return {
|
335
|
+
return symbol.addInfo ? {
|
250
336
|
fit: true,
|
251
337
|
tooltip: symbol.addInfo.title,
|
252
338
|
description: { text: symbol.addInfo.title, overflow: 'Wrap', wrap: 'WrapWithOverflow' }
|
253
|
-
};
|
339
|
+
} : null;
|
254
340
|
}
|
255
341
|
getSymbolDefaults(symbol) {
|
256
342
|
symbol.width = symbol.height = 40;
|
257
|
-
symbol.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;
|
258
343
|
}
|
259
344
|
pan() {
|
260
345
|
this.diagram.constraints = this.diagram.constraints | DiagramConstraints.Pan;
|
@@ -265,51 +350,45 @@ export class WorkflowComponent {
|
|
265
350
|
this.diagram.tool = DiagramTools.Default;
|
266
351
|
}
|
267
352
|
selectionChange(evt) {
|
268
|
-
const {
|
269
|
-
if (
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
274
|
-
|
275
|
-
|
276
|
-
|
277
|
-
|
278
|
-
|
279
|
-
|
280
|
-
|
281
|
-
|
282
|
-
if (connector.annotations.length)
|
283
|
-
this.fontSize = connector.annotations[0].style.fontSize;
|
284
|
-
this.connectorType = connectors.length === 1 || connectors.every(c => c.type === type) ? type : null;
|
285
|
-
}
|
286
|
-
if (nodes.length) {
|
287
|
-
const node = nodes[0], addInfo = node.addInfo;
|
288
|
-
if (addInfo && addInfo.nodeType) {
|
289
|
-
if (node.annotations.length)
|
290
|
-
this.fontSize = node.annotations[0].style.fontSize;
|
291
|
-
}
|
292
|
-
}
|
293
|
-
this._router.navigate(WorkflowNodeComponent, {
|
294
|
-
state: {
|
295
|
-
nodes, connectors
|
296
|
-
},
|
297
|
-
policy: OpenPolicy.Tab,
|
298
|
-
expandable: false,
|
299
|
-
group: ''
|
300
|
-
}).then(p => {
|
301
|
-
p.instance.change.
|
302
|
-
pipe(takeUntil(this._destroy)).subscribe(() => {
|
303
|
-
this.dirty = true;
|
304
|
-
this.diagram.dataBind();
|
305
|
-
});
|
306
|
-
});
|
353
|
+
const { newValue, state } = evt;
|
354
|
+
if (state !== 'Changing' || !newValue.length) {
|
355
|
+
this._nodedestroy.next();
|
356
|
+
return;
|
357
|
+
}
|
358
|
+
const connectors = newValue.filter(n => n instanceof Connector).map(n => n);
|
359
|
+
if (connectors.length) {
|
360
|
+
const connector = connectors[0], type = connector.type;
|
361
|
+
this.connectorType = connectors.length === 1 ||
|
362
|
+
connectors.every(c => c.type === type) ? type : null;
|
363
|
+
if (connector.annotations.length && connector.annotations[0].style)
|
364
|
+
this.fontSize = connector.annotations[0].style.fontSize;
|
365
|
+
this.connectorType = connectors.length === 1 ||
|
366
|
+
connectors.every(c => c.type === type) ? type : null;
|
307
367
|
}
|
308
|
-
|
309
|
-
|
368
|
+
const nodes = newValue.filter(n => n instanceof Node);
|
369
|
+
if (nodes.length) {
|
370
|
+
const node = nodes[0], addInfo = node.addInfo;
|
371
|
+
if (!addInfo || !addInfo['nodeType'])
|
372
|
+
return;
|
373
|
+
if (node.annotations.length && node.annotations[0].style)
|
374
|
+
this.fontSize = node.annotations[0].style.fontSize;
|
375
|
+
}
|
376
|
+
this._router.navigate(WorkflowNodeComponent, {
|
377
|
+
state: {
|
378
|
+
diagram: this.diagram,
|
379
|
+
nodes,
|
380
|
+
connectors
|
381
|
+
},
|
382
|
+
policy: OpenPolicy.Tab,
|
383
|
+
expandable: false,
|
384
|
+
group: ''
|
385
|
+
}).then(p => {
|
386
|
+
p.instance.change.pipe(takeUntil(this._nodedestroy)).subscribe(() => this.change());
|
387
|
+
this._nodedestroy.pipe(first()).subscribe(() => p.close());
|
388
|
+
});
|
310
389
|
}
|
311
390
|
align(value) {
|
312
|
-
|
391
|
+
this.diagram.selectedItems.nodes.forEach(n => {
|
313
392
|
n.annotations.length && Object.assign(n.annotations[0], {
|
314
393
|
offset: {
|
315
394
|
x: value === 'Right' ? 1 : value === 'Left' ? 0 : .5,
|
@@ -318,21 +397,51 @@ export class WorkflowComponent {
|
|
318
397
|
verticalAlignment: value === 'Top' ? 'Bottom' : value === 'Bottom' ? 'Top' : 'Center',
|
319
398
|
horizontalAlignment: value === 'Right' ? 'Left' : value === 'Left' ? 'Right' : 'Center'
|
320
399
|
});
|
321
|
-
}
|
322
|
-
this.diagram.selectedItems.
|
323
|
-
|
400
|
+
});
|
401
|
+
this.diagram.selectedItems.connectors.forEach(c => c.annotations.forEach(a => Object.assign(a, {
|
402
|
+
verticalAlignment: value === 'Top' ? 'Bottom' : value === 'Bottom' ? 'Top' : 'Center',
|
403
|
+
horizontalAlignment: value === 'Left' ? 'Left' : value === 'Right' ? 'Right' : 'Center',
|
404
|
+
// displacement: {
|
405
|
+
// x: value === 'Right' ? 10 : value === 'Left' ? -10 : 0,
|
406
|
+
// y: value === 'Top' ? -10 : value === 'Bottom' ? 10 : 0
|
407
|
+
// }
|
408
|
+
})));
|
324
409
|
this.alignment = value;
|
325
410
|
this.dirty = true;
|
326
411
|
}
|
327
412
|
dragEnter(args) {
|
328
|
-
|
329
|
-
|
330
|
-
|
331
|
-
|
332
|
-
|
333
|
-
|
334
|
-
|
335
|
-
|
413
|
+
if (args.element instanceof Node) {
|
414
|
+
switch (args.element.shape.type) {
|
415
|
+
case 'SwimLane':
|
416
|
+
{
|
417
|
+
const shape = args.element.shape;
|
418
|
+
switch (shape.orientation) {
|
419
|
+
case 'Horizontal':
|
420
|
+
shape.lanes[0].width = 400;
|
421
|
+
break;
|
422
|
+
case 'Vertical':
|
423
|
+
shape.lanes[0].height = 400;
|
424
|
+
break;
|
425
|
+
}
|
426
|
+
break;
|
427
|
+
}
|
428
|
+
case 'Text':
|
429
|
+
//(args.element.style as TextStyleModel).fontSize = 20;
|
430
|
+
break;
|
431
|
+
default:
|
432
|
+
{
|
433
|
+
const { width, height } = args.element;
|
434
|
+
args.element.width = 100;
|
435
|
+
args.element.height *= 100 / width;
|
436
|
+
args.element.offsetX += (args.element.width - width) / 2;
|
437
|
+
args.element.offsetY += (args.element.height - height) / 2;
|
438
|
+
args.element.style = {
|
439
|
+
fill: 'transparent',
|
440
|
+
strokeColor: this._session.theme.dark ? 'white' : 'black',
|
441
|
+
strokeWidth: 1
|
442
|
+
};
|
443
|
+
}
|
444
|
+
}
|
336
445
|
}
|
337
446
|
}
|
338
447
|
propertyChange(e) {
|
@@ -342,14 +451,9 @@ export class WorkflowComponent {
|
|
342
451
|
change() {
|
343
452
|
this.dirty = true;
|
344
453
|
}
|
345
|
-
|
346
|
-
this.
|
347
|
-
|
348
|
-
type: 'Text',
|
349
|
-
},
|
350
|
-
constraints: NodeConstraints.Default & ~NodeConstraints.InConnect & ~NodeConstraints.OutConnect
|
351
|
-
};
|
352
|
-
this.diagram.tool = DiagramTools.DrawOnce;
|
454
|
+
collectionChange() {
|
455
|
+
this._router.collapse();
|
456
|
+
this.dirty = true;
|
353
457
|
}
|
354
458
|
/**
|
355
459
|
* Ctrl-s save
|
@@ -375,8 +479,54 @@ export class WorkflowComponent {
|
|
375
479
|
this.connectorType = type;
|
376
480
|
this.dirty = true;
|
377
481
|
}
|
378
|
-
|
379
|
-
this.diagram.selectedItems.nodes.
|
482
|
+
boldChange() {
|
483
|
+
const val = !this.diagram.selectedItems.nodes[0].annotations[0]?.style?.bold;
|
484
|
+
function change(node) {
|
485
|
+
if (node.shape.type === 'Text')
|
486
|
+
node.style.bold = val;
|
487
|
+
else
|
488
|
+
node.annotations.forEach(a => {
|
489
|
+
if (!a.style)
|
490
|
+
a.style = { bold: val };
|
491
|
+
else
|
492
|
+
a.style.bold = val;
|
493
|
+
});
|
494
|
+
}
|
495
|
+
this.diagram.selectedItems.nodes.forEach(change);
|
496
|
+
this.diagram.selectedItems.connectors.forEach(change);
|
497
|
+
this.diagram.dataBind();
|
498
|
+
}
|
499
|
+
italicChange() {
|
500
|
+
const val = !this.diagram.selectedItems.nodes[0].annotations[0]?.style?.italic;
|
501
|
+
function change(node) {
|
502
|
+
if (node.shape.type === 'Text')
|
503
|
+
node.style.italic = val;
|
504
|
+
else
|
505
|
+
node.annotations.forEach(a => {
|
506
|
+
if (!a.style)
|
507
|
+
a.style = { italic: val };
|
508
|
+
else
|
509
|
+
a.style.italic = val;
|
510
|
+
});
|
511
|
+
}
|
512
|
+
this.diagram.selectedItems.nodes.forEach(change);
|
513
|
+
this.diagram.selectedItems.connectors.forEach(change);
|
514
|
+
this.diagram.dataBind();
|
515
|
+
}
|
516
|
+
fontSizeChange(val) {
|
517
|
+
function change(node) {
|
518
|
+
if (node.shape.type === 'Text')
|
519
|
+
node.style.fontSize = val;
|
520
|
+
else
|
521
|
+
node.annotations?.forEach(a => {
|
522
|
+
if (!a.style)
|
523
|
+
a.style = { fontSize: val };
|
524
|
+
else
|
525
|
+
a.style.fontSize = val;
|
526
|
+
});
|
527
|
+
}
|
528
|
+
this.diagram.selectedItems.nodes.forEach(change);
|
529
|
+
this.diagram.selectedItems.connectors.forEach(change);
|
380
530
|
this.diagram.dataBind();
|
381
531
|
}
|
382
532
|
strokeChange(val) {
|
@@ -392,11 +542,7 @@ export class WorkflowComponent {
|
|
392
542
|
this.diagram.serializationSettings = { preventDefaults: true };
|
393
543
|
const obj = JSON.parse(this.diagram.saveDiagram());
|
394
544
|
this._form.workflow.connectors = obj.connectors;
|
395
|
-
this._form.workflow.nodes = obj.nodes.filter(n => n.id !== 'version')
|
396
|
-
n.offsetX = Math.round(n.offsetX);
|
397
|
-
n.offsetY = Math.round(n.offsetY);
|
398
|
-
return n;
|
399
|
-
});
|
545
|
+
this._form.workflow.nodes = obj.nodes.filter(n => n.id !== 'version');
|
400
546
|
this.saving = true;
|
401
547
|
return this._service.save(this._form).toPromise().then(v => {
|
402
548
|
this.ps.toast('ChangesSaved');
|
@@ -419,15 +565,17 @@ export class WorkflowComponent {
|
|
419
565
|
this.diagram?.destroy();
|
420
566
|
this._destroy.next();
|
421
567
|
this._destroy.complete();
|
568
|
+
this._nodedestroy.next();
|
569
|
+
this._nodedestroy.complete();
|
422
570
|
}
|
423
571
|
}
|
424
|
-
WorkflowComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.
|
425
|
-
WorkflowComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.
|
426
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.
|
572
|
+
WorkflowComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: WorkflowComponent, deps: [{ token: i1.PromptService }, { token: i2.FormService }, { token: i3.PaneRef }, { token: i4.PanesRouter }, { token: i5.SessionService }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
573
|
+
WorkflowComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: WorkflowComponent, selector: "bizdoc-workflow", host: { listeners: { "document:keydown": "handleKeyboardEvent($event)" }, classAttribute: "pane" }, viewQueries: [{ propertyName: "symbolPaletteEl", first: true, predicate: ["symbolPaletteEl"], descendants: true, static: true }, { propertyName: "diagramEl", first: true, predicate: ["diagramEl"], descendants: true, static: true }], ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n <span class=\"tools-divider\"></span>\r\n <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n <span class=\"tools-divider\"></span>\r\n <button mat-icon-button (click)=\"diagram.copy()\" [bizdocTooltip]=\"'Copy' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>copy</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.paste()\" [bizdocTooltip]=\"'Paste' | translate\"><mat-icon>paste</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.remove()\" [bizdocTooltip]=\"'Remove' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>delete</mat-icon></button>\r\n <span class=\"tools-divider\"></span>\r\n <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"diagram.selectedItems?.connectors.length === 0\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n 'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n 'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #lineMenu overlayPanelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n </button>\r\n <!--<ng-container *ngIf=\"connectors.length\">\r\n < bizdoc-color-picker (valueChanges)='strokeChange($event)' [label]=\"'Stroke'|translate\"></ bizdoc-color-picker>\r\n <ng-container *ngIf=\"nodes[0].annotations.length\">\r\n < bizdoc-color-picker (valueChanges)='colorChange($event)' [label]=\"'Color'|translate\"></ bizdoc-color-picker>\r\n </ng-container>\r\n < bizdoc-color-picker (valueChanges)='bgChange($event)' [label]=\"'Background'|translate\"></ bizdoc-color-picker>\r\n < bizdoc-color-picker (valueChanges)='strokeChange($event)' [label]=\"'Stroke'|translate\"></ bizdoc-color-picker>\r\n </ng-container>-->\r\n </mat-menu>\r\n \r\n <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"diagram.selectedItems?.nodes.length === 0 && diagram.selectedItems?.connectors.length === 0\" [bizdocTooltip]=\"'Align'|translate\">\r\n <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n 'sf-icon-left': alignment === 'Left',\r\n 'sf-icon-center': alignment === 'Center',\r\n 'sf-icon-bottom': alignment === 'Bottom',\r\n 'sf-icon-right': alignment === 'Right'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #alignMenu overlayPanelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"align('Top')\">\r\n <span class=\"e-icons sf-icon-top\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Left')\">\r\n <span class=\"e-icons sf-icon-left\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Center')\">\r\n <span class=\"e-icons sf-icon-center\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Right')\">\r\n <span class=\"e-icons sf-icon-right\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Bottom')\">\r\n <span class=\"e-icons sf-icon-bottom\"></span>\r\n </button>\r\n </mat-menu>\r\n <button mat-icon-button (click)=\"boldChange()\" [bizdocTooltip]=\"'Bold' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>format_bold</mat-icon></button>\r\n <button mat-icon-button (click)=\"italicChange()\" [bizdocTooltip]=\"'Italic' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>format_italic</mat-icon></button>\r\n <button mat-icon-button [matMenuTriggerFor]=\"sizeMenu\"\r\n [disabled]=\"diagram.selectedItems?.nodes.length === 0 && diagram.selectedItems?.connectors.length === 0\"\r\n [bizdocTooltip]=\"'FontSize'|translate\">\r\n <mat-icon>format_size</mat-icon>\r\n </button>\r\n <mat-menu #sizeMenu overlayPanelClass=\"icon-menu-panel\">\r\n <button mat-menu-item *ngFor=\"let size of fontSizes\" (click)=\"fontSizeChange(size)\">\r\n {{size}}\r\n </button>\r\n </mat-menu>\r\n <span class=\"divider\"></span>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n <div id=\"symbolpalette\" [style.display]=\"tools?'':'none'\">\r\n <div dir=\"ltr\" #symbolPaletteEl>\r\n </div>\r\n </div>\r\n <div #diagramEl id=\"diagram\" fxFlex dir=\"ltr\">\r\n </div>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;flex-grow:1;height:100%}.container{flex-grow:1;overflow-y:auto}#diagram{flex-grow:1}#symbolpalette{width:210px}::ng-deep .e-rtl{direction:ltr}::ng-deep .mat-toolbar .mat-button-toggle{background:transparent!important}.e-menu-icon{font-family:diagram-icons!important;speak:none;font-size:18px;font-style:normal;font-weight:400;font-feature-settings:normal;font-variant:normal;text-transform:none;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::ng-deep .mat-menu-panel{min-width:0!important}.tools-divider:after{content:\"|\";opacity:.6;margin:0 2px}\n"], components: [{ type: i7.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i8.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i9.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i10.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i10.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }], directives: [{ type: i11.TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i10.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i12.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i13.DefaultClassDirective, selector: " [ngClass], [ngClass.xs], [ngClass.sm], [ngClass.md], [ngClass.lg], [ngClass.xl], [ngClass.lt-sm], [ngClass.lt-md], [ngClass.lt-lg], [ngClass.lt-xl], [ngClass.gt-xs], [ngClass.gt-sm], [ngClass.gt-md], [ngClass.gt-lg]", inputs: ["ngClass", "ngClass.xs", "ngClass.sm", "ngClass.md", "ngClass.lg", "ngClass.xl", "ngClass.lt-sm", "ngClass.lt-md", "ngClass.lt-lg", "ngClass.lt-xl", "ngClass.gt-xs", "ngClass.gt-sm", "ngClass.gt-md", "ngClass.gt-lg"] }, { type: i12.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i14.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i15.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }], pipes: { "translate": i16.TranslatePipe } });
|
574
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: WorkflowComponent, decorators: [{
|
427
575
|
type: Component,
|
428
576
|
args: [{ selector: 'bizdoc-workflow', host: {
|
429
577
|
class: 'pane'
|
430
|
-
}, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n <button mat-icon-button (click)=\"
|
578
|
+
}, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n <span class=\"tools-divider\"></span>\r\n <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n <span class=\"tools-divider\"></span>\r\n <button mat-icon-button (click)=\"diagram.copy()\" [bizdocTooltip]=\"'Copy' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>copy</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.paste()\" [bizdocTooltip]=\"'Paste' | translate\"><mat-icon>paste</mat-icon></button>\r\n <button mat-icon-button (click)=\"diagram.remove()\" [bizdocTooltip]=\"'Remove' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>delete</mat-icon></button>\r\n <span class=\"tools-divider\"></span>\r\n <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"diagram.selectedItems?.connectors.length === 0\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n 'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n 'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #lineMenu overlayPanelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n </button>\r\n <!--<ng-container *ngIf=\"connectors.length\">\r\n < bizdoc-color-picker (valueChanges)='strokeChange($event)' [label]=\"'Stroke'|translate\"></ bizdoc-color-picker>\r\n <ng-container *ngIf=\"nodes[0].annotations.length\">\r\n < bizdoc-color-picker (valueChanges)='colorChange($event)' [label]=\"'Color'|translate\"></ bizdoc-color-picker>\r\n </ng-container>\r\n < bizdoc-color-picker (valueChanges)='bgChange($event)' [label]=\"'Background'|translate\"></ bizdoc-color-picker>\r\n < bizdoc-color-picker (valueChanges)='strokeChange($event)' [label]=\"'Stroke'|translate\"></ bizdoc-color-picker>\r\n </ng-container>-->\r\n </mat-menu>\r\n \r\n <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"diagram.selectedItems?.nodes.length === 0 && diagram.selectedItems?.connectors.length === 0\" [bizdocTooltip]=\"'Align'|translate\">\r\n <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n 'sf-icon-left': alignment === 'Left',\r\n 'sf-icon-center': alignment === 'Center',\r\n 'sf-icon-bottom': alignment === 'Bottom',\r\n 'sf-icon-right': alignment === 'Right'}\"></span>\r\n <mat-icon>arrow_drop_down</mat-icon>\r\n </button>\r\n <mat-menu #alignMenu overlayPanelClass=\"icon-menu-panel\">\r\n <button mat-menu-item (click)=\"align('Top')\">\r\n <span class=\"e-icons sf-icon-top\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Left')\">\r\n <span class=\"e-icons sf-icon-left\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Center')\">\r\n <span class=\"e-icons sf-icon-center\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Right')\">\r\n <span class=\"e-icons sf-icon-right\"></span>\r\n </button>\r\n <button mat-menu-item (click)=\"align('Bottom')\">\r\n <span class=\"e-icons sf-icon-bottom\"></span>\r\n </button>\r\n </mat-menu>\r\n <button mat-icon-button (click)=\"boldChange()\" [bizdocTooltip]=\"'Bold' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>format_bold</mat-icon></button>\r\n <button mat-icon-button (click)=\"italicChange()\" [bizdocTooltip]=\"'Italic' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>format_italic</mat-icon></button>\r\n <button mat-icon-button [matMenuTriggerFor]=\"sizeMenu\"\r\n [disabled]=\"diagram.selectedItems?.nodes.length === 0 && diagram.selectedItems?.connectors.length === 0\"\r\n [bizdocTooltip]=\"'FontSize'|translate\">\r\n <mat-icon>format_size</mat-icon>\r\n </button>\r\n <mat-menu #sizeMenu overlayPanelClass=\"icon-menu-panel\">\r\n <button mat-menu-item *ngFor=\"let size of fontSizes\" (click)=\"fontSizeChange(size)\">\r\n {{size}}\r\n </button>\r\n </mat-menu>\r\n <span class=\"divider\"></span>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n <div id=\"symbolpalette\" [style.display]=\"tools?'':'none'\">\r\n <div dir=\"ltr\" #symbolPaletteEl>\r\n </div>\r\n </div>\r\n <div #diagramEl id=\"diagram\" fxFlex dir=\"ltr\">\r\n </div>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;flex-grow:1;height:100%}.container{flex-grow:1;overflow-y:auto}#diagram{flex-grow:1}#symbolpalette{width:210px}::ng-deep .e-rtl{direction:ltr}::ng-deep .mat-toolbar .mat-button-toggle{background:transparent!important}.e-menu-icon{font-family:diagram-icons!important;speak:none;font-size:18px;font-style:normal;font-weight:400;font-feature-settings:normal;font-variant:normal;text-transform:none;line-height:1;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::ng-deep .mat-menu-panel{min-width:0!important}.tools-divider:after{content:\"|\";opacity:.6;margin:0 2px}\n"] }]
|
431
579
|
}], ctorParameters: function () { return [{ type: i1.PromptService }, { type: i2.FormService }, { type: i3.PaneRef }, { type: i4.PanesRouter }, { type: i5.SessionService }, { type: i6.TranslateService }]; }, propDecorators: { symbolPaletteEl: [{
|
432
580
|
type: ViewChild,
|
433
581
|
args: ['symbolPaletteEl', { static: true }]
|
@@ -438,4 +586,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.1", ngImpor
|
|
438
586
|
type: HostListener,
|
439
587
|
args: ['document:keydown', ['$event']]
|
440
588
|
}] } });
|
441
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/form/workflow/workflow.component.ts","../../../../../../../libraries/core/src/lib/admin/form/workflow/workflow.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, OnDestroy, HostListener, ElementRef, OnInit, AfterViewInit } from '@angular/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport {\r\n  DiagramConstraints, UserHandleModel, SelectorConstraints, ToolBase, MouseEventArgs, ConnectorModel, ConnectorDrawingTool, TextModel, PointPortModel, NodeConstraints, ScrollSettingsModel,\r\n  Diagram, NodeModel, UndoRedo, SymbolInfo, IDragEnterEventArgs, SnapSettingsModel, MarginModel, Node, PaletteModel, Segments, DiagramTools, ConnectorConstraints, SelectorModel, RulerSettingsModel, AlignmentOptions, TextStyleModel, SymbolPalette, BpmnDiagrams, DataBinding,\r\n  ConnectorEditing, ConnectorBridging, Snapping\r\n} from '@syncfusion/ej2-diagrams';\r\nimport { Form } from '../../../core/models';\r\nimport { SessionService } from '../../../core/session.service';\r\nimport { FormService } from '../form.service';\r\nimport { PromptService } from '../../../core/prompt.service';\r\nimport { TranslateService } from '../../../core/translate.service';\r\nimport { PaneRef } from '../../../core/slots/pane-ref';\r\nimport { PanesRouter } from '../../../core/slots/router.service';\r\nimport { WorkflowNodeComponent } from './node.component';\r\nimport { AdminComponent } from '../../admin-dismiss.service';\r\nimport { OpenPolicy } from '../../../core/configuration';\r\nimport { ISelectionChangeEventArgs } from '@syncfusion/ej2-angular-diagrams';\r\n\r\nDiagram.Inject(UndoRedo, ConnectorBridging, ConnectorEditing, Snapping);\r\nSymbolPalette.Inject(BpmnDiagrams);\r\n\r\nfunction getPorts(): PointPortModel[] {\r\n  const ports: PointPortModel[] = [\r\n    { id: 'port1', shape: 'Circle', offset: { x: 0, y: 0.5 } },\r\n    { id: 'port2', shape: 'Circle', offset: { x: 0.5, y: 1 } },\r\n    { id: 'port3', shape: 'Circle', offset: { x: 1, y: 0.5 } },\r\n    { id: 'port4', shape: 'Circle', offset: { x: 0.5, y: 0 } }\r\n  ];\r\n  return ports;\r\n}\r\n\r\nfunction showPaletteIcon(): void {\r\n  const paletteSpace: HTMLElement = document.getElementById('palette-space');\r\n  const isMobile = window.matchMedia('(max-width:550px)').matches;\r\n  if (isMobile) {\r\n    if (!paletteSpace.classList.contains('sb-mobile-palette-open')) {\r\n      paletteSpace.classList.add('sb-mobile-palette-open');\r\n    } else {\r\n      paletteSpace.classList.remove('sb-mobile-palette-open');\r\n    }\r\n  }\r\n}\r\n\r\nfunction paletteIconClick() {\r\n  const isMobile = window.matchMedia('(max-width:550px)').matches;\r\n  if (isMobile) {\r\n    const paletteIcon = document.getElementById('palette-icon');\r\n    if (paletteIcon) {\r\n      paletteIcon.addEventListener('click', showPaletteIcon, false);\r\n    }\r\n  }\r\n}\r\n\r\n//Defines the tool\r\nclass DrawTool extends ConnectorDrawingTool {\r\n  public mouseMove(args: MouseEventArgs): boolean {\r\n    if (this.diagram.selectedItems.nodes.length) {\r\n      this.diagram.drawingObject = {\r\n        type: this.segments || 'Bezier',\r\n        sourceID: this.diagram.selectedItems.nodes[0].id\r\n      };\r\n      this.inAction = true;\r\n    }\r\n    const ok = super.mouseMove(args);\r\n    return ok;\r\n  }\r\n  constructor(private diagram: Diagram, private segments: Segments) {\r\n    super(diagram.commandHandler, 'ConnectorSourceEnd', null);\r\n  }\r\n}\r\nconst LINK_PATH = 'M346.7,714.6l368.1-368.1c17.9-17.9,17.9-47.1,0-64.9c-17.9-17.9-47.1-17.9-64.9,0l-368,368c-17.9,17.9-17.9,47.1,0,64.9C299.6,732.5,328.9,732.5,346.7,714.6z M468.2,651c6.4,9,7.6,18.5,7.6,23.8c0,6.3-1.5,18.6-11.8,28.9L271,896.5c-10.3,10.3-22.5,11.8-28.9,11.8c-6.3,0-18.6-1.5-28.9-11.8L103.5,786.8c-10.3-10.3-11.8-22.5-11.8-28.9c0-6.4,1.5-18.6,11.8-28.9l192.9-192.9c10.3-10.3,22.5-11.8,28.9-11.8c4.5,0,11.8,0.8,19.3,4.8l58.6-58.6c-48-39.6-119.6-36.9-164.5,7.9L45.7,671.3c-47.7,47.7-47.7,125.5,0,173.2l109.7,109.7c47.7,47.7,125.5,47.7,173.2,0l192.9-192.9c46-46,47.6-120.4,4.6-168.4L468.2,651z M954.2,155.5L844.5,45.8C796.9-1.9,719-1.9,671.3,45.8L478.4,238.7c-44.8,44.8-47.5,116.5-7.9,164.5l58.6-58.6c-4-7.6-4.8-14.9-4.8-19.3c0-6.3,1.5-18.6,11.8-28.9l192.9-192.9c10.3-10.3,22.5-11.8,28.9-11.8c6.3,0,18.6,1.5,28.9,11.8l109.7,109.7c10.3,10.3,11.8,22.5,11.8,28.9c0,6.3-1.5,18.6-11.8,28.9L703.7,464c-10.3,10.3-22.5,11.8-28.9,11.8c-5.3,0-14.8-1.1-23.8-7.6l-58,58c48,43,122.3,41.5,168.4-4.6l192.9-192.9C1001.9,281.1,1001.9,203.1,954.2,155.5z';\r\n\r\n@Component({\r\n  selector: 'bizdoc-workflow',\r\n  templateUrl: './workflow.component.html',\r\n  styleUrls: ['./workflow.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** workflow component*/\r\nexport class WorkflowComponent implements OnInit, AfterViewInit, OnDestroy, AdminComponent {\r\n  symbolPalette: SymbolPalette;\r\n  diagram: Diagram;\r\n  @ViewChild('symbolPaletteEl', { static: true }) symbolPaletteEl: ElementRef;\r\n  @ViewChild('diagramEl', { static: true }) diagramEl: ElementRef;\r\n  tools = true;\r\n  connectorType: Segments = 'Bezier';\r\n  alignment: AlignmentOptions = 'Center';\r\n  fontSize = 12;\r\n  public getTool(action: string): ToolBase {\r\n    let tool: ToolBase = null;\r\n    if (action === 'connect')\r\n      tool = new DrawTool(this.diagram, this.connectorType);\r\n    return tool;\r\n  }\r\n  saving = false;\r\n  element?: any;\r\n  dirty = false;\r\n  params: {};\r\n  palettes: PaletteModel[] = [];\r\n  diagramConstraints: DiagramConstraints = DiagramConstraints.Default | DiagramConstraints.Bridging | DiagramConstraints.UserInteraction | DiagramConstraints.Zoom;\r\n  diagramTool: DiagramTools = DiagramTools.Default;\r\n  //Defines the user handle collection for nodes in diagram\r\n  private readonly _userHandles: UserHandleModel[] = [\r\n    {\r\n      name: 'connect',\r\n      pathData: LINK_PATH,\r\n      visible: true,\r\n      offset: 0,\r\n      side: 'Right',\r\n      displacement: 20,\r\n      margin: { top: 0, bottom: 0, left: 0, right: 0 }\r\n    }\r\n  ];\r\n  //SymbolPalette Properties\r\n  readonly symbolMargin: MarginModel = { left: 10, right: 10, top: 10, bottom: 10 };\r\n  readonly snapSettings: SnapSettingsModel = {\r\n  };\r\n  readonly selectedItems: SelectorModel = {\r\n  };\r\n  readonly scrollSettings: ScrollSettingsModel = {\r\n    minZoom: .5,\r\n    maxZoom: 2.5\r\n  };\r\n  private _rulerColor = this._session.getAccent(100);\r\n  readonly rulerSettings: RulerSettingsModel = {\r\n    horizontalRuler: { markerColor: this._rulerColor },\r\n    verticalRuler: { markerColor: this._rulerColor }\r\n  };\r\n  private _form: Form;\r\n  private readonly _destroy = new Subject<void>();\r\n  /** workflow ctor */\r\n  constructor(private ps: PromptService,\r\n    private _service: FormService,\r\n    private _pane: PaneRef<WorkflowComponent>,\r\n    private _router: PanesRouter,\r\n    private _session: SessionService,\r\n    private _translate: TranslateService) {\r\n    this._palettes();\r\n  }\r\n  ngAfterViewInit(): void {\r\n  }\r\n  ngOnInit() {\r\n    this.symbolPalette = new SymbolPalette({\r\n      expandMode: 'Multiple',\r\n      palettes: this.palettes,\r\n      width: \"100%\", height: \"100%\", symbolHeight: 80,\r\n      enableRtl: false, enableAnimation: false, symbolWidth: 80,\r\n      symbolMargin: this.symbolMargin,\r\n      getSymbolInfo: this.getSymbolInfo.bind(this),\r\n      getNodeDefaults: this.getSymbolDefaults.bind(this)\r\n    });\r\n    this.symbolPalette.appendTo(this.symbolPaletteEl.nativeElement);\r\n    this.diagram = new Diagram({\r\n      width: \"100%\", height: \"100%\",\r\n      snapSettings: this.snapSettings,\r\n      getConnectorDefaults: this.connDefaults.bind(this),\r\n      constraints: this.diagramConstraints,\r\n      tool: this.diagramTool,\r\n      getNodeDefaults: this.nodeDefaults.bind(this),\r\n      getCustomTool: this.getTool.bind(this),\r\n      scrollSettings: this.scrollSettings,\r\n      selectedItems: this.selectedItems,\r\n      rulerSettings: this.rulerSettings,\r\n      dragEnter: this.dragEnter.bind(this),\r\n      connectionChange: this.change.bind(this),\r\n      collectionChange: this.change.bind(this),\r\n      propertyChange: this.propertyChange.bind(this),\r\n      selectionChange: this.selectionChange.bind(this),\r\n    }, this.diagramEl.nativeElement);\r\n    paletteIconClick();\r\n    this._pane.paramsChange.pipe(takeUntil(this._destroy)).subscribe(p => {\r\n      const id = p['id'];\r\n      this._form = this._session.profile.forms.find(f => f.name === id);\r\n      this._pane.title = this._form.title;\r\n      this.params = { id: this._form.name };\r\n    });\r\n    this._pane.dataChange.pipe(takeUntil(this._destroy)).subscribe(d => {\r\n      Object.assign(this._form, d.form);\r\n      const flow = this._form.workflow;\r\n      this.diagram.nodes = flow.nodes;\r\n      this.diagram.connectors = flow.connectors;\r\n      this.diagram.dataBind();\r\n      this.diagram.add(this._versionNode(flow.version));\r\n      this.diagram.fitToPage();\r\n      this.dirty = false;\r\n    });\r\n    this._pane.resized.pipe(takeUntil(this._destroy)).subscribe(() =>\r\n      this.diagram.refresh());\r\n  }\r\n  private _palettes() {\r\n    this._session.profile.nodes.forEach(n => {\r\n      const node: NodeModel = {\r\n        id: n.name,\r\n        shape: n.shape,\r\n        addInfo: {\r\n          nodeType: n.name,\r\n          title: n.title\r\n        },\r\n      };\r\n      (node as any).node = n.name;\r\n      let palette = this.palettes.find(p => p.title === (n.palette || ''));\r\n      if (!palette) {\r\n        palette = { id: `_${n.palette}`, expanded: true, title: n.palette || '', symbols: [] };\r\n        this.palettes.push(palette);\r\n      }\r\n      palette.symbols.push(node);\r\n    });\r\n    //this.palettes.push({ id: 'design', title: this._translation.get('Design'), symbols: [{ id: 'text', shape: { type: 'Text', textContent: 'T' }, addInfo: { title: this._translation.get('Text') } }] });\r\n    /*this.palettes.push(swimlane );*/\r\n  }\r\n\r\n  private _versionNode(version: number): NodeModel {\r\n    return {\r\n      id: 'version',\r\n      shape: {\r\n        type: 'Text',\r\n        content: this._translate.get('DiagramVersion', version || 0)\r\n      },\r\n      offsetY: 5,\r\n      offsetX: 5,\r\n      style: {\r\n        fontSize: 50,\r\n        color: this._session.theme.dark ? 'white' : 'black',\r\n        opacity: .1\r\n      } as TextStyleModel,\r\n      constraints: NodeConstraints.ReadOnly,\r\n      zIndex: -1\r\n    } as TextModel;\r\n  }\r\n  nodeDefaults = (): NodeModel => {\r\n    const obj: NodeModel = {\r\n      style: {\r\n        fill: 'transparent',\r\n        strokeColor: this._session.theme.dark ? 'white' : 'black',\r\n        strokeWidth: 1\r\n      },\r\n      annotations: [{\r\n        style: {\r\n          color: this._session.theme.dark ? 'white' : 'black',\r\n          fill: 'transparent',\r\n          opacity: .8\r\n        }\r\n      }]\r\n    };\r\n    if (obj.width === undefined) {\r\n      obj.width = 145;\r\n    } else {\r\n      const ratio: number = 100 / obj.width;\r\n      obj.width = 100;\r\n      obj.height *= ratio;\r\n    }\r\n    obj.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;\r\n    obj.ports = getPorts();\r\n    return obj;\r\n  }\r\n  public connDefaults = (obj: ConnectorModel): void => {\r\n    obj.constraints = ConnectorConstraints.Default | ConnectorConstraints.Bridging | ConnectorConstraints.DragSegmentThumb;\r\n    obj.style.strokeColor = this._session.theme.dark ? 'white' : 'black';\r\n  }\r\n  public getSymbolInfo(symbol: NodeModel): SymbolInfo {\r\n    return {\r\n      fit: true,\r\n      tooltip: (symbol.addInfo as any).title,\r\n      description: { text: (symbol.addInfo as any).title, overflow: 'Wrap', wrap: 'WrapWithOverflow' }\r\n    };\r\n  }\r\n  public getSymbolDefaults(symbol: NodeModel): void {\r\n    symbol.width = symbol.height = 40;\r\n    symbol.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;\r\n  }\r\n  pan() {\r\n    this.diagram.constraints = this.diagram.constraints | DiagramConstraints.Pan;\r\n    this.diagram.tool = DiagramTools.ZoomPan;\r\n  }\r\n  cursor() {\r\n    this.diagram.constraints = this.diagram.constraints & ~DiagramConstraints.Pan;\r\n    this.diagram.tool = DiagramTools.Default;\r\n  }\r\n  selectionChange(evt: ISelectionChangeEventArgs) {\r\n    const { nodes, connectors } = this.diagram.selectedItems;\r\n    if (connectors.length || nodes.length) {\r\n      if (nodes.length === 1 && nodes[0].addInfo) {\r\n        this.diagram.selectedItems.constraints = SelectorConstraints.All | SelectorConstraints.UserHandle;\r\n        this.diagram.selectedItems.userHandles = this._userHandles;\r\n      }\r\n      else this.diagram.selectedItems.constraints = SelectorConstraints.All ^ SelectorConstraints.UserHandle;\r\n\r\n      if (connectors.length) {\r\n        const connector = connectors[0];\r\n        connectors.forEach(c => { if (!c.addInfo) c.addInfo = {} });\r\n        const type = connector.type;\r\n        this.connectorType = connectors.length === 1 || connectors.every(c => c.type === type) ? type : null;\r\n        if (connector.annotations.length)\r\n          this.fontSize = connector.annotations[0].style.fontSize;\r\n        this.connectorType = connectors.length === 1 || connectors.every(c => c.type === type) ? type : null;\r\n      }\r\n      if (nodes.length) {\r\n        const node = nodes[0],\r\n          addInfo = node.addInfo as any;\r\n        if (addInfo && addInfo.nodeType) {\r\n          if (node.annotations.length)\r\n            this.fontSize = node.annotations[0].style.fontSize;\r\n        }\r\n      }\r\n      this._router.navigate(WorkflowNodeComponent, {\r\n        state: {\r\n          nodes, connectors\r\n        },\r\n        policy: OpenPolicy.Tab,\r\n        expandable: false,\r\n        group: ''\r\n      }).then(p => {\r\n        (p.instance as WorkflowNodeComponent).change.\r\n          pipe(takeUntil(this._destroy)).subscribe(() => {\r\n            this.dirty = true;\r\n            this.diagram.dataBind();\r\n          });\r\n      });\r\n    }\r\n    else\r\n      this._router.collapse();\r\n  }\r\n  align(value: AlignmentOptions) {\r\n    function align(n: NodeModel | ConnectorModel) {\r\n      n.annotations.length && Object.assign(n.annotations[0], {\r\n        offset: {\r\n          x: value === 'Right' ? 1 : value === 'Left' ? 0 : .5,\r\n          y: value === 'Top' ? 0 : value === 'Bottom' ? 1 : .5\r\n        },\r\n        verticalAlignment: value === 'Top' ? 'Bottom' : value === 'Bottom' ? 'Top' : 'Center',\r\n        horizontalAlignment: value === 'Right' ? 'Left' : value === 'Left' ? 'Right' : 'Center'\r\n      });\r\n    }\r\n    this.diagram.selectedItems.nodes.forEach(align);\r\n    this.diagram.selectedItems.connectors.forEach(align);\r\n    this.alignment = value;\r\n    this.dirty = true;\r\n  }\r\n  public dragEnter(args: IDragEnterEventArgs): void {\r\n    const obj: NodeModel = args.element as NodeModel;\r\n    if (obj instanceof Node) {\r\n      const { width, height } = obj;\r\n      obj.width = 100;\r\n      obj.height *= 100 / width;\r\n      obj.offsetX += (obj.width - width) / 2;\r\n      obj.offsetY += (obj.height - height) / 2;\r\n      obj.style = { fill: 'white', strokeColor: 'black' };\r\n    }\r\n  }\r\n  propertyChange(e) {\r\n    if (e.cause !== 2) this.dirty = true;\r\n  }\r\n  change() {\r\n    this.dirty = true;\r\n  }\r\n  addText() {\r\n    this.diagram.drawingObject = {\r\n      shape: {\r\n        type: 'Text',\r\n      },\r\n      constraints: NodeConstraints.Default & ~NodeConstraints.InConnect & ~NodeConstraints.OutConnect\r\n    } as NodeModel;\r\n    this.diagram.tool = DiagramTools.DrawOnce;\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (this.dirty && event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  bgChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.style.fill = val);\r\n    this.dirty = true;\r\n  }\r\n  colorChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.annotations.forEach(a => a.style.color = val));\r\n    this.diagram.selectedItems.connectors.forEach(c => c.annotations.forEach(a => a.style.color = val));\r\n    this.dirty = true;\r\n  }\r\n  connectorTypeChange(type: Segments) {\r\n    this.diagram.selectedItems.connectors.forEach(c => c.type = type);\r\n    this.connectorType = type;\r\n    this.dirty = true;\r\n  }\r\n  sizeChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.annotations.forEach(a => a.style.fontSize = parseInt(val)));\r\n    this.diagram.dataBind();\r\n  }\r\n  strokeChange(val: string) {\r\n    this.diagram.selectedItems.connectors.forEach(c => {\r\n      c.style.strokeColor = val;\r\n      if (c.annotations) c.annotations[0].style.color = val;\r\n    });\r\n    this.diagram.selectedItems.nodes.forEach(n => n.style.strokeColor = val);\r\n    this.dirty = true;\r\n  }\r\n  save(): Promise<any> {\r\n    this.diagram.serializationSettings = {preventDefaults: true};\r\n    const obj = JSON.parse(this.diagram.saveDiagram());\r\n    this._form.workflow.connectors = obj.connectors;\r\n    this._form.workflow.nodes = obj.nodes.filter(n => n.id !== 'version').map((n: NodeModel) => {\r\n      n.offsetX = Math.round(n.offsetX);\r\n      n.offsetY = Math.round(n.offsetY);\r\n      return n;\r\n    });\r\n    this.saving = true;\r\n    return this._service.save(this._form).toPromise().then(v => {\r\n      this.ps.toast('ChangesSaved');\r\n      if (this._form.workflow.version < v) {\r\n        this.ps.toast('DiagramVersion', v);\r\n        const node = this.diagram.getNodeObject('version');\r\n        (node.shape as TextModel).content = this._translate.get('DiagramVersion', v);\r\n        this.diagram.dataBind();\r\n      }\r\n      this._form.workflow.version = v;\r\n      this.dirty = false;\r\n      this.saving = false;\r\n    }, () => {\r\n      this.ps.error();\r\n      this.saving = false;\r\n    });\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.symbolPalette?.destroy();\r\n    this.diagram?.destroy();\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n  }\r\n}\r\n","<mat-toolbar>\r\n  <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n  <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n  <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n  <span class=\"tools-divider\"></span>\r\n  <button mat-icon-button (click)=\"diagram.copy()\" [bizdocTooltip]=\"'Copy' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>copy</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.paste()\" [bizdocTooltip]=\"'Paste' | translate\"><mat-icon>paste</mat-icon></button>\r\n  <span class=\"tools-divider\"></span>\r\n  <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n  <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n  <span class=\"divider\"></span>\r\n  <button mat-icon-button (click)=\"addText()\" [bizdocTooltip]=\"'Text' | translate\"><mat-icon>title</mat-icon></button>\r\n  <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"diagram.selectedItems?.connectors.length === 0\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n    <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n          'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n          'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n    <mat-icon>arrow_drop_down</mat-icon>\r\n  </button>\r\n  <mat-menu #lineMenu panelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n      <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n      <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n      <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n    </button>\r\n  </mat-menu>\r\n  &nbsp;\r\n  <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"diagram.selectedItems?.nodes.length === 0 && diagram.selectedItems?.connectors.length === 0\" [bizdocTooltip]=\"'Align'|translate\">\r\n    <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n          'sf-icon-left': alignment === 'Left',\r\n          'sf-icon-center': alignment === 'Center',\r\n          'sf-icon-bottom': alignment === 'Bottom',\r\n          'sf-icon-right': alignment === 'Right'}\"></span>\r\n    <mat-icon>arrow_drop_down</mat-icon>\r\n  </button>\r\n  <mat-menu #alignMenu panelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item (click)=\"align('Top')\">\r\n      <span class=\"e-icons sf-icon-top\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Left')\">\r\n      <span class=\"e-icons sf-icon-left\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Center')\">\r\n      <span class=\"e-icons sf-icon-center\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Bottom')\">\r\n      <span class=\"e-icons sf-icon-bottom\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Right')\">\r\n      <span class=\"e-icons sf-icon-right\"></span>\r\n    </button>\r\n  </mat-menu>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n  <div id=\"symbolpalette\" [style.display]=\"tools?'':'none'\">\r\n    <div dir=\"ltr\" #symbolPaletteEl>\r\n    </div>\r\n  </div>\r\n  <div #diagramEl id=\"diagram\" fxFlex dir=\"ltr\">\r\n  </div>\r\n</div>\r\n"]}
|
589
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.component.js","sourceRoot":"","sources":["../../../../../../../libraries/core/src/lib/admin/form/workflow/workflow.component.ts","../../../../../../../libraries/core/src/lib/admin/form/workflow/workflow.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, OnDestroy, HostListener, ElementRef, OnInit, AfterViewInit } from '@angular/core';\r\nimport { first, Subject, tap } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport {\r\n  DiagramConstraints, SelectorConstraints, ConnectorModel,\r\n  TextModel, PointPortModel, NodeConstraints, ScrollSettingsModel,\r\n  Diagram, NodeModel, UndoRedo, SymbolInfo, IDragEnterEventArgs, SnapSettingsModel, MarginModel,\r\n  Node, PaletteModel, Segments, DiagramTools, ConnectorConstraints, SelectorModel, RulerSettingsModel, AlignmentOptions, TextStyleModel,\r\n  SymbolPalette, BpmnDiagrams, DataBinding, ISelectionChangeEventArgs,\r\n  ConnectorEditing, ConnectorBridging, Snapping, Connector, SwimLaneModel, PortConstraints, HeaderModel, PortVisibility, SnapConstraints, ShapeAnnotationModel, PathAnnotationModel, DiagramModel\r\n} from '@syncfusion/ej2-angular-diagrams';\r\nimport { Form } from '../../../core/models';\r\nimport { SessionService } from '../../../core/session.service';\r\nimport { FormService } from '../form.service';\r\nimport { PromptService } from '../../../core/prompt.service';\r\nimport { TranslateService } from '../../../core/translate.service';\r\nimport { PaneRef } from '../../../core/slots/pane-ref';\r\nimport { PanesRouter } from '../../../core/slots/router.service';\r\nimport { WorkflowNodeComponent } from './node.component';\r\nimport { AdminComponent } from '../../admin-dismiss.service';\r\nimport { OpenPolicy } from '../../../core/configuration';\r\nimport { MATERIAL_PALETTES } from '../../../core/colors';\r\n\r\nDiagram.Inject(UndoRedo, ConnectorBridging, ConnectorEditing, Snapping);\r\nSymbolPalette.Inject(BpmnDiagrams);\r\n\r\nconst ports: PointPortModel[] = [\r\n  { id: 'port1', shape: 'Circle', offset: { x: 0, y: 0.5 }, visibility: PortVisibility.Connect | PortVisibility.Hover, constraints: PortConstraints.Default | PortConstraints.Draw },\r\n  { id: 'port2', shape: 'Circle', offset: { x: 0.5, y: 1 }, visibility: PortVisibility.Connect | PortVisibility.Hover, constraints: PortConstraints.Default | PortConstraints.Draw },\r\n  { id: 'port3', shape: 'Circle', offset: { x: 1, y: 0.5 }, visibility: PortVisibility.Connect | PortVisibility.Hover, constraints: PortConstraints.Default | PortConstraints.Draw },\r\n  { id: 'port4', shape: 'Circle', offset: { x: 0.5, y: 0 }, visibility: PortVisibility.Connect | PortVisibility.Hover, constraints: PortConstraints.Default | PortConstraints.Draw }\r\n];\r\n\r\nfunction showPaletteIcon(): void {\r\n  const paletteSpace: HTMLElement = document.getElementById('palette-space');\r\n  const isMobile = window.matchMedia('(max-width:550px)').matches;\r\n  if (isMobile) {\r\n    if (!paletteSpace.classList.contains('sb-mobile-palette-open')) {\r\n      paletteSpace.classList.add('sb-mobile-palette-open');\r\n    } else {\r\n      paletteSpace.classList.remove('sb-mobile-palette-open');\r\n    }\r\n  }\r\n}\r\n\r\nfunction paletteIconClick() {\r\n  const isMobile = window.matchMedia('(max-width:550px)').matches;\r\n  if (isMobile) {\r\n    const paletteIcon = document.getElementById('palette-icon');\r\n    if (paletteIcon) {\r\n      paletteIcon.addEventListener('click', showPaletteIcon, false);\r\n    }\r\n  }\r\n}\r\n\r\n@Component({\r\n  selector: 'bizdoc-workflow',\r\n  templateUrl: './workflow.component.html',\r\n  styleUrls: ['./workflow.component.scss'],\r\n  host: {\r\n    class: 'pane'\r\n  }\r\n})\r\n/** workflow component*/\r\nexport class WorkflowComponent implements OnInit, AfterViewInit, OnDestroy, AdminComponent {\r\n  symbolPalette: SymbolPalette;\r\n  readonly fontSizes = [9, 11, 12, 13, 15, 21, 31, 41];\r\n  diagram: Diagram;\r\n  @ViewChild('symbolPaletteEl', { static: true }) symbolPaletteEl: ElementRef;\r\n  @ViewChild('diagramEl', { static: true }) diagramEl: ElementRef;\r\n  private _tools: boolean;\r\n  get tools() { return this._tools; }\r\n  set tools(val: boolean) {\r\n    localStorage.setItem('diagram_tools', val ? '1' : '0');\r\n    this._tools = val;\r\n  }\r\n  connectorType: Segments = 'Bezier';\r\n  alignment: AlignmentOptions = 'Center';\r\n  fontSize = 12;\r\n  saving = false;\r\n  element?: any;\r\n  dirty = false;\r\n  params: {};\r\n  readonly palettes: PaletteModel[] = [];\r\n  diagramConstraints: DiagramConstraints = DiagramConstraints.Default | DiagramConstraints.Bridging | DiagramConstraints.UserInteraction | DiagramConstraints.Zoom;\r\n  //SymbolPalette Properties\r\n  readonly symbolMargin: MarginModel = { left: 10, right: 10, top: 10, bottom: 10 };\r\n  readonly snapSettings: SnapSettingsModel = {\r\n    snapLineColor: this._session.getAccent(100)\r\n  };\r\n  readonly selectedItems: SelectorModel = {\r\n    constraints: SelectorConstraints.All & ~SelectorConstraints.Rotate,\r\n  };\r\n  readonly scrollSettings: ScrollSettingsModel = {\r\n    minZoom: .5,\r\n    maxZoom: 2.5,\r\n  };\r\n  readonly rulerSettings: RulerSettingsModel = {\r\n  };\r\n  private _form: Form;\r\n  private readonly _destroy = new Subject<void>();\r\n  private readonly _nodedestroy = new Subject<void>();\r\n  /** workflow ctor */\r\n  constructor(private ps: PromptService,\r\n    private _service: FormService,\r\n    private _pane: PaneRef<WorkflowComponent>,\r\n    private _router: PanesRouter,\r\n    private _session: SessionService,\r\n    private _translate: TranslateService) {\r\n    this._tools = localStorage.getItem('diagram_tools') === '1';\r\n\r\n    this._palettes();\r\n  }\r\n  ngAfterViewInit(): void {\r\n  }\r\n  ngOnInit() {\r\n    this.symbolPalette = new SymbolPalette({\r\n      expandMode: 'Multiple',\r\n      palettes: this.palettes,\r\n      width: \"100%\",\r\n      height: \"100%\",\r\n      enableRtl: false,\r\n      enableAnimation: false,\r\n      symbolHeight: 80,\r\n      symbolWidth: 80,\r\n      symbolMargin: this.symbolMargin,\r\n      getSymbolInfo: this.getSymbolInfo.bind(this),\r\n      getNodeDefaults: this.getSymbolDefaults.bind(this),\r\n    });\r\n    this.symbolPalette.appendTo(this.symbolPaletteEl.nativeElement);\r\n    this.diagram = new Diagram({\r\n      width: \"100%\", height: \"100%\",\r\n      snapSettings: this.snapSettings,\r\n      getConnectorDefaults: this.connDefaults.bind(this),\r\n      constraints: this.diagramConstraints,\r\n      getNodeDefaults: this.nodeDefaults.bind(this),\r\n      scrollSettings: this.scrollSettings,\r\n      selectedItems: this.selectedItems,\r\n      rulerSettings: this.rulerSettings,\r\n      dragEnter: this.dragEnter.bind(this),\r\n      connectionChange: this.change.bind(this),\r\n      collectionChange: this.collectionChange.bind(this),\r\n      propertyChange: this.propertyChange.bind(this),\r\n      selectionChange: this.selectionChange.bind(this),\r\n    }, this.diagramEl.nativeElement);\r\n    paletteIconClick();\r\n    this._pane.paramsChange.pipe(takeUntil(this._destroy)).subscribe(p => {\r\n      const id = p['id'];\r\n      this._form = this._session.profile.forms.find(f => f.name === id);\r\n      this._pane.title = this._form.title;\r\n      this.params = { id: this._form.name };\r\n    });\r\n    this._pane.dataChange.pipe(takeUntil(this._destroy)).subscribe(d => {\r\n      Object.assign(this._form, d.form);\r\n      const flow = this._form.workflow;\r\n      this.diagram.nodes = flow.nodes;\r\n      this.diagram.connectors = flow.connectors;\r\n      this.diagram.dataBind();\r\n      this.diagram.add(this._versionNode(flow.version));\r\n      this.diagram.fitToPage();\r\n      this.dirty = false;\r\n    });\r\n  }\r\n  private _palettes() {\r\n    this._session.profile.nodes.forEach(n => {\r\n      const node: NodeModel = {\r\n        id: n.name,\r\n        shape: n.shape,\r\n        addInfo: {\r\n          nodeType: n.name,\r\n          title: n.title\r\n        },\r\n        width: 145,\r\n        height: 145,\r\n      };\r\n      (node as any).node = n.name;\r\n      let palette = this.palettes.find(p => p.title === (n.palette || ''));\r\n      if (!palette) {\r\n        palette = { id: `_${n.palette}`, expanded: true, title: n.palette || '', symbols: [] };\r\n        this.palettes.push(palette);\r\n      }\r\n      palette.symbols.push(node);\r\n    });\r\n    this.palettes.push({\r\n      id: 'design',\r\n      title: this._translate.get('Design'),\r\n      symbols: [{\r\n        id: 'Link22',\r\n        type: 'Straight',\r\n        sourcePoint: { x: 0, y: 0 },\r\n        targetPoint: { x: 60, y: 60 },\r\n        targetDecorator: {\r\n          shape: 'Arrow',\r\n          style: { strokeColor: '#757575', fill: '#757575' },\r\n        },\r\n        style: {\r\n          strokeWidth: 1,\r\n          strokeDashArray: '4 4',\r\n          strokeColor: '#757575',\r\n        }\r\n      },\r\n      {\r\n        id: 'text', shape: { type: 'Text', content: 'T' },\r\n        style: {\r\n          fill: 'transparent'\r\n        },\r\n        constraints: NodeConstraints.Default & ~NodeConstraints.InConnect & ~NodeConstraints.OutConnect,\r\n        addInfo: { title: this._translate.get('Text') }\r\n      }]\r\n    });\r\n    const color = MATERIAL_PALETTES['grey'][200];\r\n    this.palettes.push({\r\n      id: 'swimlaneShapes',\r\n      expanded: true,\r\n      title: this._translate.get('Swimlane Shapes'),\r\n      symbols: [\r\n        {\r\n          id: 'swimlane',\r\n          addInfo: {\r\n            title: this._translate.get('Horizontal')\r\n          },\r\n          shape: {\r\n            header: {\r\n              annotation: { content: 'Plan' }\r\n            },\r\n            type: 'SwimLane',\r\n            lanes: [\r\n              {\r\n                id: 'lane1',\r\n                header: {\r\n                  annotation: { content: 'Lane' },\r\n                  style: { fill: color }\r\n                }\r\n              }\r\n            ],\r\n            orientation: 'Horizontal',\r\n            isLane: true\r\n          },\r\n          height: 60,\r\n          width: 140,\r\n          offsetX: 70,\r\n          offsetY: 30,\r\n        }, {\r\n          id: 'vswimlane',\r\n          addInfo: {\r\n            title: this._translate.get('Vertical')\r\n          },\r\n          shape: {\r\n            type: 'SwimLane',\r\n            header: {\r\n              annotation: { content: 'Plan' }\r\n            },\r\n            lanes: [\r\n              {\r\n                id: 'lane1',\r\n                header: {\r\n                  annotation: { content: 'Lane' },\r\n                  style: { fill: color }\r\n                }\r\n              }\r\n            ],\r\n            orientation: 'Vertical', isLane: true\r\n          },\r\n          height: 140,\r\n          width: 60,\r\n          offsetX: 70,\r\n          offsetY: 30,\r\n        }, {\r\n          id: 'vphase',\r\n          addInfo: {\r\n            title: this._translate.get('Phase')\r\n          },\r\n          shape: {\r\n            type: 'SwimLane',\r\n            phases: [\r\n              {\r\n                style: { strokeWidth: 1, strokeDashArray: '3,3', strokeColor: color },\r\n                header: {\r\n                  annotation: { text: 'Phase' }\r\n                }\r\n              }],\r\n            orientation: 'Vertical', isPhase: true\r\n          },\r\n          height: 60,\r\n          width: 140,\r\n          style: { strokeColor: color }\r\n        }, {\r\n          id: 'hphase',\r\n          addInfo: {\r\n            title: this._translate.get('Phase')\r\n          },\r\n          shape: {\r\n            type: 'SwimLane',\r\n            phases: [{\r\n              style: { strokeWidth: 1, strokeDashArray: '3,3', strokeColor: color },\r\n              header: {\r\n                annotation: { text: 'Phase' }\r\n              }\r\n            }],\r\n            orientation: 'Horizontal', isPhase: true\r\n          },\r\n          height: 60,\r\n          width: 140,\r\n          style: { strokeColor: color }\r\n        }]\r\n    } as PaletteModel);\r\n  }\r\n  private _versionNode(version: number): NodeModel {\r\n    return {\r\n      id: 'version',\r\n      shape: {\r\n        type: 'Text',\r\n        content: this._translate.get('DiagramVersion', version || 0)\r\n      },\r\n      offsetY: 5,\r\n      offsetX: 5,\r\n      style: {\r\n        fontSize: 50,\r\n        color: this._session.theme.dark ? 'white' : 'black',\r\n        opacity: .1\r\n      } as TextStyleModel,\r\n      constraints: NodeConstraints.ReadOnly,\r\n      zIndex: -1\r\n    };\r\n  }\r\n  nodeDefaults = (obj: NodeModel): NodeModel => {\r\n    switch (obj.shape.type) {\r\n      case 'SwimLane':\r\n        break;\r\n      case 'Text':\r\n        if (obj.id !== 'version')\r\n          obj.constraints = NodeConstraints.Default & ~NodeConstraints.InConnect & ~NodeConstraints.OutConnect;\r\n        break;\r\n      default:\r\n        if (obj.addInfo && obj.addInfo['nodeType']) {\r\n          obj.constraints = NodeConstraints.Default | NodeConstraints.AspectRatio;\r\n          obj.style.strokeColor = this._session.theme.dark ? 'white' : 'black';\r\n          obj.ports = ports;\r\n        }\r\n        break;\r\n    }\r\n    return obj;\r\n  }\r\n  public connDefaults = (obj: ConnectorModel) => {\r\n    obj.constraints = ConnectorConstraints.Default | ConnectorConstraints.Bridging;\r\n    obj.style.strokeColor = this._session.theme.dark ? 'white' : 'black';\r\n    if (!obj.type) obj.type = this.connectorType;\r\n    return obj;\r\n  }\r\n  public getSymbolInfo(symbol: NodeModel): SymbolInfo {\r\n    return symbol.addInfo ? {\r\n      fit: true,\r\n      tooltip: (symbol.addInfo as any).title,\r\n      description: { text: (symbol.addInfo as any).title, overflow: 'Wrap', wrap: 'WrapWithOverflow' }\r\n    } : null;\r\n  }\r\n  public getSymbolDefaults(symbol: NodeModel): void {\r\n    symbol.width = symbol.height = 40;\r\n  }\r\n  pan() {\r\n    this.diagram.constraints = this.diagram.constraints | DiagramConstraints.Pan;\r\n    this.diagram.tool = DiagramTools.ZoomPan;\r\n  }\r\n  cursor() {\r\n    this.diagram.constraints = this.diagram.constraints & ~DiagramConstraints.Pan;\r\n    this.diagram.tool = DiagramTools.Default;\r\n  }\r\n  selectionChange(evt: ISelectionChangeEventArgs) {\r\n    const { newValue, state } = evt;\r\n    if (state !== 'Changing' || !newValue.length) {\r\n      this._nodedestroy.next();\r\n      return;\r\n    }\r\n    const connectors = newValue.filter(n => n instanceof Connector).map(n => n as ConnectorModel);\r\n    if (connectors.length) {\r\n      const connector = connectors[0],\r\n        type = connector.type;\r\n      this.connectorType = connectors.length === 1 ||\r\n        connectors.every(c => c.type === type) ? type : null;\r\n      if (connector.annotations.length && connector.annotations[0].style)\r\n        this.fontSize = connector.annotations[0].style.fontSize;\r\n      this.connectorType = connectors.length === 1 ||\r\n        connectors.every(c => c.type === type) ? type : null;\r\n    }\r\n    const nodes = newValue.filter(n => n instanceof Node);\r\n    if (nodes.length) {\r\n      const node = nodes[0], addInfo = node.addInfo as any;\r\n      if (!addInfo || !addInfo['nodeType'])\r\n        return;\r\n      if (node.annotations.length && node.annotations[0].style)\r\n        this.fontSize = node.annotations[0].style.fontSize;\r\n    }\r\n    this._router.navigate(WorkflowNodeComponent, {\r\n      state: {\r\n        diagram: this.diagram,\r\n        nodes,\r\n        connectors\r\n      },\r\n      policy: OpenPolicy.Tab,\r\n      expandable: false,\r\n      group: ''\r\n    }).then(p => {\r\n      p.instance.change.pipe(takeUntil(this._nodedestroy)).subscribe(() => this.change());\r\n      this._nodedestroy.pipe(first()).subscribe(() => p.close())\r\n    });\r\n  }\r\n  align(value: AlignmentOptions) {\r\n    this.diagram.selectedItems.nodes.forEach(n => {\r\n      n.annotations.length && Object.assign(n.annotations[0], {\r\n        offset: {\r\n          x: value === 'Right' ? 1 : value === 'Left' ? 0 : .5,\r\n          y: value === 'Top' ? 0 : value === 'Bottom' ? 1 : .5\r\n        },\r\n        verticalAlignment: value === 'Top' ? 'Bottom' : value === 'Bottom' ? 'Top' : 'Center',\r\n        horizontalAlignment: value === 'Right' ? 'Left' : value === 'Left' ? 'Right' : 'Center'\r\n      });\r\n    });\r\n    this.diagram.selectedItems.connectors.forEach(c =>\r\n      c.annotations.forEach(a => Object.assign(a, {\r\n        verticalAlignment: value === 'Top' ? 'Bottom' : value === 'Bottom' ? 'Top' : 'Center',\r\n        horizontalAlignment: value === 'Left' ? 'Left' : value === 'Right' ? 'Right' : 'Center',\r\n        //  displacement: {\r\n        //    x: value === 'Right' ? 10 : value === 'Left' ? -10 : 0,\r\n        //    y: value === 'Top' ? -10 : value === 'Bottom' ? 10 : 0\r\n        //  }\r\n      }))\r\n    );\r\n    this.alignment = value;\r\n    this.dirty = true;\r\n  }\r\n  public dragEnter(args: IDragEnterEventArgs): void {\r\n    if (args.element instanceof Node) {\r\n      switch (args.element.shape.type) {\r\n        case 'SwimLane':\r\n          {\r\n            const shape = args.element.shape as SwimLaneModel;\r\n            switch (shape.orientation) {\r\n              case 'Horizontal':\r\n                shape.lanes[0].width = 400;\r\n                break;\r\n              case 'Vertical':\r\n                shape.lanes[0].height = 400;\r\n                break;\r\n            }\r\n            break;\r\n          }\r\n        case 'Text':\r\n          //(args.element.style as TextStyleModel).fontSize = 20;\r\n          break;\r\n        default:\r\n          {\r\n            const { width, height } = args.element;\r\n            args.element.width = 100;\r\n            args.element.height *= 100 / width;\r\n            args.element.offsetX += (args.element.width - width) / 2;\r\n            args.element.offsetY += (args.element.height - height) / 2;\r\n            args.element.style = {\r\n              fill: 'transparent',\r\n              strokeColor: this._session.theme.dark ? 'white' : 'black',\r\n              strokeWidth: 1\r\n            };\r\n          }\r\n      }\r\n    }\r\n  }\r\n  propertyChange(e) {\r\n    if (e.cause !== 2) this.dirty = true;\r\n  }\r\n  change() {\r\n    this.dirty = true;\r\n  }\r\n  collectionChange() {\r\n    this._router.collapse();\r\n    this.dirty = true;\r\n  }\r\n  /**\r\n   * Ctrl-s save\r\n   * @param event\r\n   */\r\n  @HostListener('document:keydown', ['$event'])\r\n  handleKeyboardEvent(event: KeyboardEvent) {\r\n    if (this.dirty && event.ctrlKey && (event.which === 83 || event.which === 115)) {\r\n      this.save();\r\n      event.preventDefault();\r\n    }\r\n  }\r\n  bgChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.style.fill = val);\r\n    this.dirty = true;\r\n  }\r\n  colorChange(val: string) {\r\n    this.diagram.selectedItems.nodes.forEach(n => n.annotations.forEach(a => a.style.color = val));\r\n    this.diagram.selectedItems.connectors.forEach(c => c.annotations.forEach(a => a.style.color = val));\r\n    this.dirty = true;\r\n  }\r\n  connectorTypeChange(type: Segments) {\r\n    this.diagram.selectedItems.connectors.forEach(c => c.type = type);\r\n    this.connectorType = type;\r\n    this.dirty = true;\r\n  }\r\n  boldChange() {\r\n    const val = !this.diagram.selectedItems.nodes[0].annotations[0]?.style?.bold;\r\n    function change(node: (NodeModel | ConnectorModel)) {\r\n      if (node.shape.type === 'Text')\r\n        (node.style as TextStyleModel).bold = val;\r\n      else node.annotations.forEach(a => {\r\n        if (!a.style)\r\n          a.style = { bold: val };\r\n        else\r\n          a.style.bold = val;\r\n      });\r\n    }\r\n    this.diagram.selectedItems.nodes.forEach(change);\r\n    this.diagram.selectedItems.connectors.forEach(change);\r\n    this.diagram.dataBind();\r\n  }\r\n  italicChange() {\r\n    const val = !this.diagram.selectedItems.nodes[0].annotations[0]?.style?.italic;\r\n    function change(node: (NodeModel | ConnectorModel)) {\r\n      if (node.shape.type === 'Text')\r\n        (node.style as TextStyleModel).italic = val;\r\n      else node.annotations.forEach(a => {\r\n        if (!a.style)\r\n          a.style = { italic: val };\r\n        else\r\n          a.style.italic = val;\r\n      });\r\n    }\r\n    this.diagram.selectedItems.nodes.forEach(change);\r\n    this.diagram.selectedItems.connectors.forEach(change);\r\n    this.diagram.dataBind();\r\n  }\r\n  fontSizeChange(val: number) {\r\n    function change(node: (NodeModel | ConnectorModel)) {\r\n      if (node.shape.type === 'Text')\r\n        (node.style as TextStyleModel).fontSize = val;\r\n      else (node as NodeModel).annotations?.forEach(a => {\r\n        if (!a.style)\r\n          a.style = { fontSize: val };\r\n        else\r\n          a.style.fontSize = val;\r\n      });\r\n    }\r\n    this.diagram.selectedItems.nodes.forEach(change);\r\n    this.diagram.selectedItems.connectors.forEach(change);\r\n    this.diagram.dataBind();\r\n  }\r\n  strokeChange(val: string) {\r\n    this.diagram.selectedItems.connectors.forEach(c => {\r\n      c.style.strokeColor = val;\r\n      if (c.annotations) c.annotations[0].style.color = val;\r\n    });\r\n    this.diagram.selectedItems.nodes.forEach(n => n.style.strokeColor = val);\r\n    this.dirty = true;\r\n  }\r\n  save(): Promise<any> {\r\n    this.diagram.serializationSettings = { preventDefaults: true };\r\n    const obj = JSON.parse(this.diagram.saveDiagram()) as DiagramModel;\r\n    this._form.workflow.connectors = obj.connectors;\r\n    this._form.workflow.nodes = obj.nodes.filter(n => n.id !== 'version');\r\n    this.saving = true;\r\n    return this._service.save(this._form).toPromise().then(v => {\r\n      this.ps.toast('ChangesSaved');\r\n      if (this._form.workflow.version < v) {\r\n        this.ps.toast('DiagramVersion', v);\r\n        const node = this.diagram.getNodeObject('version');\r\n        (node.shape as TextModel).content = this._translate.get('DiagramVersion', v);\r\n        this.diagram.dataBind();\r\n      }\r\n      this._form.workflow.version = v;\r\n      this.dirty = false;\r\n      this.saving = false;\r\n    }, () => {\r\n      this.ps.error();\r\n      this.saving = false;\r\n    });\r\n  }\r\n  ngOnDestroy(): void {\r\n    this.symbolPalette?.destroy();\r\n    this.diagram?.destroy();\r\n    this._destroy.next();\r\n    this._destroy.complete();\r\n    this._nodedestroy.next();\r\n    this._nodedestroy.complete();\r\n  }\r\n}\r\n","<mat-toolbar>\r\n  <button mat-icon-button (click)=\"tools = !tools\" [bizdocTooltip]=\"'Collapse' | translate\"><mat-icon>view_sidebar</mat-icon></button>\r\n  <button mat-button (click)=\"save()\" color=\"primary\" [disabled]=\"!dirty || saving\">{{'SaveChanges' | translate}}</button>\r\n  <button mat-icon-button (click)=\"diagram.fitToPage()\" [bizdocTooltip]=\"'FitToPage' | translate\"><mat-icon>fullscreen_exit</mat-icon></button>\r\n  <button mat-icon-button (click)=\"pan()\" [bizdocTooltip]=\"'Pan' | translate\"><span class=\"e-icons sf-icon-pan\"></span></button>\r\n  <button mat-icon-button (click)=\"cursor()\" [bizdocTooltip]=\"'Cursor' | translate\"><span class=\"e-icons sf-icon-cursor\"></span></button>\r\n  <span class=\"tools-divider\"></span>\r\n  <button mat-icon-button (click)=\"diagram.undo()\" [bizdocTooltip]=\"'Undo' | translate\" [disabled]=\"!diagram.historyManager?.canUndo\"><mat-icon>undo</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.redo()\" [bizdocTooltip]=\"'Redo' | translate\" [disabled]=\"!diagram.historyManager?.canRedo\"><mat-icon>redo</mat-icon></button>\r\n  <span class=\"tools-divider\"></span>\r\n  <button mat-icon-button (click)=\"diagram.copy()\" [bizdocTooltip]=\"'Copy' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>copy</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.paste()\" [bizdocTooltip]=\"'Paste' | translate\"><mat-icon>paste</mat-icon></button>\r\n  <button mat-icon-button (click)=\"diagram.remove()\" [bizdocTooltip]=\"'Remove' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>delete</mat-icon></button>\r\n  <span class=\"tools-divider\"></span>\r\n  <button mat-button [matMenuTriggerFor]=\"lineMenu\" [disabled]=\"diagram.selectedItems?.connectors.length === 0\" [bizdocTooltip]=\"'ConnectorMode'|translate\">\r\n    <span class=\"e-menu-icon\" [ngClass]=\"{'sf-icon-straight-line': connectorType === 'Straight',\r\n          'sf-icon-orthogonal-line': connectorType === 'Orthogonal',\r\n          'sf-icon-beizer-line': connectorType === 'Bezier'}\"></span>\r\n    <mat-icon>arrow_drop_down</mat-icon>\r\n  </button>\r\n  <mat-menu #lineMenu overlayPanelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Straight')\">\r\n      <span class=\"e-menu-icon sf-icon-straight-line\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Orthogonal')\">\r\n      <span class=\"e-menu-icon sf-icon-orthogonal-line\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"connectorTypeChange('Bezier')\">\r\n      <span class=\"e-menu-icon sf-icon-beizer-line\"></span>\r\n    </button>\r\n    <!--<ng-container *ngIf=\"connectors.length\">\r\n      < bizdoc-color-picker (valueChanges)='strokeChange($event)' [label]=\"'Stroke'|translate\"></ bizdoc-color-picker>\r\n      <ng-container *ngIf=\"nodes[0].annotations.length\">\r\n        < bizdoc-color-picker (valueChanges)='colorChange($event)' [label]=\"'Color'|translate\"></ bizdoc-color-picker>\r\n      </ng-container>\r\n      < bizdoc-color-picker (valueChanges)='bgChange($event)' [label]=\"'Background'|translate\"></ bizdoc-color-picker>\r\n      < bizdoc-color-picker (valueChanges)='strokeChange($event)' [label]=\"'Stroke'|translate\"></ bizdoc-color-picker>\r\n    </ng-container>-->\r\n  </mat-menu>\r\n  &nbsp;\r\n  <button mat-button [matMenuTriggerFor]=\"alignMenu\" [disabled]=\"diagram.selectedItems?.nodes.length === 0 && diagram.selectedItems?.connectors.length === 0\" [bizdocTooltip]=\"'Align'|translate\">\r\n    <span class=\"e-icons\" [ngClass]=\"{'sf-icon-top': alignment === 'Top',\r\n          'sf-icon-left': alignment === 'Left',\r\n          'sf-icon-center': alignment === 'Center',\r\n          'sf-icon-bottom': alignment === 'Bottom',\r\n          'sf-icon-right': alignment === 'Right'}\"></span>\r\n    <mat-icon>arrow_drop_down</mat-icon>\r\n  </button>\r\n  <mat-menu #alignMenu overlayPanelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item (click)=\"align('Top')\">\r\n      <span class=\"e-icons sf-icon-top\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Left')\">\r\n      <span class=\"e-icons sf-icon-left\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Center')\">\r\n      <span class=\"e-icons sf-icon-center\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Right')\">\r\n      <span class=\"e-icons sf-icon-right\"></span>\r\n    </button>\r\n    <button mat-menu-item (click)=\"align('Bottom')\">\r\n      <span class=\"e-icons sf-icon-bottom\"></span>\r\n    </button>\r\n  </mat-menu>\r\n  <button mat-icon-button (click)=\"boldChange()\" [bizdocTooltip]=\"'Bold' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>format_bold</mat-icon></button>\r\n  <button mat-icon-button (click)=\"italicChange()\" [bizdocTooltip]=\"'Italic' | translate\" [disabled]=\"diagram.selectedItems?.connectors.length === 0 && diagram.selectedItems?.nodes.length === 0\"><mat-icon>format_italic</mat-icon></button>\r\n  <button mat-icon-button [matMenuTriggerFor]=\"sizeMenu\"\r\n          [disabled]=\"diagram.selectedItems?.nodes.length === 0 && diagram.selectedItems?.connectors.length === 0\"\r\n          [bizdocTooltip]=\"'FontSize'|translate\">\r\n    <mat-icon>format_size</mat-icon>\r\n  </button>\r\n  <mat-menu #sizeMenu overlayPanelClass=\"icon-menu-panel\">\r\n    <button mat-menu-item *ngFor=\"let size of fontSizes\" (click)=\"fontSizeChange(size)\">\r\n      {{size}}\r\n    </button>\r\n  </mat-menu>\r\n  <span class=\"divider\"></span>\r\n</mat-toolbar>\r\n<div class=\"row container\">\r\n  <div id=\"symbolpalette\" [style.display]=\"tools?'':'none'\">\r\n    <div dir=\"ltr\" #symbolPaletteEl>\r\n    </div>\r\n  </div>\r\n  <div #diagramEl id=\"diagram\" fxFlex dir=\"ltr\">\r\n  </div>\r\n</div>\r\n"]}
|