@cuby-ui/core 0.0.491 → 0.0.493

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/esm2022/widgets/ui/criterion-info/criterion-info.component.mjs +21 -12
  2. package/esm2022/widgets/ui/criterion-info-form/criterion-info-form.component.mjs +27 -15
  3. package/esm2022/widgets/ui/criterion-info-form/criterion-info-form.options.mjs +1 -1
  4. package/esm2022/widgets/ui/criterion-readonly-info/criterion-readonly-info.component.mjs +26 -21
  5. package/esm2022/widgets/ui/index.mjs +8 -4
  6. package/esm2022/widgets/ui/instruction-info/instruction-info.component.mjs +11 -12
  7. package/esm2022/widgets/ui/instruction-info-form/instruction-info-form.component.mjs +18 -12
  8. package/esm2022/widgets/ui/instruction-readonly-info/instruction-readonly-info.component.mjs +26 -21
  9. package/esm2022/widgets/ui/utility-modal/components/criterion-modal-create/criterion-modal-create.component.mjs +4 -3
  10. package/esm2022/widgets/ui/utility-modal/components/index.mjs +3 -1
  11. package/esm2022/widgets/ui/utility-modal/components/instruction-modal-create/instruction-modal-create.component.mjs +4 -4
  12. package/esm2022/widgets/ui/utility-modal/components/readonly-criterion-modal/readonly-criterion-modal.component.mjs +13 -7
  13. package/esm2022/widgets/ui/utility-modal/components/readonly-instruction-modal/readonly-instruction-modal.component.mjs +11 -5
  14. package/esm2022/widgets/ui/utility-modal/utility-modal.options.mjs +1 -1
  15. package/esm2022/widgets/ui/utility-thumbnail/utility-thumbnail.component.mjs +6 -7
  16. package/fesm2022/cuby-ui-core.mjs +245 -201
  17. package/fesm2022/cuby-ui-core.mjs.map +1 -1
  18. package/package.json +4 -4
  19. package/widgets/ui/criterion-info/criterion-info.component.d.ts +6 -7
  20. package/widgets/ui/criterion-info-form/criterion-info-form.component.d.ts +6 -2
  21. package/widgets/ui/criterion-info-form/criterion-info-form.options.d.ts +2 -0
  22. package/widgets/ui/criterion-readonly-info/criterion-readonly-info.component.d.ts +10 -9
  23. package/widgets/ui/index.d.ts +7 -3
  24. package/widgets/ui/instruction-info/instruction-info.component.d.ts +2 -4
  25. package/widgets/ui/instruction-info-form/instruction-info-form.component.d.ts +2 -2
  26. package/widgets/ui/instruction-readonly-info/instruction-readonly-info.component.d.ts +10 -9
  27. package/widgets/ui/utility-modal/components/criterion-modal-create/criterion-modal-create.component.d.ts +3 -1
  28. package/widgets/ui/utility-modal/components/index.d.ts +2 -0
  29. package/widgets/ui/utility-modal/components/instruction-modal-create/instruction-modal-create.component.d.ts +3 -2
  30. package/widgets/ui/utility-modal/components/readonly-criterion-modal/readonly-criterion-modal.component.d.ts +10 -3
  31. package/widgets/ui/utility-modal/components/readonly-instruction-modal/readonly-instruction-modal.component.d.ts +10 -3
  32. package/widgets/ui/utility-modal/utility-modal.options.d.ts +3 -3
  33. package/widgets/ui/utility-thumbnail/utility-thumbnail.component.d.ts +2 -3
@@ -4,11 +4,10 @@ export { CuiLinearLoaderComponent } from './linear-loader';
4
4
  export { CuiDeleteModalComponent } from './delete-modal';
5
5
  export { CuiCategoriesComponent, CuiSelectedCategoryService } from './categories';
6
6
  export { CuiChecklistBlockComponent } from './checklist-block';
7
- export { CuiInstructionReadonlyInfoComponent } from './instruction-readonly-info';
8
- export { CuiCriterionInfoComponent } from './criterion-info';
9
- export { CuiInstructionInfoComponent } from './instruction-info';
10
7
  export { CuiGeneralControlErrorHintComponent } from './general-control-error-hint';
11
8
  export { CuiFramerPreviewComponent } from './framer-preview';
9
+ export * from './criterion-info';
10
+ export * from './instruction-info';
12
11
  export * from './instruction-info-form';
13
12
  export * from './select-modal';
14
13
  export * from './storage-list';
@@ -26,5 +25,10 @@ export * from './resources-block';
26
25
  export * from './utility-info-readonly';
27
26
  export * from './inserted';
28
27
  export * from './instruction-readonly-info';
28
+ export * from './criterion-readonly-info';
29
29
  export * from './button-change-theme';
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvdWkvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLDBCQUEwQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxtQ0FBbUMsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ2xGLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQzdELE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxtQ0FBbUMsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ25GLE9BQU8sRUFBRSx5QkFBeUIsRUFBZSxNQUFNLGtCQUFrQixDQUFDO0FBQzFFLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyx1QkFBdUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEN1aVN0YXRlZExvYWRlckNvbXBvbmVudCB9IGZyb20gJy4vc3RhdGVkLWxvYWRlcic7XG5leHBvcnQgeyBDdWlDaXJjbGVMb2FkZXJDb21wb25lbnQgfSBmcm9tICcuL2NpcmNsZS1sb2FkZXInO1xuZXhwb3J0IHsgQ3VpTGluZWFyTG9hZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9saW5lYXItbG9hZGVyJztcbmV4cG9ydCB7IEN1aURlbGV0ZU1vZGFsQ29tcG9uZW50IH0gZnJvbSAnLi9kZWxldGUtbW9kYWwnO1xuZXhwb3J0IHsgQ3VpQ2F0ZWdvcmllc0NvbXBvbmVudCwgQ3VpU2VsZWN0ZWRDYXRlZ29yeVNlcnZpY2UgfSBmcm9tICcuL2NhdGVnb3JpZXMnO1xuZXhwb3J0IHsgQ3VpQ2hlY2tsaXN0QmxvY2tDb21wb25lbnQgfSBmcm9tICcuL2NoZWNrbGlzdC1ibG9jayc7XG5leHBvcnQgeyBDdWlJbnN0cnVjdGlvblJlYWRvbmx5SW5mb0NvbXBvbmVudCB9IGZyb20gJy4vaW5zdHJ1Y3Rpb24tcmVhZG9ubHktaW5mbyc7XG5leHBvcnQgeyBDdWlDcml0ZXJpb25JbmZvQ29tcG9uZW50IH0gZnJvbSAnLi9jcml0ZXJpb24taW5mbyc7XG5leHBvcnQgeyBDdWlJbnN0cnVjdGlvbkluZm9Db21wb25lbnQgfSBmcm9tICcuL2luc3RydWN0aW9uLWluZm8nO1xuZXhwb3J0IHsgQ3VpR2VuZXJhbENvbnRyb2xFcnJvckhpbnRDb21wb25lbnQgfSBmcm9tICcuL2dlbmVyYWwtY29udHJvbC1lcnJvci1oaW50JztcbmV4cG9ydCB7IEN1aUZyYW1lclByZXZpZXdDb21wb25lbnQsIEN1aUltYWdlVXJsIH0gZnJvbSAnLi9mcmFtZXItcHJldmlldyc7XG5leHBvcnQgKiBmcm9tICcuL2luc3RydWN0aW9uLWluZm8tZm9ybSc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC1tb2RhbCc7XG5leHBvcnQgKiBmcm9tICcuL3N0b3JhZ2UtbGlzdCc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxpdHktbW9kYWwnO1xuZXhwb3J0ICogZnJvbSAnLi91c2VyLWFjdGlvbi1jb250ZXh0LW1lbnUnO1xuZXhwb3J0ICogZnJvbSAnLi9hc3NpZ25lZS1yb2xlLWl0ZW0nO1xuZXhwb3J0ICogZnJvbSAnLi9hc3NpZ25lZS1yb2xlcy10YWJzJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtZGl2aWRlZC1zZWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtaGVhZGVyLWluc2VydGVkLWJ1dHRvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RhbC1pbmZvLXRhYic7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsLW9wZXJhdGlvbi1wYXJ0JztcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtcmVzb3VyY2VzLXRhYic7XG5leHBvcnQgKiBmcm9tICcuL3JlbmRlci1keW5hbWljLW1vZGFsJztcbmV4cG9ydCAqIGZyb20gJy4vcmVzb3VyY2VzLWJsb2NrJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbGl0eS1pbmZvLXJlYWRvbmx5JztcbmV4cG9ydCAqIGZyb20gJy4vaW5zZXJ0ZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnN0cnVjdGlvbi1yZWFkb25seS1pbmZvJztcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uLWNoYW5nZS10aGVtZSdcbiJdfQ==
30
+ export * from './criterion-info-form';
31
+ export * from './utility-modal';
32
+ export * from './utility-readonly-thumbnail';
33
+ export * from './utility-thumbnail';
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL3dpZGdldHMvdWkvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDM0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDekQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLDBCQUEwQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxtQ0FBbUMsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ25GLE9BQU8sRUFBRSx5QkFBeUIsRUFBZSxNQUFNLGtCQUFrQixDQUFDO0FBQzFFLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyx1QkFBdUIsQ0FBQTtBQUNyQyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgQ3VpU3RhdGVkTG9hZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9zdGF0ZWQtbG9hZGVyJztcbmV4cG9ydCB7IEN1aUNpcmNsZUxvYWRlckNvbXBvbmVudCB9IGZyb20gJy4vY2lyY2xlLWxvYWRlcic7XG5leHBvcnQgeyBDdWlMaW5lYXJMb2FkZXJDb21wb25lbnQgfSBmcm9tICcuL2xpbmVhci1sb2FkZXInO1xuZXhwb3J0IHsgQ3VpRGVsZXRlTW9kYWxDb21wb25lbnQgfSBmcm9tICcuL2RlbGV0ZS1tb2RhbCc7XG5leHBvcnQgeyBDdWlDYXRlZ29yaWVzQ29tcG9uZW50LCBDdWlTZWxlY3RlZENhdGVnb3J5U2VydmljZSB9IGZyb20gJy4vY2F0ZWdvcmllcyc7XG5leHBvcnQgeyBDdWlDaGVja2xpc3RCbG9ja0NvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tsaXN0LWJsb2NrJztcbmV4cG9ydCB7IEN1aUdlbmVyYWxDb250cm9sRXJyb3JIaW50Q29tcG9uZW50IH0gZnJvbSAnLi9nZW5lcmFsLWNvbnRyb2wtZXJyb3ItaGludCc7XG5leHBvcnQgeyBDdWlGcmFtZXJQcmV2aWV3Q29tcG9uZW50LCBDdWlJbWFnZVVybCB9IGZyb20gJy4vZnJhbWVyLXByZXZpZXcnO1xuZXhwb3J0ICogZnJvbSAnLi9jcml0ZXJpb24taW5mbyc7XG5leHBvcnQgKiBmcm9tICcuL2luc3RydWN0aW9uLWluZm8nO1xuZXhwb3J0ICogZnJvbSAnLi9pbnN0cnVjdGlvbi1pbmZvLWZvcm0nO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QtbW9kYWwnO1xuZXhwb3J0ICogZnJvbSAnLi9zdG9yYWdlLWxpc3QnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlsaXR5LW1vZGFsJztcbmV4cG9ydCAqIGZyb20gJy4vdXNlci1hY3Rpb24tY29udGV4dC1tZW51JztcbmV4cG9ydCAqIGZyb20gJy4vYXNzaWduZWUtcm9sZS1pdGVtJztcbmV4cG9ydCAqIGZyb20gJy4vYXNzaWduZWUtcm9sZXMtdGFicyc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsLWRpdmlkZWQtc2VjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsLWhlYWRlci1pbnNlcnRlZC1idXR0b25zJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kYWwtaW5mby10YWInO1xuZXhwb3J0ICogZnJvbSAnLi9tb2RhbC1vcGVyYXRpb24tcGFydCc7XG5leHBvcnQgKiBmcm9tICcuL21vZGFsLXJlc291cmNlcy10YWInO1xuZXhwb3J0ICogZnJvbSAnLi9yZW5kZXItZHluYW1pYy1tb2RhbCc7XG5leHBvcnQgKiBmcm9tICcuL3Jlc291cmNlcy1ibG9jayc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxpdHktaW5mby1yZWFkb25seSc7XG5leHBvcnQgKiBmcm9tICcuL2luc2VydGVkJztcbmV4cG9ydCAqIGZyb20gJy4vaW5zdHJ1Y3Rpb24tcmVhZG9ubHktaW5mbyc7XG5leHBvcnQgKiBmcm9tICcuL2NyaXRlcmlvbi1yZWFkb25seS1pbmZvJztcbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uLWNoYW5nZS10aGVtZSdcbmV4cG9ydCAqIGZyb20gJy4vY3JpdGVyaW9uLWluZm8tZm9ybSc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxpdHktbW9kYWwnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlsaXR5LXJlYWRvbmx5LXRodW1ibmFpbCc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxpdHktdGh1bWJuYWlsJztcbiJdfQ==
@@ -1,9 +1,9 @@
1
1
  import { ChangeDetectionStrategy, Component, computed, DestroyRef, effect, inject, input, model, output, signal, untracked, viewChild } from '@angular/core';
2
2
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
- import { TranslocoModule, TranslocoService } from '@jsverse/transloco';
4
- import { finalize, forkJoin } from 'rxjs';
5
3
  import { CuiTreeStructNavigatorApiService } from '@cuby-ui/api';
6
4
  import { CuiIdService } from '@cuby-ui/cdk';
5
+ import { TranslocoModule, TranslocoService } from '@jsverse/transloco';
6
+ import { finalize, forkJoin } from 'rxjs';
7
7
  import { CuiBadgeModule, CuiButtonModule, CuiDialogModule, CuiFormFieldModule, CuiLabelModule, CuiSvgModule } from '../../../components';
8
8
  import { CuiCategoriesComponent, CuiSelectedCategoryService } from '../categories';
9
9
  import { CuiInstructionInfoFormComponent } from '../instruction-info-form';
@@ -32,8 +32,7 @@ export class CuiInstructionInfoComponent {
32
32
  this.selectTitle = computed(() => this.category()?.title || this.translocoService.translate('SELECT') + '...');
33
33
  this.element = viewChild('scrollContent');
34
34
  this.instruction = model();
35
- this.tools = input.required();
36
- this.editorResourceUrl = input.required();
35
+ this.config = input.required();
37
36
  this.validationChanged = output();
38
37
  this.instructionCreated = output();
39
38
  this.initConfigEffect();
@@ -76,7 +75,7 @@ export class CuiInstructionInfoComponent {
76
75
  if (!element) {
77
76
  return;
78
77
  }
79
- this.editorConfig.set({ tools: this.tools(), element });
78
+ this.editorConfig.set({ ...this.config(), element });
80
79
  });
81
80
  }
82
81
  initCategory() {
@@ -85,7 +84,7 @@ export class CuiInstructionInfoComponent {
85
84
  return;
86
85
  }
87
86
  this.treeStructNavigatorApiService
88
- .getCategory(storageObjectId, "INSTRUCTION_STORAGE" /* TreeStructType.Instruction */)
87
+ .getCategory(storageObjectId, "INSTRUCTION_STORAGE" /* TreeStructType.Instruction */, this.config().requestOptions)
89
88
  .pipe(takeUntilDestroyed(this.destroyRef))
90
89
  .subscribe((category) => {
91
90
  this.skipCategoryChange = true;
@@ -105,7 +104,7 @@ export class CuiInstructionInfoComponent {
105
104
  movableItemId: targetId,
106
105
  treeStructTargetItemId: categoryId,
107
106
  treeStructMovableItemId: prevCategoryId
108
- })
107
+ }, this.config().requestOptions)
109
108
  .subscribe(() => this.prevCategoryId.set(categoryId));
110
109
  }
111
110
  createInstruction(categoryId) {
@@ -113,7 +112,7 @@ export class CuiInstructionInfoComponent {
113
112
  this.prevCategoryId.set(categoryId);
114
113
  }
115
114
  changeTitle(value, instructionId) {
116
- return this.instructionApiService.changeTitle(instructionId, value).pipe(finalize(() => this.instruction.update((prev) => ({
115
+ return this.instructionApiService.changeTitle(instructionId, value, this.config().requestOptions).pipe(finalize(() => this.instruction.update((prev) => ({
117
116
  ...prev,
118
117
  storageElement: { ...prev.storageElement, title: value }
119
118
  }))));
@@ -122,13 +121,13 @@ export class CuiInstructionInfoComponent {
122
121
  if (!this.instructionApiService.changeDescription) {
123
122
  throw new Error('Change description not implemented');
124
123
  }
125
- return this.instructionApiService.changeDescription(instructionId, value).pipe(finalize(() => this.instruction.update((prev) => ({
124
+ return this.instructionApiService.changeDescription(instructionId, value, this.config().requestOptions).pipe(finalize(() => this.instruction.update((prev) => ({
126
125
  ...prev,
127
126
  storageElement: { ...prev.storageElement, shortDescription: value }
128
127
  }))));
129
128
  }
130
129
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiInstructionInfoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
131
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiInstructionInfoComponent, isStandalone: true, selector: "cui-instruction-info", inputs: { instruction: { classPropertyName: "instruction", publicName: "instruction", isSignal: true, isRequired: false, transformFunction: null }, tools: { classPropertyName: "tools", publicName: "tools", isSignal: true, isRequired: true, transformFunction: null }, editorResourceUrl: { classPropertyName: "editorResourceUrl", publicName: "editorResourceUrl", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { instruction: "instructionChange", validationChanged: "validationChanged", instructionCreated: "instructionCreated" }, providers: [CuiSelectedCategoryService], viewQueries: [{ propertyName: "element", first: true, predicate: ["scrollContent"], descendants: true, isSignal: true }], ngImport: i0, template: "<div\n class=\"wrapper\"\n *transloco=\"let t\"\n>\n <div\n #scrollContent\n class=\"content content_scrollable\"\n >\n <div class=\"category\">\n <cui-form-field>\n <label\n cuiLabel\n [for]=\"categoryId\"\n [isRequired]=\"true\"\n >\n {{ t('SELECT_CATEGORY') }}\n </label>\n <cui-categories\n [buttonId]=\"categoryId\"\n [treeStructType]=\"TYPE\"\n >\n <div class=\"select\">\n <span [style.color]=\"labelColor()\">\n {{ selectTitle() }}\n </span>\n\n <cui-svg icon=\"cuiIconChevronDown\" />\n </div>\n </cui-categories>\n </cui-form-field>\n </div>\n\n @let instructionData = instruction();\n @let editorConfigData = editorConfig();\n\n @if (editorConfigData && instructionData) {\n <cui-instruction-info-form\n [config]=\"editorConfigData\"\n [baseResourceUrl]=\"editorResourceUrl()\"\n [title]=\"instructionData.storageElement.title\"\n [description]=\"instructionData.storageElement.shortDescription\"\n [framerId]=\"instructionData.storageElement.framerInstructionId\"\n class=\"utility\"\n (isFormValidChanged)=\"onFormValidationChanged($event)\"\n (formChanged)=\"onFormChanged($event, instructionData.id)\"\n />\n }\n </div>\n</div>\n", styles: [".wrapper{display:flex;flex-direction:column;height:100%}.content{height:calc(100vh - 109px)}.content_scrollable{overflow:auto}.category{padding-top:16px;padding-right:23px;padding-left:23px}.select{padding:7px 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;height:36px;border-radius:8px;border:1px solid var(--cui-base-200);color:var(--cui-base-900);background:var(--cui-input)}.utility{--editor-height: none}\n"], dependencies: [{ kind: "ngmodule", type: CuiBadgeModule }, { kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: CuiCategoriesComponent, selector: "cui-categories", inputs: ["treeStructType", "buttonId", "disabled", "context"] }, { kind: "ngmodule", type: CuiDialogModule }, { kind: "ngmodule", type: CuiFormFieldModule }, { kind: "component", type: i1.CuiFormFieldComponent, selector: "cui-form-field" }, { kind: "component", type: CuiInstructionInfoFormComponent, selector: "cui-instruction-info-form", inputs: ["title", "description", "framerId", "baseResourceUrl", "config"], outputs: ["formChanged", "isFormValidChanged"] }, { kind: "ngmodule", type: CuiLabelModule }, { kind: "component", type: i2.CuiLabelComponent, selector: "label[cuiLabel]", inputs: ["isRequired"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i3.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "ngmodule", type: TranslocoModule }, { kind: "directive", type: i4.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
130
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiInstructionInfoComponent, isStandalone: true, selector: "cui-instruction-info", inputs: { instruction: { classPropertyName: "instruction", publicName: "instruction", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { instruction: "instructionChange", validationChanged: "validationChanged", instructionCreated: "instructionCreated" }, providers: [CuiSelectedCategoryService], viewQueries: [{ propertyName: "element", first: true, predicate: ["scrollContent"], descendants: true, isSignal: true }], ngImport: i0, template: "<div\n class=\"wrapper\"\n *transloco=\"let t\"\n>\n <div\n #scrollContent\n class=\"content content_scrollable\"\n >\n <div class=\"category\">\n <cui-form-field>\n <label\n cuiLabel\n [for]=\"categoryId\"\n [isRequired]=\"true\"\n >\n {{ t('SELECT_CATEGORY') }}\n </label>\n <cui-categories\n [buttonId]=\"categoryId\"\n [treeStructType]=\"TYPE\"\n >\n <div class=\"select\">\n <span [style.color]=\"labelColor()\">\n {{ selectTitle() }}\n </span>\n\n <cui-svg icon=\"cuiIconChevronDown\" />\n </div>\n </cui-categories>\n </cui-form-field>\n </div>\n\n @let instructionData = instruction();\n @let editorConfigData = editorConfig();\n\n @if (editorConfigData && instructionData) {\n <cui-instruction-info-form\n [config]=\"editorConfigData\"\n [title]=\"instructionData.storageElement.title\"\n [description]=\"instructionData.storageElement.shortDescription\"\n [framerId]=\"instructionData.storageElement.framerInstructionId\"\n class=\"utility\"\n (isFormValidChanged)=\"onFormValidationChanged($event)\"\n (formChanged)=\"onFormChanged($event, instructionData.id)\"\n />\n }\n </div>\n</div>\n", styles: [".wrapper{display:flex;flex-direction:column;height:100%}.content{height:calc(100vh - 109px)}.content_scrollable{overflow:auto}.category{padding-top:16px;padding-right:23px;padding-left:23px}.select{padding:7px 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;height:36px;border-radius:8px;border:1px solid var(--cui-base-200);color:var(--cui-base-900);background:var(--cui-input)}.utility{--editor-height: none}\n"], dependencies: [{ kind: "ngmodule", type: CuiBadgeModule }, { kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: CuiCategoriesComponent, selector: "cui-categories", inputs: ["treeStructType", "buttonId", "disabled", "context"] }, { kind: "ngmodule", type: CuiDialogModule }, { kind: "ngmodule", type: CuiFormFieldModule }, { kind: "component", type: i1.CuiFormFieldComponent, selector: "cui-form-field" }, { kind: "component", type: CuiInstructionInfoFormComponent, selector: "cui-instruction-info-form", inputs: ["title", "description", "framerId", "config"], outputs: ["formChanged", "isFormValidChanged"] }, { kind: "ngmodule", type: CuiLabelModule }, { kind: "component", type: i2.CuiLabelComponent, selector: "label[cuiLabel]", inputs: ["isRequired"] }, { kind: "ngmodule", type: CuiSvgModule }, { kind: "component", type: i3.CuiSvgComponent, selector: "cui-svg[icon]", inputs: ["width", "height", "strokeWidth", "color", "icon"] }, { kind: "ngmodule", type: TranslocoModule }, { kind: "directive", type: i4.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
132
131
  }
133
132
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiInstructionInfoComponent, decorators: [{
134
133
  type: Component,
@@ -142,6 +141,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
142
141
  CuiLabelModule,
143
142
  CuiSvgModule,
144
143
  TranslocoModule
145
- ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, providers: [CuiSelectedCategoryService], template: "<div\n class=\"wrapper\"\n *transloco=\"let t\"\n>\n <div\n #scrollContent\n class=\"content content_scrollable\"\n >\n <div class=\"category\">\n <cui-form-field>\n <label\n cuiLabel\n [for]=\"categoryId\"\n [isRequired]=\"true\"\n >\n {{ t('SELECT_CATEGORY') }}\n </label>\n <cui-categories\n [buttonId]=\"categoryId\"\n [treeStructType]=\"TYPE\"\n >\n <div class=\"select\">\n <span [style.color]=\"labelColor()\">\n {{ selectTitle() }}\n </span>\n\n <cui-svg icon=\"cuiIconChevronDown\" />\n </div>\n </cui-categories>\n </cui-form-field>\n </div>\n\n @let instructionData = instruction();\n @let editorConfigData = editorConfig();\n\n @if (editorConfigData && instructionData) {\n <cui-instruction-info-form\n [config]=\"editorConfigData\"\n [baseResourceUrl]=\"editorResourceUrl()\"\n [title]=\"instructionData.storageElement.title\"\n [description]=\"instructionData.storageElement.shortDescription\"\n [framerId]=\"instructionData.storageElement.framerInstructionId\"\n class=\"utility\"\n (isFormValidChanged)=\"onFormValidationChanged($event)\"\n (formChanged)=\"onFormChanged($event, instructionData.id)\"\n />\n }\n </div>\n</div>\n", styles: [".wrapper{display:flex;flex-direction:column;height:100%}.content{height:calc(100vh - 109px)}.content_scrollable{overflow:auto}.category{padding-top:16px;padding-right:23px;padding-left:23px}.select{padding:7px 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;height:36px;border-radius:8px;border:1px solid var(--cui-base-200);color:var(--cui-base-900);background:var(--cui-input)}.utility{--editor-height: none}\n"] }]
144
+ ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, providers: [CuiSelectedCategoryService], template: "<div\n class=\"wrapper\"\n *transloco=\"let t\"\n>\n <div\n #scrollContent\n class=\"content content_scrollable\"\n >\n <div class=\"category\">\n <cui-form-field>\n <label\n cuiLabel\n [for]=\"categoryId\"\n [isRequired]=\"true\"\n >\n {{ t('SELECT_CATEGORY') }}\n </label>\n <cui-categories\n [buttonId]=\"categoryId\"\n [treeStructType]=\"TYPE\"\n >\n <div class=\"select\">\n <span [style.color]=\"labelColor()\">\n {{ selectTitle() }}\n </span>\n\n <cui-svg icon=\"cuiIconChevronDown\" />\n </div>\n </cui-categories>\n </cui-form-field>\n </div>\n\n @let instructionData = instruction();\n @let editorConfigData = editorConfig();\n\n @if (editorConfigData && instructionData) {\n <cui-instruction-info-form\n [config]=\"editorConfigData\"\n [title]=\"instructionData.storageElement.title\"\n [description]=\"instructionData.storageElement.shortDescription\"\n [framerId]=\"instructionData.storageElement.framerInstructionId\"\n class=\"utility\"\n (isFormValidChanged)=\"onFormValidationChanged($event)\"\n (formChanged)=\"onFormChanged($event, instructionData.id)\"\n />\n }\n </div>\n</div>\n", styles: [".wrapper{display:flex;flex-direction:column;height:100%}.content{height:calc(100vh - 109px)}.content_scrollable{overflow:auto}.category{padding-top:16px;padding-right:23px;padding-left:23px}.select{padding:7px 13px;font-weight:400;font-size:14px;line-height:20px;display:flex;justify-content:space-between;height:36px;border-radius:8px;border:1px solid var(--cui-base-200);color:var(--cui-base-900);background:var(--cui-input)}.utility{--editor-height: none}\n"] }]
146
145
  }], ctorParameters: () => [] });
147
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instruction-info.component.js","sourceRoot":"","sources":["../../../../../../projects/core/widgets/ui/instruction-info/instruction-info.component.ts","../../../../../../projects/core/widgets/ui/instruction-info/instruction-info.component.html"],"names":[],"mappings":"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","sourcesContent":["import type { ElementRef, OnInit } from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    DestroyRef,\n    effect,\n    inject,\n    input,\n    model,\n    output,\n    signal,\n    untracked,\n    viewChild\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { TranslocoModule, TranslocoService } from '@jsverse/transloco';\nimport type { Observable, Subscription } from 'rxjs';\nimport { finalize, forkJoin } from 'rxjs';\nimport type { Instruction, StorageObject, TreeStruct } from '@cuby-ui/api';\nimport { CuiTreeStructNavigatorApiService, MovingType, TreeStructType } from '@cuby-ui/api';\nimport type { CuiNullable } from '@cuby-ui/cdk';\nimport { CuiIdService } from '@cuby-ui/cdk';\n\nimport {\n    CuiBadgeModule,\n    CuiButtonModule,\n    CuiDialogModule,\n    CuiFormFieldModule,\n    CuiLabelModule,\n    CuiSvgModule\n} from '../../../components';\nimport { CuiCategoriesComponent, CuiSelectedCategoryService } from '../categories';\nimport { CuiEditorConfig } from '../../../editor';\nimport type { CuiTools } from '../../../editor';\nimport { CuiInstructionInfoFormComponent } from '../instruction-info-form';\nimport type { CuiInstructionFormValues } from '../instruction-info-form';\nimport { UTILITY_MODAL_SERVICE_TOKEN, UtilityModalService } from '../utility-modal';\n\n@Component({\n    selector: 'cui-instruction-info',\n    imports: [\n        CuiBadgeModule,\n        CuiButtonModule,\n        CuiCategoriesComponent,\n        CuiDialogModule,\n        CuiFormFieldModule,\n        CuiInstructionInfoFormComponent,\n        CuiLabelModule,\n        CuiSvgModule,\n        TranslocoModule\n    ],\n    standalone: true,\n    templateUrl: './instruction-info.component.html',\n    styleUrls: ['./instruction-info.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [CuiSelectedCategoryService]\n})\nexport class CuiInstructionInfoComponent implements OnInit {\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly translocoService = inject(TranslocoService);\n    private readonly cuiIdService = inject(CuiIdService);\n    private readonly cuiCategoriesModalService = inject(CuiSelectedCategoryService);\n    private readonly treeStructNavigatorApiService = inject(CuiTreeStructNavigatorApiService);\n    private readonly instructionApiService = inject<UtilityModalService<Instruction>>(UTILITY_MODAL_SERVICE_TOKEN);\n\n    protected readonly TYPE = TreeStructType.Instruction;\n\n    private subscription!: Subscription;\n    private skipCategoryChange = false;\n\n    protected readonly categoryId = this.cuiIdService.generate();\n\n    protected readonly category = this.cuiCategoriesModalService.category;\n    protected readonly isFormValid = signal(false);\n    protected readonly prevCategoryId = signal<CuiNullable<string>>(null);\n    protected readonly editorConfig = signal<CuiNullable<CuiEditorConfig>>(null);\n    protected readonly labelColor = computed(() =>\n        this.category()?.title ? 'var(--cui-base-900)' : 'var(--cui-base-400)'\n    );\n    protected readonly selectTitle = computed(\n        () => this.category()?.title || this.translocoService.translate('SELECT') + '...'\n    );\n\n    protected readonly element = viewChild<ElementRef<HTMLElement>>('scrollContent');\n\n    public readonly instruction = model<StorageObject<Instruction>>();\n    public readonly tools = input.required<CuiTools>();\n    public readonly editorResourceUrl = input.required<string>();\n\n    public readonly validationChanged = output<boolean>();\n    public readonly instructionCreated = output<string>();\n\n    constructor() {\n        this.initConfigEffect();\n        this.initCategoryEffect();\n    }\n\n    public ngOnInit(): void {\n        this.initCategory();\n    }\n\n    protected onFormChanged(values: Partial<CuiInstructionFormValues>, instructionId: string): void {\n        const actions: Record<keyof CuiInstructionFormValues, (value: string) => Observable<void>> = {\n            title: (title: string) => this.changeTitle(title, instructionId),\n            description: (description: string) => this.changeDescription(description, instructionId)\n        };\n\n        forkJoin(\n            Object.keys(values).map((key) =>\n                actions[key as keyof CuiInstructionFormValues](values[key as keyof CuiInstructionFormValues] || '')\n            )\n        )\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe();\n    }\n\n    protected onFormValidationChanged(isValid: boolean): void {\n        this.isFormValid.set(isValid);\n        this.validationChanged.emit(isValid);\n    }\n\n    private initCategoryEffect(): void {\n        effect(() => {\n            const category = this.category();\n            const storageObjectInstruction = untracked(this.instruction);\n\n            if (!category || this.skipCategoryChange) {\n                this.skipCategoryChange = false;\n\n                return;\n            }\n\n            if (storageObjectInstruction) {\n                this.changeCategory(category.id, storageObjectInstruction.id);\n\n                return;\n            }\n\n            this.createInstruction(category.id);\n        });\n    }\n\n    private initConfigEffect(): void {\n        effect(() => {\n            const element = this.element()?.nativeElement;\n\n            if (!element) {\n                return;\n            }\n\n            this.editorConfig.set({ tools: this.tools(), element });\n        });\n    }\n\n    private initCategory(): void {\n        const storageObjectId = this.instruction()?.id;\n\n        if (!storageObjectId) {\n            return;\n        }\n\n        this.treeStructNavigatorApiService\n            .getCategory(storageObjectId, TreeStructType.Instruction)\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((category) => {\n                this.skipCategoryChange = true;\n                this.prevCategoryId.set(category.id);\n                this.cuiCategoriesModalService.setCurrentCategory(category as TreeStruct);\n            });\n    }\n\n    private changeCategory(categoryId: string, targetId: string): void {\n        const prevCategoryId = untracked(this.prevCategoryId);\n\n        if (!prevCategoryId) {\n            return;\n        }\n\n        this.subscription?.unsubscribe();\n        this.subscription = this.treeStructNavigatorApiService\n            .moveElement({\n                type: MovingType.TARGET_TREE_STRUCT,\n                movableItemId: targetId,\n                treeStructTargetItemId: categoryId,\n                treeStructMovableItemId: prevCategoryId\n            })\n            .subscribe(() => this.prevCategoryId.set(categoryId));\n    }\n\n    private createInstruction(categoryId: string): void {\n        this.instructionCreated.emit(categoryId);\n        this.prevCategoryId.set(categoryId);\n    }\n\n    private changeTitle(value: string, instructionId: string): Observable<void> {\n        return this.instructionApiService.changeTitle(instructionId, value).pipe(\n            finalize(() =>\n                this.instruction.update((prev) => ({\n                    ...prev!,\n                    storageElement: { ...prev!.storageElement, title: value }\n                }))\n            )\n        );\n    }\n\n    private changeDescription(value: string, instructionId: string): Observable<void> {\n        if (!this.instructionApiService.changeDescription) {\n            throw new Error('Change description not implemented');\n        }\n\n        return this.instructionApiService.changeDescription(instructionId, value).pipe(\n            finalize(() =>\n                this.instruction.update((prev) => ({\n                    ...prev!,\n                    storageElement: { ...prev!.storageElement, shortDescription: value }\n                }))\n            )\n        );\n    }\n}\n","<div\n    class=\"wrapper\"\n    *transloco=\"let t\"\n>\n    <div\n        #scrollContent\n        class=\"content content_scrollable\"\n    >\n        <div class=\"category\">\n            <cui-form-field>\n                <label\n                    cuiLabel\n                    [for]=\"categoryId\"\n                    [isRequired]=\"true\"\n                >\n                    {{ t('SELECT_CATEGORY') }}\n                </label>\n                <cui-categories\n                    [buttonId]=\"categoryId\"\n                    [treeStructType]=\"TYPE\"\n                >\n                    <div class=\"select\">\n                        <span [style.color]=\"labelColor()\">\n                            {{ selectTitle() }}\n                        </span>\n\n                        <cui-svg icon=\"cuiIconChevronDown\" />\n                    </div>\n                </cui-categories>\n            </cui-form-field>\n        </div>\n\n        @let instructionData = instruction();\n        @let editorConfigData = editorConfig();\n\n        @if (editorConfigData && instructionData) {\n            <cui-instruction-info-form\n                [config]=\"editorConfigData\"\n                [baseResourceUrl]=\"editorResourceUrl()\"\n                [title]=\"instructionData.storageElement.title\"\n                [description]=\"instructionData.storageElement.shortDescription\"\n                [framerId]=\"instructionData.storageElement.framerInstructionId\"\n                class=\"utility\"\n                (isFormValidChanged)=\"onFormValidationChanged($event)\"\n                (formChanged)=\"onFormChanged($event, instructionData.id)\"\n            />\n        }\n    </div>\n</div>\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instruction-info.component.js","sourceRoot":"","sources":["../../../../../../projects/core/widgets/ui/instruction-info/instruction-info.component.ts","../../../../../../projects/core/widgets/ui/instruction-info/instruction-info.component.html"],"names":[],"mappings":"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","sourcesContent":["import type { ElementRef, OnInit } from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    DestroyRef,\n    effect,\n    inject,\n    input,\n    model,\n    output,\n    signal,\n    untracked,\n    viewChild\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport type { Instruction, StorageObject, TreeStruct } from '@cuby-ui/api';\nimport { CuiTreeStructNavigatorApiService, MovingType, TreeStructType } from '@cuby-ui/api';\nimport type { CuiNullable } from '@cuby-ui/cdk';\nimport { CuiIdService } from '@cuby-ui/cdk';\nimport { TranslocoModule, TranslocoService } from '@jsverse/transloco';\nimport type { Observable, Subscription } from 'rxjs';\nimport { finalize, forkJoin } from 'rxjs';\n\nimport {\n    CuiBadgeModule,\n    CuiButtonModule,\n    CuiDialogModule,\n    CuiFormFieldModule,\n    CuiLabelModule,\n    CuiSvgModule\n} from '../../../components';\nimport { CuiEditorConfig } from '../../../editor';\nimport { CuiCategoriesComponent, CuiSelectedCategoryService } from '../categories';\nimport type { CuiInstructionFormValues } from '../instruction-info-form';\nimport { CuiInstructionInfoFormComponent } from '../instruction-info-form';\nimport { UTILITY_MODAL_SERVICE_TOKEN, UtilityModalService } from '../utility-modal';\n\n@Component({\n    selector: 'cui-instruction-info',\n    imports: [\n        CuiBadgeModule,\n        CuiButtonModule,\n        CuiCategoriesComponent,\n        CuiDialogModule,\n        CuiFormFieldModule,\n        CuiInstructionInfoFormComponent,\n        CuiLabelModule,\n        CuiSvgModule,\n        TranslocoModule\n    ],\n    standalone: true,\n    templateUrl: './instruction-info.component.html',\n    styleUrls: ['./instruction-info.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [CuiSelectedCategoryService]\n})\nexport class CuiInstructionInfoComponent implements OnInit {\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly translocoService = inject(TranslocoService);\n    private readonly cuiIdService = inject(CuiIdService);\n    private readonly cuiCategoriesModalService = inject(CuiSelectedCategoryService);\n    private readonly treeStructNavigatorApiService = inject(CuiTreeStructNavigatorApiService);\n    private readonly instructionApiService = inject<UtilityModalService<Instruction>>(UTILITY_MODAL_SERVICE_TOKEN);\n\n    protected readonly TYPE = TreeStructType.Instruction;\n\n    private subscription!: Subscription;\n    private skipCategoryChange = false;\n\n    protected readonly categoryId = this.cuiIdService.generate();\n\n    protected readonly category = this.cuiCategoriesModalService.category;\n    protected readonly isFormValid = signal(false);\n    protected readonly prevCategoryId = signal<CuiNullable<string>>(null);\n    protected readonly editorConfig = signal<CuiNullable<CuiEditorConfig>>(null);\n    protected readonly labelColor = computed(() =>\n        this.category()?.title ? 'var(--cui-base-900)' : 'var(--cui-base-400)'\n    );\n    protected readonly selectTitle = computed(\n        () => this.category()?.title || this.translocoService.translate('SELECT') + '...'\n    );\n\n    protected readonly element = viewChild<ElementRef<HTMLElement>>('scrollContent');\n\n    public readonly instruction = model<StorageObject<Instruction>>();\n    public readonly config = input.required<CuiEditorConfig>();\n\n    public readonly validationChanged = output<boolean>();\n    public readonly instructionCreated = output<string>();\n\n    constructor() {\n        this.initConfigEffect();\n        this.initCategoryEffect();\n    }\n\n    public ngOnInit(): void {\n        this.initCategory();\n    }\n\n    protected onFormChanged(values: Partial<CuiInstructionFormValues>, instructionId: string): void {\n        const actions: Record<keyof CuiInstructionFormValues, (value: string) => Observable<void>> = {\n            title: (title: string) => this.changeTitle(title, instructionId),\n            description: (description: string) => this.changeDescription(description, instructionId)\n        };\n\n        forkJoin(\n            Object.keys(values).map((key) =>\n                actions[key as keyof CuiInstructionFormValues](values[key as keyof CuiInstructionFormValues] || '')\n            )\n        )\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe();\n    }\n\n    protected onFormValidationChanged(isValid: boolean): void {\n        this.isFormValid.set(isValid);\n        this.validationChanged.emit(isValid);\n    }\n\n    private initCategoryEffect(): void {\n        effect(() => {\n            const category = this.category();\n            const storageObjectInstruction = untracked(this.instruction);\n\n            if (!category || this.skipCategoryChange) {\n                this.skipCategoryChange = false;\n\n                return;\n            }\n\n            if (storageObjectInstruction) {\n                this.changeCategory(category.id, storageObjectInstruction.id);\n\n                return;\n            }\n\n            this.createInstruction(category.id);\n        });\n    }\n\n    private initConfigEffect(): void {\n        effect(() => {\n            const element = this.element()?.nativeElement;\n\n            if (!element) {\n                return;\n            }\n\n            this.editorConfig.set({ ...this.config(), element });\n        });\n    }\n\n    private initCategory(): void {\n        const storageObjectId = this.instruction()?.id;\n\n        if (!storageObjectId) {\n            return;\n        }\n\n        this.treeStructNavigatorApiService\n            .getCategory(storageObjectId, TreeStructType.Instruction, this.config().requestOptions)\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((category) => {\n                this.skipCategoryChange = true;\n                this.prevCategoryId.set(category.id);\n                this.cuiCategoriesModalService.setCurrentCategory(category as TreeStruct);\n            });\n    }\n\n    private changeCategory(categoryId: string, targetId: string): void {\n        const prevCategoryId = untracked(this.prevCategoryId);\n\n        if (!prevCategoryId) {\n            return;\n        }\n\n        this.subscription?.unsubscribe();\n        this.subscription = this.treeStructNavigatorApiService\n            .moveElement({\n                type: MovingType.TARGET_TREE_STRUCT,\n                movableItemId: targetId,\n                treeStructTargetItemId: categoryId,\n                treeStructMovableItemId: prevCategoryId\n            }, this.config().requestOptions)\n            .subscribe(() => this.prevCategoryId.set(categoryId));\n    }\n\n    private createInstruction(categoryId: string): void {\n        this.instructionCreated.emit(categoryId);\n        this.prevCategoryId.set(categoryId);\n    }\n\n    private changeTitle(value: string, instructionId: string): Observable<void> {\n        return this.instructionApiService.changeTitle(instructionId, value, this.config().requestOptions).pipe(\n            finalize(() =>\n                this.instruction.update((prev) => ({\n                    ...prev!,\n                    storageElement: { ...prev!.storageElement, title: value }\n                }))\n            )\n        );\n    }\n\n    private changeDescription(value: string, instructionId: string): Observable<void> {\n        if (!this.instructionApiService.changeDescription) {\n            throw new Error('Change description not implemented');\n        }\n\n        return this.instructionApiService.changeDescription(instructionId, value, this.config().requestOptions).pipe(\n            finalize(() =>\n                this.instruction.update((prev) => ({\n                    ...prev!,\n                    storageElement: { ...prev!.storageElement, shortDescription: value }\n                }))\n            )\n        );\n    }\n}\n","<div\n    class=\"wrapper\"\n    *transloco=\"let t\"\n>\n    <div\n        #scrollContent\n        class=\"content content_scrollable\"\n    >\n        <div class=\"category\">\n            <cui-form-field>\n                <label\n                    cuiLabel\n                    [for]=\"categoryId\"\n                    [isRequired]=\"true\"\n                >\n                    {{ t('SELECT_CATEGORY') }}\n                </label>\n                <cui-categories\n                    [buttonId]=\"categoryId\"\n                    [treeStructType]=\"TYPE\"\n                >\n                    <div class=\"select\">\n                        <span [style.color]=\"labelColor()\">\n                            {{ selectTitle() }}\n                        </span>\n\n                        <cui-svg icon=\"cuiIconChevronDown\" />\n                    </div>\n                </cui-categories>\n            </cui-form-field>\n        </div>\n\n        @let instructionData = instruction();\n        @let editorConfigData = editorConfig();\n\n        @if (editorConfigData && instructionData) {\n            <cui-instruction-info-form\n                [config]=\"editorConfigData\"\n                [title]=\"instructionData.storageElement.title\"\n                [description]=\"instructionData.storageElement.shortDescription\"\n                [framerId]=\"instructionData.storageElement.framerInstructionId\"\n                class=\"utility\"\n                (isFormValidChanged)=\"onFormValidationChanged($event)\"\n                (formChanged)=\"onFormChanged($event, instructionData.id)\"\n            />\n        }\n    </div>\n</div>\n"]}
@@ -1,14 +1,14 @@
1
1
  import { ChangeDetectionStrategy, Component, DestroyRef, effect, inject, input, output, signal } from '@angular/core';
2
2
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
3
  import { NonNullableFormBuilder, ReactiveFormsModule } from '@angular/forms';
4
+ import { CuiFrameApiService, CuiResourceApiService } from '@cuby-ui/api';
5
+ import { CuiIdService, takeCaptureFromVideo } from '@cuby-ui/cdk';
4
6
  import { TranslocoDirective } from '@jsverse/transloco';
5
7
  import { debounceTime, map, pairwise, startWith } from 'rxjs';
6
- import { CuiFrameApiService } from '@cuby-ui/api';
7
- import { CuiIdService, takeCaptureFromVideo } from '@cuby-ui/cdk';
8
8
  import { CuiAccordionModule, CuiButtonModule, CuiFormFieldModule, CuiHintModule, CuiInputModule, CuiLabelModule } from '../../../components';
9
+ import { CuiEditorBlockComponent } from '../../../editor';
9
10
  import { cuiCreateDefaultValidators } from '../../../utils';
10
11
  import { CuiGeneralControlErrorHintComponent } from '../general-control-error-hint';
11
- import { CuiEditorBlockComponent } from '../../../editor';
12
12
  import { CuiUtilityThumbnailComponent } from '../utility-thumbnail';
13
13
  import * as i0 from "@angular/core";
14
14
  import * as i1 from "../../../components/form-field/form-field.component";
@@ -32,6 +32,7 @@ export class CuiInstructionInfoFormComponent {
32
32
  this.destroy = inject(DestroyRef);
33
33
  this.formBuilder = inject(NonNullableFormBuilder);
34
34
  this.frameApiService = inject(CuiFrameApiService);
35
+ this.resourceApiService = inject(CuiResourceApiService);
35
36
  this.cuiIdService = inject(CuiIdService);
36
37
  this.CONTROL_DELAY = 500;
37
38
  this.titleId = this.cuiIdService.generate();
@@ -47,7 +48,6 @@ export class CuiInstructionInfoFormComponent {
47
48
  this.title = input.required();
48
49
  this.description = input.required();
49
50
  this.framerId = input.required();
50
- this.baseResourceUrl = input.required();
51
51
  this.config = input.required();
52
52
  this.formChanged = output();
53
53
  this.isFormValidChanged = output();
@@ -87,7 +87,7 @@ export class CuiInstructionInfoFormComponent {
87
87
  if (!frameId) {
88
88
  return;
89
89
  }
90
- this.frameApiService.getFrame(frameId).subscribe((frame) => {
90
+ this.frameApiService.getFrame(frameId, this.config().requestOptions).subscribe((frame) => {
91
91
  frame.fragments.forEach((fragment) => {
92
92
  if (fragment.type === "J_TEXT" /* FragmentType.jText */) {
93
93
  this.editorId.set(fragment?.id);
@@ -112,12 +112,18 @@ export class CuiInstructionInfoFormComponent {
112
112
  return changedFields;
113
113
  }
114
114
  setResourceFile(resource) {
115
- const url = this.baseResourceUrl() + resource.fileId;
116
- this.thumbnail.set(resource);
117
- if (!url || resource?.name?.split('.').pop() !== 'mp4') {
115
+ if (!resource.fileId) {
118
116
  return;
119
117
  }
120
- this.getCaptureFromVideo(url);
118
+ this.resourceApiService.get(resource.fileId, this.config().requestOptions)
119
+ .pipe(takeUntilDestroyed(this.destroy), map((url) => URL.createObjectURL(url)))
120
+ .subscribe((url) => {
121
+ this.thumbnail.set({ ...resource, resource: url });
122
+ if (!url || resource?.name?.split('.').pop() !== 'mp4') {
123
+ return;
124
+ }
125
+ this.getCaptureFromVideo(url);
126
+ });
121
127
  }
122
128
  getCaptureFromVideo(url, file) {
123
129
  takeCaptureFromVideo(url).then((capture) => {
@@ -132,7 +138,7 @@ export class CuiInstructionInfoFormComponent {
132
138
  return !this.isDescriptionEmpty() && !this.form.invalid;
133
139
  }
134
140
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiInstructionInfoFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
135
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiInstructionInfoFormComponent, isStandalone: true, selector: "cui-instruction-info-form", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, description: { classPropertyName: "description", publicName: "description", isSignal: true, isRequired: true, transformFunction: null }, framerId: { classPropertyName: "framerId", publicName: "framerId", isSignal: true, isRequired: true, transformFunction: null }, baseResourceUrl: { classPropertyName: "baseResourceUrl", publicName: "baseResourceUrl", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { formChanged: "formChanged", isFormValidChanged: "isFormValidChanged" }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n <section class=\"content\">\n <cui-form-field>\n <label\n cuiLabel\n [isRequired]=\"true\"\n [for]=\"titleId\"\n >\n {{ t('TITLE') }}\n </label>\n\n <cui-input-text\n [cuiTextFieldId]=\"titleId\"\n [cuiTextFieldPlaceholder]=\"t('ADD_A_TITLE')\"\n [cuiTextFieldIsError]=\"isTitleError\"\n [formControl]=\"form.controls.title\"\n />\n\n @if (isTitleError) {\n <cui-general-control-error-hint\n [control]=\"form.controls.title\"\n [isVisible]=\"true\"\n />\n }\n </cui-form-field>\n\n <cui-form-field>\n <label\n cuiLabel\n [isRequired]=\"true\"\n [for]=\"descriptionId\"\n >\n {{ t('SHORT_DESCRIPTION') }}\n </label>\n\n <cui-input-text\n [cuiTextFieldId]=\"descriptionId\"\n cuiTextFieldPlaceholder=\"{{ t('SHORT_DESCRIPTION') }}...\"\n [cuiTextFieldIsError]=\"isDescriptionError\"\n [formControl]=\"form.controls.description\"\n />\n\n @if (isDescriptionError) {\n <cui-general-control-error-hint\n [control]=\"form.controls.description\"\n [isVisible]=\"true\"\n />\n }\n </cui-form-field>\n\n <cui-utility-thumbnail\n [baseResourceUrl]=\"baseResourceUrl()\"\n [framerId]=\"framerId()\"\n [(thumbnail)]=\"thumbnail\"\n />\n\n @if (editorId(); as editorId) {\n <cui-editor-block\n [title]=\"form.controls.title.value || title()\"\n [config]=\"config()\"\n [editorId]=\"editorId\"\n [required]=\"true\"\n class=\"editor\"\n (editorEmpty)=\"onEditorEmpty($event)\"\n />\n }\n </section>\n</ng-container>\n", styles: ["::ng-deep cui-dialog:has(.instruction-description-modal){inset:0;margin:auto;transform:none!important}:host{--editor-height: 650px;display:block}:host .editor{--max-editor-height: var(--editor-height)}.content{display:flex;flex-direction:column;gap:16px;padding:16px 24px}\n"], dependencies: [{ kind: "ngmodule", type: CuiAccordionModule }, { kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: CuiEditorBlockComponent, selector: "cui-editor-block", inputs: ["title", "editorId", "config", "required"], outputs: ["editorEmpty"] }, { kind: "ngmodule", type: CuiFormFieldModule }, { kind: "component", type: i1.CuiFormFieldComponent, selector: "cui-form-field" }, { kind: "component", type: CuiGeneralControlErrorHintComponent, selector: "cui-general-control-error-hint", inputs: ["control", "isVisible"] }, { kind: "ngmodule", type: CuiHintModule }, { kind: "ngmodule", type: CuiInputModule }, { kind: "component", type: i2.CuiInputTextComponent, selector: "cui-input-text" }, { kind: "directive", type: i3.CuiTextFieldIdDirective, selector: "[cuiTextFieldId]", inputs: ["cuiTextFieldId"] }, { kind: "directive", type: i4.CuiTextFieldPlaceholderDirective, selector: "[cuiTextFieldPlaceholder]", inputs: ["cuiTextFieldPlaceholder"] }, { kind: "directive", type: i5.CuiTextFieldIsErrorDirective, selector: "[cuiTextFieldIsError]", inputs: ["cuiTextFieldIsError"] }, { kind: "ngmodule", type: CuiLabelModule }, { kind: "component", type: i6.CuiLabelComponent, selector: "label[cuiLabel]", inputs: ["isRequired"] }, { kind: "component", type: CuiUtilityThumbnailComponent, selector: "cui-utility-thumbnail", inputs: ["thumbnail", "framerId", "baseResourceUrl"], outputs: ["thumbnailChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
141
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: CuiInstructionInfoFormComponent, isStandalone: true, selector: "cui-instruction-info-form", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, description: { classPropertyName: "description", publicName: "description", isSignal: true, isRequired: true, transformFunction: null }, framerId: { classPropertyName: "framerId", publicName: "framerId", isSignal: true, isRequired: true, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { formChanged: "formChanged", isFormValidChanged: "isFormValidChanged" }, ngImport: i0, template: "<ng-container *transloco=\"let t\">\n <section class=\"content\">\n <cui-form-field>\n <label\n cuiLabel\n [isRequired]=\"true\"\n [for]=\"titleId\"\n >\n {{ t('TITLE') }}\n </label>\n\n <cui-input-text\n [cuiTextFieldId]=\"titleId\"\n [cuiTextFieldPlaceholder]=\"t('ADD_A_TITLE')\"\n [cuiTextFieldIsError]=\"isTitleError\"\n [formControl]=\"form.controls.title\"\n />\n\n @if (isTitleError) {\n <cui-general-control-error-hint\n [control]=\"form.controls.title\"\n [isVisible]=\"true\"\n />\n }\n </cui-form-field>\n\n <cui-form-field>\n <label\n cuiLabel\n [isRequired]=\"true\"\n [for]=\"descriptionId\"\n >\n {{ t('SHORT_DESCRIPTION') }}\n </label>\n\n <cui-input-text\n [cuiTextFieldId]=\"descriptionId\"\n cuiTextFieldPlaceholder=\"{{ t('SHORT_DESCRIPTION') }}...\"\n [cuiTextFieldIsError]=\"isDescriptionError\"\n [formControl]=\"form.controls.description\"\n />\n\n @if (isDescriptionError) {\n <cui-general-control-error-hint\n [control]=\"form.controls.description\"\n [isVisible]=\"true\"\n />\n }\n </cui-form-field>\n\n <cui-utility-thumbnail\n [framerId]=\"framerId()\"\n [(thumbnail)]=\"thumbnail\"\n />\n\n @if (editorId(); as editorId) {\n <cui-editor-block\n [title]=\"form.controls.title.value || title()\"\n [config]=\"config()\"\n [editorId]=\"editorId\"\n [required]=\"true\"\n class=\"editor\"\n (editorEmpty)=\"onEditorEmpty($event)\"\n />\n }\n </section>\n</ng-container>\n", styles: ["::ng-deep cui-dialog:has(.instruction-description-modal){inset:0;margin:auto;transform:none!important}:host{--editor-height: 650px;display:block}:host .editor{--max-editor-height: var(--editor-height)}.content{display:flex;flex-direction:column;gap:16px;padding:16px 24px}\n"], dependencies: [{ kind: "ngmodule", type: CuiAccordionModule }, { kind: "ngmodule", type: CuiButtonModule }, { kind: "component", type: CuiEditorBlockComponent, selector: "cui-editor-block", inputs: ["title", "editorId", "config", "required"], outputs: ["editorEmpty"] }, { kind: "ngmodule", type: CuiFormFieldModule }, { kind: "component", type: i1.CuiFormFieldComponent, selector: "cui-form-field" }, { kind: "component", type: CuiGeneralControlErrorHintComponent, selector: "cui-general-control-error-hint", inputs: ["control", "isVisible"] }, { kind: "ngmodule", type: CuiHintModule }, { kind: "ngmodule", type: CuiInputModule }, { kind: "component", type: i2.CuiInputTextComponent, selector: "cui-input-text" }, { kind: "directive", type: i3.CuiTextFieldIdDirective, selector: "[cuiTextFieldId]", inputs: ["cuiTextFieldId"] }, { kind: "directive", type: i4.CuiTextFieldPlaceholderDirective, selector: "[cuiTextFieldPlaceholder]", inputs: ["cuiTextFieldPlaceholder"] }, { kind: "directive", type: i5.CuiTextFieldIsErrorDirective, selector: "[cuiTextFieldIsError]", inputs: ["cuiTextFieldIsError"] }, { kind: "ngmodule", type: CuiLabelModule }, { kind: "component", type: i6.CuiLabelComponent, selector: "label[cuiLabel]", inputs: ["isRequired"] }, { kind: "component", type: CuiUtilityThumbnailComponent, selector: "cui-utility-thumbnail", inputs: ["thumbnail", "framerId"], outputs: ["thumbnailChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
136
142
  }
137
143
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: CuiInstructionInfoFormComponent, decorators: [{
138
144
  type: Component,
@@ -148,6 +154,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
148
154
  CuiUtilityThumbnailComponent,
149
155
  ReactiveFormsModule,
150
156
  TranslocoDirective
151
- ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\n <section class=\"content\">\n <cui-form-field>\n <label\n cuiLabel\n [isRequired]=\"true\"\n [for]=\"titleId\"\n >\n {{ t('TITLE') }}\n </label>\n\n <cui-input-text\n [cuiTextFieldId]=\"titleId\"\n [cuiTextFieldPlaceholder]=\"t('ADD_A_TITLE')\"\n [cuiTextFieldIsError]=\"isTitleError\"\n [formControl]=\"form.controls.title\"\n />\n\n @if (isTitleError) {\n <cui-general-control-error-hint\n [control]=\"form.controls.title\"\n [isVisible]=\"true\"\n />\n }\n </cui-form-field>\n\n <cui-form-field>\n <label\n cuiLabel\n [isRequired]=\"true\"\n [for]=\"descriptionId\"\n >\n {{ t('SHORT_DESCRIPTION') }}\n </label>\n\n <cui-input-text\n [cuiTextFieldId]=\"descriptionId\"\n cuiTextFieldPlaceholder=\"{{ t('SHORT_DESCRIPTION') }}...\"\n [cuiTextFieldIsError]=\"isDescriptionError\"\n [formControl]=\"form.controls.description\"\n />\n\n @if (isDescriptionError) {\n <cui-general-control-error-hint\n [control]=\"form.controls.description\"\n [isVisible]=\"true\"\n />\n }\n </cui-form-field>\n\n <cui-utility-thumbnail\n [baseResourceUrl]=\"baseResourceUrl()\"\n [framerId]=\"framerId()\"\n [(thumbnail)]=\"thumbnail\"\n />\n\n @if (editorId(); as editorId) {\n <cui-editor-block\n [title]=\"form.controls.title.value || title()\"\n [config]=\"config()\"\n [editorId]=\"editorId\"\n [required]=\"true\"\n class=\"editor\"\n (editorEmpty)=\"onEditorEmpty($event)\"\n />\n }\n </section>\n</ng-container>\n", styles: ["::ng-deep cui-dialog:has(.instruction-description-modal){inset:0;margin:auto;transform:none!important}:host{--editor-height: 650px;display:block}:host .editor{--max-editor-height: var(--editor-height)}.content{display:flex;flex-direction:column;gap:16px;padding:16px 24px}\n"] }]
157
+ ], standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *transloco=\"let t\">\n <section class=\"content\">\n <cui-form-field>\n <label\n cuiLabel\n [isRequired]=\"true\"\n [for]=\"titleId\"\n >\n {{ t('TITLE') }}\n </label>\n\n <cui-input-text\n [cuiTextFieldId]=\"titleId\"\n [cuiTextFieldPlaceholder]=\"t('ADD_A_TITLE')\"\n [cuiTextFieldIsError]=\"isTitleError\"\n [formControl]=\"form.controls.title\"\n />\n\n @if (isTitleError) {\n <cui-general-control-error-hint\n [control]=\"form.controls.title\"\n [isVisible]=\"true\"\n />\n }\n </cui-form-field>\n\n <cui-form-field>\n <label\n cuiLabel\n [isRequired]=\"true\"\n [for]=\"descriptionId\"\n >\n {{ t('SHORT_DESCRIPTION') }}\n </label>\n\n <cui-input-text\n [cuiTextFieldId]=\"descriptionId\"\n cuiTextFieldPlaceholder=\"{{ t('SHORT_DESCRIPTION') }}...\"\n [cuiTextFieldIsError]=\"isDescriptionError\"\n [formControl]=\"form.controls.description\"\n />\n\n @if (isDescriptionError) {\n <cui-general-control-error-hint\n [control]=\"form.controls.description\"\n [isVisible]=\"true\"\n />\n }\n </cui-form-field>\n\n <cui-utility-thumbnail\n [framerId]=\"framerId()\"\n [(thumbnail)]=\"thumbnail\"\n />\n\n @if (editorId(); as editorId) {\n <cui-editor-block\n [title]=\"form.controls.title.value || title()\"\n [config]=\"config()\"\n [editorId]=\"editorId\"\n [required]=\"true\"\n class=\"editor\"\n (editorEmpty)=\"onEditorEmpty($event)\"\n />\n }\n </section>\n</ng-container>\n", styles: ["::ng-deep cui-dialog:has(.instruction-description-modal){inset:0;margin:auto;transform:none!important}:host{--editor-height: 650px;display:block}:host .editor{--max-editor-height: var(--editor-height)}.content{display:flex;flex-direction:column;gap:16px;padding:16px 24px}\n"] }]
152
158
  }], ctorParameters: () => [] });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instruction-info-form.component.js","sourceRoot":"","sources":["../../../../../../projects/core/widgets/ui/instruction-info-form/instruction-info-form.component.ts","../../../../../../projects/core/widgets/ui/instruction-info-form/instruction-info-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, DestroyRef, effect, inject, input, output, signal } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { NonNullableFormBuilder, ReactiveFormsModule } from '@angular/forms';\nimport { TranslocoDirective } from '@jsverse/transloco';\nimport { debounceTime, map, pairwise, startWith } from 'rxjs';\nimport type { ResourceFragment } from '@cuby-ui/api';\nimport { CuiFrameApiService, FragmentType } from '@cuby-ui/api';\nimport type { CuiNullable } from '@cuby-ui/cdk';\nimport { CuiIdService, takeCaptureFromVideo } from '@cuby-ui/cdk';\n\nimport {\n    CuiAccordionModule,\n    CuiButtonModule,\n    CuiFormFieldModule,\n    CuiHintModule,\n    CuiInputModule,\n    CuiLabelModule\n} from '../../../components';\nimport { cuiCreateDefaultValidators } from '../../../utils';\nimport { CuiGeneralControlErrorHintComponent } from '../general-control-error-hint';\nimport { CuiEditorBlockComponent } from '../../../editor';\nimport type { CuiEditorConfig } from '../../../editor';\nimport { CuiUtilityThumbnailComponent } from '../utility-thumbnail';\n\nimport type { CuiInstructionFormGroup, CuiInstructionFormValues } from './instruction-info-form.options';\n\n@Component({\n    selector: 'cui-instruction-info-form',\n    imports: [\n        CuiAccordionModule,\n        CuiButtonModule,\n        CuiEditorBlockComponent,\n        CuiFormFieldModule,\n        CuiGeneralControlErrorHintComponent,\n        CuiHintModule,\n        CuiInputModule,\n        CuiLabelModule,\n        CuiUtilityThumbnailComponent,\n        ReactiveFormsModule,\n        TranslocoDirective\n    ],\n    standalone: true,\n    templateUrl: './instruction-info-form.component.html',\n    styleUrl: './instruction-info-form.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiInstructionInfoFormComponent {\n    private readonly destroy = inject(DestroyRef);\n    private readonly formBuilder = inject(NonNullableFormBuilder);\n    private readonly frameApiService = inject(CuiFrameApiService);\n    private readonly cuiIdService = inject(CuiIdService);\n\n    protected readonly CONTROL_DELAY = 500;\n\n    protected readonly titleId = this.cuiIdService.generate();\n    protected readonly descriptionId = this.cuiIdService.generate();\n    protected readonly form = this.formBuilder.group<CuiInstructionFormGroup>({\n        title: this.formBuilder.control('', cuiCreateDefaultValidators({ asyncDelay: this.CONTROL_DELAY })),\n        description: this.formBuilder.control('', cuiCreateDefaultValidators({ asyncDelay: this.CONTROL_DELAY }))\n    });\n\n    protected heading: CuiNullable<string> = null;\n\n    protected readonly isDescriptionEmpty = signal(false);\n    protected readonly editorId = signal<CuiNullable<string>>(null);\n    protected readonly thumbnail = signal<CuiNullable<ResourceFragment>>(null);\n\n    public readonly title = input.required<string>();\n    public readonly description = input.required<string>();\n    public readonly framerId = input.required<string>();\n    public readonly baseResourceUrl = input.required<string>();\n    public readonly config = input.required<CuiEditorConfig>();\n\n    public readonly formChanged = output<Partial<CuiInstructionFormValues>>();\n    public readonly isFormValidChanged = output<boolean>();\n\n    protected get controls(): CuiInstructionFormGroup {\n        return this.form.controls;\n    }\n\n    protected get isTitleError(): boolean {\n        return this.controls.title.invalid && this.controls.title.dirty;\n    }\n\n    protected get isDescriptionError(): boolean {\n        return this.controls.description.invalid && this.controls.description.dirty;\n    }\n\n    constructor() {\n        this.initUtilityEffect();\n    }\n\n    protected onEditorEmpty(isEmpty: boolean): void {\n        this.isDescriptionEmpty.set(isEmpty);\n        this.isFormValidChanged.emit(this.checkFormValidation());\n    }\n\n    private initUtilityEffect(): void {\n        const effectRef = effect(() => {\n            const title = this.title();\n\n            if (!title) {\n                return;\n            }\n\n            this.initFormSubscriptions();\n            this.initFrameFragments();\n            effectRef.destroy();\n        });\n    }\n\n    private initFormSubscriptions(): void {\n        this.form.setValue({ title: this.title(), description: this.description() }, { emitEvent: false });\n\n        this.form.statusChanges\n            .pipe(takeUntilDestroyed(this.destroy))\n            .subscribe(() => this.isFormValidChanged.emit(this.checkFormValidation()));\n\n        this.form.valueChanges\n            .pipe(\n                takeUntilDestroyed(this.destroy),\n                startWith(this.form.value),\n                pairwise(),\n                debounceTime(this.CONTROL_DELAY),\n                map(([prev, current]) => this.compareFormValues([prev, current]))\n            )\n            .subscribe((value) => {\n                if (!Object.keys(value).length) {\n                    return;\n                }\n\n                this.formChanged.emit(value);\n            });\n    }\n\n    private initFrameFragments(): void {\n        const frameId = this.framerId();\n\n        if (!frameId) {\n            return;\n        }\n\n        this.frameApiService.getFrame(frameId).subscribe((frame) => {\n            frame.fragments.forEach((fragment) => {\n                if (fragment.type === FragmentType.jText) {\n                    this.editorId.set(fragment?.id);\n                }\n\n                if (fragment.type === FragmentType.resourceFile) {\n                    this.setResourceFile(fragment as ResourceFragment);\n                }\n            });\n        });\n    }\n\n    private compareFormValues([\n        prevGroup,\n        currentGruop\n    ]: Partial<CuiInstructionFormValues>[]): Partial<CuiInstructionFormValues> {\n        const keys = Object.keys(currentGruop) as (keyof CuiInstructionFormValues)[];\n        const changedFields: Record<string, unknown> = {};\n\n        keys.forEach((key) => {\n            const prev = prevGroup[key];\n            const current = currentGruop[key];\n\n            if (prev === current || this.controls[key].invalid) {\n                return;\n            }\n\n            changedFields[key] = current;\n        });\n\n        return changedFields;\n    }\n\n    private setResourceFile(resource: ResourceFragment): void {\n        const url = this.baseResourceUrl() + resource.fileId!;\n\n        this.thumbnail.set(resource);\n\n        if (!url || resource?.name?.split('.').pop() !== 'mp4') {\n            return;\n        }\n\n        this.getCaptureFromVideo(url);\n    }\n\n    private getCaptureFromVideo(url: string, file?: File): void {\n        takeCaptureFromVideo(url).then((capture) => {\n            this.thumbnail.update((prev) => ({\n                ...prev!,\n                name: (file?.name ?? prev?.name)!,\n                resource: capture\n            }));\n        });\n    }\n\n    private checkFormValidation(): boolean {\n        return !this.isDescriptionEmpty() && !this.form.invalid;\n    }\n}\n","<ng-container *transloco=\"let t\">\n    <section class=\"content\">\n        <cui-form-field>\n            <label\n                cuiLabel\n                [isRequired]=\"true\"\n                [for]=\"titleId\"\n            >\n                {{ t('TITLE') }}\n            </label>\n\n            <cui-input-text\n                [cuiTextFieldId]=\"titleId\"\n                [cuiTextFieldPlaceholder]=\"t('ADD_A_TITLE')\"\n                [cuiTextFieldIsError]=\"isTitleError\"\n                [formControl]=\"form.controls.title\"\n            />\n\n            @if (isTitleError) {\n                <cui-general-control-error-hint\n                    [control]=\"form.controls.title\"\n                    [isVisible]=\"true\"\n                />\n            }\n        </cui-form-field>\n\n        <cui-form-field>\n            <label\n                cuiLabel\n                [isRequired]=\"true\"\n                [for]=\"descriptionId\"\n            >\n                {{ t('SHORT_DESCRIPTION') }}\n            </label>\n\n            <cui-input-text\n                [cuiTextFieldId]=\"descriptionId\"\n                cuiTextFieldPlaceholder=\"{{ t('SHORT_DESCRIPTION') }}...\"\n                [cuiTextFieldIsError]=\"isDescriptionError\"\n                [formControl]=\"form.controls.description\"\n            />\n\n            @if (isDescriptionError) {\n                <cui-general-control-error-hint\n                    [control]=\"form.controls.description\"\n                    [isVisible]=\"true\"\n                />\n            }\n        </cui-form-field>\n\n        <cui-utility-thumbnail\n            [baseResourceUrl]=\"baseResourceUrl()\"\n            [framerId]=\"framerId()\"\n            [(thumbnail)]=\"thumbnail\"\n        />\n\n        @if (editorId(); as editorId) {\n            <cui-editor-block\n                [title]=\"form.controls.title.value || title()\"\n                [config]=\"config()\"\n                [editorId]=\"editorId\"\n                [required]=\"true\"\n                class=\"editor\"\n                (editorEmpty)=\"onEditorEmpty($event)\"\n            />\n        }\n    </section>\n</ng-container>\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instruction-info-form.component.js","sourceRoot":"","sources":["../../../../../../projects/core/widgets/ui/instruction-info-form/instruction-info-form.component.ts","../../../../../../projects/core/widgets/ui/instruction-info-form/instruction-info-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, DestroyRef, effect, inject, input, output, signal } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { NonNullableFormBuilder, ReactiveFormsModule } from '@angular/forms';\nimport type { ResourceFragment } from '@cuby-ui/api';\nimport { CuiFrameApiService, CuiResourceApiService, FragmentType } from '@cuby-ui/api';\nimport type { CuiNullable } from '@cuby-ui/cdk';\nimport { CuiIdService, takeCaptureFromVideo } from '@cuby-ui/cdk';\nimport { TranslocoDirective } from '@jsverse/transloco';\nimport { debounceTime, map, pairwise, startWith } from 'rxjs';\n\nimport {\n    CuiAccordionModule,\n    CuiButtonModule,\n    CuiFormFieldModule,\n    CuiHintModule,\n    CuiInputModule,\n    CuiLabelModule\n} from '../../../components';\nimport type { CuiEditorConfig } from '../../../editor';\nimport { CuiEditorBlockComponent } from '../../../editor';\nimport { cuiCreateDefaultValidators } from '../../../utils';\nimport { CuiGeneralControlErrorHintComponent } from '../general-control-error-hint';\nimport { CuiUtilityThumbnailComponent } from '../utility-thumbnail';\n\nimport type { CuiInstructionFormGroup, CuiInstructionFormValues } from './instruction-info-form.options';\n\n@Component({\n    selector: 'cui-instruction-info-form',\n    imports: [\n        CuiAccordionModule,\n        CuiButtonModule,\n        CuiEditorBlockComponent,\n        CuiFormFieldModule,\n        CuiGeneralControlErrorHintComponent,\n        CuiHintModule,\n        CuiInputModule,\n        CuiLabelModule,\n        CuiUtilityThumbnailComponent,\n        ReactiveFormsModule,\n        TranslocoDirective\n    ],\n    standalone: true,\n    templateUrl: './instruction-info-form.component.html',\n    styleUrl: './instruction-info-form.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class CuiInstructionInfoFormComponent {\n    private readonly destroy = inject(DestroyRef);\n    private readonly formBuilder = inject(NonNullableFormBuilder);\n    private readonly frameApiService = inject(CuiFrameApiService);\n    private readonly resourceApiService = inject(CuiResourceApiService);\n    private readonly cuiIdService = inject(CuiIdService);\n\n    protected readonly CONTROL_DELAY = 500;\n\n    protected readonly titleId = this.cuiIdService.generate();\n    protected readonly descriptionId = this.cuiIdService.generate();\n    protected readonly form = this.formBuilder.group<CuiInstructionFormGroup>({\n        title: this.formBuilder.control('', cuiCreateDefaultValidators({ asyncDelay: this.CONTROL_DELAY })),\n        description: this.formBuilder.control('', cuiCreateDefaultValidators({ asyncDelay: this.CONTROL_DELAY }))\n    });\n\n    protected heading: CuiNullable<string> = null;\n\n    protected readonly isDescriptionEmpty = signal(false);\n    protected readonly editorId = signal<CuiNullable<string>>(null);\n    protected readonly thumbnail = signal<CuiNullable<ResourceFragment>>(null);\n\n    public readonly title = input.required<string>();\n    public readonly description = input.required<string>();\n    public readonly framerId = input.required<string>();\n    public readonly config = input.required<CuiEditorConfig>();\n\n    public readonly formChanged = output<Partial<CuiInstructionFormValues>>();\n    public readonly isFormValidChanged = output<boolean>();\n\n    protected get controls(): CuiInstructionFormGroup {\n        return this.form.controls;\n    }\n\n    protected get isTitleError(): boolean {\n        return this.controls.title.invalid && this.controls.title.dirty;\n    }\n\n    protected get isDescriptionError(): boolean {\n        return this.controls.description.invalid && this.controls.description.dirty;\n    }\n\n    constructor() {\n        this.initUtilityEffect();\n    }\n\n    protected onEditorEmpty(isEmpty: boolean): void {\n        this.isDescriptionEmpty.set(isEmpty);\n        this.isFormValidChanged.emit(this.checkFormValidation());\n    }\n\n    private initUtilityEffect(): void {\n        const effectRef = effect(() => {\n            const title = this.title();\n\n            if (!title) {\n                return;\n            }\n\n            this.initFormSubscriptions();\n            this.initFrameFragments();\n            effectRef.destroy();\n        });\n    }\n\n    private initFormSubscriptions(): void {\n        this.form.setValue({ title: this.title(), description: this.description() }, { emitEvent: false });\n\n        this.form.statusChanges\n            .pipe(takeUntilDestroyed(this.destroy))\n            .subscribe(() => this.isFormValidChanged.emit(this.checkFormValidation()));\n\n        this.form.valueChanges\n            .pipe(\n                takeUntilDestroyed(this.destroy),\n                startWith(this.form.value),\n                pairwise(),\n                debounceTime(this.CONTROL_DELAY),\n                map(([prev, current]) => this.compareFormValues([prev, current]))\n            )\n            .subscribe((value) => {\n                if (!Object.keys(value).length) {\n                    return;\n                }\n\n                this.formChanged.emit(value);\n            });\n    }\n\n    private initFrameFragments(): void {\n        const frameId = this.framerId();\n\n        if (!frameId) {\n            return;\n        }\n\n        this.frameApiService.getFrame(frameId, this.config().requestOptions).subscribe((frame) => {\n            frame.fragments.forEach((fragment) => {\n                if (fragment.type === FragmentType.jText) {\n                    this.editorId.set(fragment?.id);\n                }\n\n                if (fragment.type === FragmentType.resourceFile) {\n                    this.setResourceFile(fragment as ResourceFragment);\n                }\n            });\n        });\n    }\n\n    private compareFormValues([\n        prevGroup,\n        currentGruop\n    ]: Partial<CuiInstructionFormValues>[]): Partial<CuiInstructionFormValues> {\n        const keys = Object.keys(currentGruop) as (keyof CuiInstructionFormValues)[];\n        const changedFields: Record<string, unknown> = {};\n\n        keys.forEach((key) => {\n            const prev = prevGroup[key];\n            const current = currentGruop[key];\n\n            if (prev === current || this.controls[key].invalid) {\n                return;\n            }\n\n            changedFields[key] = current;\n        });\n\n        return changedFields;\n    }\n\n    private setResourceFile(resource: ResourceFragment): void {\n        if (!resource.fileId) {\n            return;\n        }\n\n        this.resourceApiService.get(resource.fileId, this.config().requestOptions)\n            .pipe(\n                takeUntilDestroyed(this.destroy),\n                map((url) => URL.createObjectURL(url))\n            )\n            .subscribe((url) => {\n                this.thumbnail.set({ ...resource, resource: url });\n\n                if (!url || resource?.name?.split('.').pop() !== 'mp4') {\n                    return;\n                }\n\n                this.getCaptureFromVideo(url);\n            });\n    }\n\n    private getCaptureFromVideo(url: string, file?: File): void {\n        takeCaptureFromVideo(url).then((capture) => {\n            this.thumbnail.update((prev) => ({\n                ...prev!,\n                name: (file?.name ?? prev?.name)!,\n                resource: capture\n            }));\n        });\n    }\n\n    private checkFormValidation(): boolean {\n        return !this.isDescriptionEmpty() && !this.form.invalid;\n    }\n}\n","<ng-container *transloco=\"let t\">\n    <section class=\"content\">\n        <cui-form-field>\n            <label\n                cuiLabel\n                [isRequired]=\"true\"\n                [for]=\"titleId\"\n            >\n                {{ t('TITLE') }}\n            </label>\n\n            <cui-input-text\n                [cuiTextFieldId]=\"titleId\"\n                [cuiTextFieldPlaceholder]=\"t('ADD_A_TITLE')\"\n                [cuiTextFieldIsError]=\"isTitleError\"\n                [formControl]=\"form.controls.title\"\n            />\n\n            @if (isTitleError) {\n                <cui-general-control-error-hint\n                    [control]=\"form.controls.title\"\n                    [isVisible]=\"true\"\n                />\n            }\n        </cui-form-field>\n\n        <cui-form-field>\n            <label\n                cuiLabel\n                [isRequired]=\"true\"\n                [for]=\"descriptionId\"\n            >\n                {{ t('SHORT_DESCRIPTION') }}\n            </label>\n\n            <cui-input-text\n                [cuiTextFieldId]=\"descriptionId\"\n                cuiTextFieldPlaceholder=\"{{ t('SHORT_DESCRIPTION') }}...\"\n                [cuiTextFieldIsError]=\"isDescriptionError\"\n                [formControl]=\"form.controls.description\"\n            />\n\n            @if (isDescriptionError) {\n                <cui-general-control-error-hint\n                    [control]=\"form.controls.description\"\n                    [isVisible]=\"true\"\n                />\n            }\n        </cui-form-field>\n\n        <cui-utility-thumbnail\n            [framerId]=\"framerId()\"\n            [(thumbnail)]=\"thumbnail\"\n        />\n\n        @if (editorId(); as editorId) {\n            <cui-editor-block\n                [title]=\"form.controls.title.value || title()\"\n                [config]=\"config()\"\n                [editorId]=\"editorId\"\n                [required]=\"true\"\n                class=\"editor\"\n                (editorEmpty)=\"onEditorEmpty($event)\"\n            />\n        }\n    </section>\n</ng-container>\n"]}