@cqa-lib/cqa-ui 1.1.525 → 1.1.527

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 (45) hide show
  1. package/esm2020/lib/assets/images/image-assets.constants.mjs +3 -1
  2. package/esm2020/lib/compare-runs/compare-runs.component.mjs +1 -1
  3. package/esm2020/lib/execution-screen/db-query-execution-item/db-query-execution-item.component.mjs +1 -1
  4. package/esm2020/lib/execution-screen/db-verification-step/db-verification-step.component.mjs +1 -1
  5. package/esm2020/lib/iterations-loop/iterations-loop.component.mjs +1 -1
  6. package/esm2020/lib/segment-control/segment-control.component.mjs +6 -3
  7. package/esm2020/lib/simulator/simulator.component.mjs +3 -3
  8. package/esm2020/lib/step-builder/step-builder-document-generation-template-step/step-builder-document-generation-template-step.component.mjs +1 -1
  9. package/esm2020/lib/table/dynamic-table/dynamic-table.component.mjs +148 -4
  10. package/esm2020/lib/templates/modular-table-template/dialogs/delete-folder-dialog.component.mjs +181 -0
  11. package/esm2020/lib/templates/modular-table-template/dialogs/move-to-folder-dialog.component.mjs +264 -0
  12. package/esm2020/lib/templates/modular-table-template/dialogs/new-folder-dialog.component.mjs +352 -0
  13. package/esm2020/lib/templates/modular-table-template/directives/folder-drag.directive.mjs +45 -0
  14. package/esm2020/lib/templates/modular-table-template/directives/folder-drop.directive.mjs +95 -0
  15. package/esm2020/lib/templates/modular-table-template/directives/row-drag.directive.mjs +44 -0
  16. package/esm2020/lib/templates/modular-table-template/folder-sidebar/folder-sidebar.component.mjs +479 -0
  17. package/esm2020/lib/templates/modular-table-template/modular-table-template.component.mjs +1475 -0
  18. package/esm2020/lib/templates/modular-table-template/modular-table-template.models.mjs +79 -0
  19. package/esm2020/lib/templates/table-template.component.mjs +88 -12
  20. package/esm2020/lib/test-case-details/api-edit-step/api-edit-step.component.mjs +1 -1
  21. package/esm2020/lib/ui-kit.module.mjs +41 -1
  22. package/esm2020/public-api.mjs +10 -1
  23. package/fesm2015/cqa-lib-cqa-ui.mjs +3409 -179
  24. package/fesm2015/cqa-lib-cqa-ui.mjs.map +1 -1
  25. package/fesm2020/cqa-lib-cqa-ui.mjs +3389 -177
  26. package/fesm2020/cqa-lib-cqa-ui.mjs.map +1 -1
  27. package/lib/assets/images/image-assets.constants.d.ts +1 -0
  28. package/lib/segment-control/segment-control.component.d.ts +2 -1
  29. package/lib/table/dynamic-table/dynamic-table.component.d.ts +43 -1
  30. package/lib/templates/modular-table-template/dialogs/delete-folder-dialog.component.d.ts +34 -0
  31. package/lib/templates/modular-table-template/dialogs/move-to-folder-dialog.component.d.ts +57 -0
  32. package/lib/templates/modular-table-template/dialogs/new-folder-dialog.component.d.ts +79 -0
  33. package/lib/templates/modular-table-template/directives/folder-drag.directive.d.ts +10 -0
  34. package/lib/templates/modular-table-template/directives/folder-drop.directive.d.ts +22 -0
  35. package/lib/templates/modular-table-template/directives/row-drag.directive.d.ts +10 -0
  36. package/lib/templates/modular-table-template/folder-sidebar/folder-sidebar.component.d.ts +149 -0
  37. package/lib/templates/modular-table-template/modular-table-template.component.d.ts +453 -0
  38. package/lib/templates/modular-table-template/modular-table-template.models.d.ts +150 -0
  39. package/lib/templates/table-template.component.d.ts +40 -2
  40. package/lib/ui-kit.module.d.ts +153 -145
  41. package/package.json +1 -1
  42. package/public-api.d.ts +9 -0
  43. package/src/lib/assets/images/EmptyFolderState.png +0 -0
  44. package/src/lib/assets/images/image-assets.constants.ts +3 -0
  45. package/styles.css +1 -1
@@ -0,0 +1,79 @@
1
+ export const DEFAULT_MODULAR_CONFIG = {
2
+ showSidebar: true,
3
+ showBreadcrumb: true,
4
+ showFolderGrid: true,
5
+ showUnorganisedSection: true,
6
+ showSubfolderSection: true,
7
+ showCounts: true,
8
+ allowCreateFolder: true,
9
+ allowRenameFolder: true,
10
+ allowDeleteFolder: true,
11
+ allowNestedFolders: true,
12
+ allowTestDragDrop: true,
13
+ allowBulkSelection: true,
14
+ };
15
+ export const DEFAULT_MODULAR_LABELS = {
16
+ folders: 'Folders',
17
+ organised: 'Organised',
18
+ unorganised: 'Unorganised',
19
+ newFolder: 'New folder',
20
+ searchFoldersPlaceholder: 'Search folders...',
21
+ allFolders: 'All folders',
22
+ subfoldersIn: 'Subfolders in',
23
+ moveToFolder: 'Move to folder',
24
+ addTag: 'Add Tag',
25
+ delete: 'Delete',
26
+ selectAll: 'Select all',
27
+ testsCountSingular: '1 test',
28
+ testsCountPlural: '{n} tests',
29
+ foldersCountSingular: '1 folder',
30
+ foldersCountPlural: '{n} folders',
31
+ subfolderCountSingular: '1 subfolder',
32
+ subfolderCountPlural: '{n} subfolders',
33
+ oneSubfolder: '1 subfolder',
34
+ subfoldersCount: '{n} subfolders',
35
+ clearFilter: 'Clear filter',
36
+ moveDialogTitle: 'Move to Folder',
37
+ moveDialogCancel: 'Cancel',
38
+ moveDialogConfirm: 'Move here',
39
+ moveDialogRoot: 'Unorganised',
40
+ moveDialogDescriptionSingular: 'Moving 1 test case — select destination',
41
+ moveDialogDescriptionPlural: 'Moving {n} test cases — select destination',
42
+ newFolderDialogTitle: 'New Folder',
43
+ newFolderDialogDescription: 'Rename any time by double-clicking in the tree',
44
+ newFolderDialogNameLabel: 'Folder name',
45
+ newFolderDialogNamePlaceholder: 'e.g. Checkout Flow, User Auth, Payment Tests',
46
+ newFolderDialogParentLabel: 'Parent folder (optional)',
47
+ newFolderDialogParentNone: 'None',
48
+ newFolderDialogColorLabel: 'Folder color (optional)',
49
+ newFolderDialogCancel: 'Cancel',
50
+ newFolderDialogConfirm: 'Create folder',
51
+ folderMenuCreateSubfolder: 'Create subfolder',
52
+ folderMenuRename: 'Rename',
53
+ folderMenuMove: 'Move folder',
54
+ folderMenuDuplicate: 'Duplicate folder',
55
+ folderMenuDelete: 'Delete folder',
56
+ deleteFolderDialogTitle: 'Delete folder',
57
+ deleteFolderDialogBodySingular: 'This folder contains 1 test case. What should happen to them?',
58
+ deleteFolderDialogBodyPlural: 'This folder contains {n} test cases. What should happen to them?',
59
+ deleteFolderDialogMoveToParentTitle: 'Move test cases to parent folder',
60
+ deleteFolderDialogMoveToParentDescription: 'Test cases move one level up — nothing is lost',
61
+ deleteFolderDialogMoveToUnorganisedTitle: 'Move test cases to Unorganised',
62
+ deleteFolderDialogMoveToUnorganisedDescription: 'Test cases return to the Unorganised section',
63
+ deleteFolderDialogCancel: 'Cancel',
64
+ deleteFolderDialogConfirm: 'Delete folder',
65
+ emptyNoTestsInFolderTitle: 'No Test Case Found',
66
+ emptyNoTestsInFolderDescription: 'This folder does not contain any test cases yet.',
67
+ };
68
+ export const DEFAULT_REORDER_LABELS = {
69
+ reorderButton: 'Reorder',
70
+ cancelButton: 'Cancel',
71
+ doneButton: 'Done',
72
+ savingButton: 'Saving...',
73
+ bannerTitle: 'Reorder mode',
74
+ bannerDescription: 'Drag rows using the handle to rearrange.',
75
+ };
76
+ export const ROW_DRAG_MIME = 'application/x-cqa-test-ids';
77
+ /** Custom MIME for folder-row drags in the sidebar. Payload is a JSON-stringified folder id. */
78
+ export const FOLDER_DRAG_MIME = 'application/x-cqa-folder-id';
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modular-table-template.models.js","sourceRoot":"","sources":["../../../../../../src/lib/templates/modular-table-template/modular-table-template.models.ts"],"names":[],"mappings":"AA4BA,MAAM,CAAC,MAAM,sBAAsB,GAAkB;IACnD,WAAW,EAAE,IAAI;IACjB,cAAc,EAAE,IAAI;IACpB,cAAc,EAAE,IAAI;IACpB,sBAAsB,EAAE,IAAI;IAC5B,oBAAoB,EAAE,IAAI;IAC1B,UAAU,EAAE,IAAI;IAChB,iBAAiB,EAAE,IAAI;IACvB,iBAAiB,EAAE,IAAI;IACvB,iBAAiB,EAAE,IAAI;IACvB,kBAAkB,EAAE,IAAI;IACxB,iBAAiB,EAAE,IAAI;IACvB,kBAAkB,EAAE,IAAI;CACzB,CAAC;AAgEF,MAAM,CAAC,MAAM,sBAAsB,GAAkB;IACnD,OAAO,EAAE,SAAS;IAClB,SAAS,EAAE,WAAW;IACtB,WAAW,EAAE,aAAa;IAC1B,SAAS,EAAE,YAAY;IACvB,wBAAwB,EAAE,mBAAmB;IAC7C,UAAU,EAAE,aAAa;IACzB,YAAY,EAAE,eAAe;IAC7B,YAAY,EAAE,gBAAgB;IAC9B,MAAM,EAAE,SAAS;IACjB,MAAM,EAAE,QAAQ;IAChB,SAAS,EAAE,YAAY;IACvB,kBAAkB,EAAE,QAAQ;IAC5B,gBAAgB,EAAE,WAAW;IAC7B,oBAAoB,EAAE,UAAU;IAChC,kBAAkB,EAAE,aAAa;IACjC,sBAAsB,EAAE,aAAa;IACrC,oBAAoB,EAAE,gBAAgB;IACtC,YAAY,EAAE,aAAa;IAC3B,eAAe,EAAE,gBAAgB;IACjC,WAAW,EAAE,cAAc;IAC3B,eAAe,EAAE,gBAAgB;IACjC,gBAAgB,EAAE,QAAQ;IAC1B,iBAAiB,EAAE,WAAW;IAC9B,cAAc,EAAE,aAAa;IAC7B,6BAA6B,EAAE,yCAAyC;IACxE,2BAA2B,EAAE,4CAA4C;IAEzE,oBAAoB,EAAE,YAAY;IAClC,0BAA0B,EAAE,gDAAgD;IAC5E,wBAAwB,EAAE,aAAa;IACvC,8BAA8B,EAAE,8CAA8C;IAC9E,0BAA0B,EAAE,0BAA0B;IACtD,yBAAyB,EAAE,MAAM;IACjC,yBAAyB,EAAE,yBAAyB;IACpD,qBAAqB,EAAE,QAAQ;IAC/B,sBAAsB,EAAE,eAAe;IAEvC,yBAAyB,EAAE,kBAAkB;IAC7C,gBAAgB,EAAE,QAAQ;IAC1B,cAAc,EAAE,aAAa;IAC7B,mBAAmB,EAAE,kBAAkB;IACvC,gBAAgB,EAAE,eAAe;IAEjC,uBAAuB,EAAE,eAAe;IACxC,8BAA8B,EAAE,+DAA+D;IAC/F,4BAA4B,EAAE,kEAAkE;IAChG,mCAAmC,EAAE,kCAAkC;IACvE,yCAAyC,EAAE,gDAAgD;IAC3F,wCAAwC,EAAE,gCAAgC;IAC1E,8CAA8C,EAAE,8CAA8C;IAC9F,wBAAwB,EAAE,QAAQ;IAClC,yBAAyB,EAAE,eAAe;IAE1C,yBAAyB,EAAE,oBAAoB;IAC/C,+BAA+B,EAAE,kDAAkD;CACpF,CAAC;AA4EF,MAAM,CAAC,MAAM,sBAAsB,GAAkB;IACnD,aAAa,EAAE,SAAS;IACxB,YAAY,EAAE,QAAQ;IACtB,UAAU,EAAE,MAAM;IAClB,YAAY,EAAE,WAAW;IACzB,WAAW,EAAE,cAAc;IAC3B,iBAAiB,EAAE,0CAA0C;CAC9D,CAAC;AAMF,MAAM,CAAC,MAAM,aAAa,GAAG,4BAA4B,CAAC;AAE1D,gGAAgG;AAChG,MAAM,CAAC,MAAM,gBAAgB,GAAG,6BAA6B,CAAC","sourcesContent":["export interface FolderNode {\n  id: number;\n  name: string;\n  /** Direct test-case count — cases with `folderId === this.id`. Rendered as the row badge. */\n  count?: number;\n  /** Total test-case count including all descendants. Rendered as a tooltip on the folder row. */\n  totalCount?: number;\n  color?: string;\n  children?: FolderNode[];\n}\n\nexport type FolderIdAccessor = (row: any) => number | null | undefined;\n\nexport interface ModularConfig {\n  showSidebar: boolean;\n  showBreadcrumb: boolean;\n  showFolderGrid: boolean;\n  showUnorganisedSection: boolean;\n  showSubfolderSection: boolean;\n  showCounts: boolean;\n  allowCreateFolder: boolean;\n  allowRenameFolder: boolean;\n  allowDeleteFolder: boolean;\n  allowNestedFolders: boolean;\n  allowTestDragDrop: boolean;\n  allowBulkSelection: boolean;\n}\n\nexport const DEFAULT_MODULAR_CONFIG: ModularConfig = {\n  showSidebar: true,\n  showBreadcrumb: true,\n  showFolderGrid: true,\n  showUnorganisedSection: true,\n  showSubfolderSection: true,\n  showCounts: true,\n  allowCreateFolder: true,\n  allowRenameFolder: true,\n  allowDeleteFolder: true,\n  allowNestedFolders: true,\n  allowTestDragDrop: true,\n  allowBulkSelection: true,\n};\n\nexport interface ModularLabels {\n  folders: string;\n  organised: string;\n  unorganised: string;\n  newFolder: string;\n  searchFoldersPlaceholder: string;\n  allFolders: string;\n  subfoldersIn: string;\n  moveToFolder: string;\n  addTag: string;\n  delete: string;\n  selectAll: string;\n  testsCountSingular: string;\n  testsCountPlural: string;\n  foldersCountSingular: string;\n  foldersCountPlural: string;\n  subfolderCountSingular: string;\n  subfolderCountPlural: string;\n  oneSubfolder: string;\n  subfoldersCount: string;\n  clearFilter: string;\n  moveDialogTitle: string;\n  moveDialogCancel: string;\n  moveDialogConfirm: string;\n  moveDialogRoot: string;\n  moveDialogDescriptionSingular: string;\n  moveDialogDescriptionPlural: string;\n\n  // New Folder dialog\n  newFolderDialogTitle: string;\n  newFolderDialogDescription: string;\n  newFolderDialogNameLabel: string;\n  newFolderDialogNamePlaceholder: string;\n  newFolderDialogParentLabel: string;\n  newFolderDialogParentNone: string;\n  newFolderDialogColorLabel: string;\n  newFolderDialogCancel: string;\n  newFolderDialogConfirm: string;\n\n  // Folder row context menu (right-click / ellipsis)\n  folderMenuCreateSubfolder: string;\n  folderMenuRename: string;\n  folderMenuMove: string;\n  folderMenuDuplicate: string;\n  folderMenuDelete: string;\n\n  // Delete Folder dialog\n  deleteFolderDialogTitle: string;\n  deleteFolderDialogBodySingular: string;\n  deleteFolderDialogBodyPlural: string;\n  deleteFolderDialogMoveToParentTitle: string;\n  deleteFolderDialogMoveToParentDescription: string;\n  deleteFolderDialogMoveToUnorganisedTitle: string;\n  deleteFolderDialogMoveToUnorganisedDescription: string;\n  deleteFolderDialogCancel: string;\n  deleteFolderDialogConfirm: string;\n\n  // Auto-derived empty states (shown when pagedRows is empty and host did not set isEmptyState)\n  emptyNoTestsInFolderTitle: string;\n  emptyNoTestsInFolderDescription: string;\n}\n\nexport const DEFAULT_MODULAR_LABELS: ModularLabels = {\n  folders: 'Folders',\n  organised: 'Organised',\n  unorganised: 'Unorganised',\n  newFolder: 'New folder',\n  searchFoldersPlaceholder: 'Search folders...',\n  allFolders: 'All folders',\n  subfoldersIn: 'Subfolders in',\n  moveToFolder: 'Move to folder',\n  addTag: 'Add Tag',\n  delete: 'Delete',\n  selectAll: 'Select all',\n  testsCountSingular: '1 test',\n  testsCountPlural: '{n} tests',\n  foldersCountSingular: '1 folder',\n  foldersCountPlural: '{n} folders',\n  subfolderCountSingular: '1 subfolder',\n  subfolderCountPlural: '{n} subfolders',\n  oneSubfolder: '1 subfolder',\n  subfoldersCount: '{n} subfolders',\n  clearFilter: 'Clear filter',\n  moveDialogTitle: 'Move to Folder',\n  moveDialogCancel: 'Cancel',\n  moveDialogConfirm: 'Move here',\n  moveDialogRoot: 'Unorganised',\n  moveDialogDescriptionSingular: 'Moving 1 test case — select destination',\n  moveDialogDescriptionPlural: 'Moving {n} test cases — select destination',\n\n  newFolderDialogTitle: 'New Folder',\n  newFolderDialogDescription: 'Rename any time by double-clicking in the tree',\n  newFolderDialogNameLabel: 'Folder name',\n  newFolderDialogNamePlaceholder: 'e.g. Checkout Flow, User Auth, Payment Tests',\n  newFolderDialogParentLabel: 'Parent folder (optional)',\n  newFolderDialogParentNone: 'None',\n  newFolderDialogColorLabel: 'Folder color (optional)',\n  newFolderDialogCancel: 'Cancel',\n  newFolderDialogConfirm: 'Create folder',\n\n  folderMenuCreateSubfolder: 'Create subfolder',\n  folderMenuRename: 'Rename',\n  folderMenuMove: 'Move folder',\n  folderMenuDuplicate: 'Duplicate folder',\n  folderMenuDelete: 'Delete folder',\n\n  deleteFolderDialogTitle: 'Delete folder',\n  deleteFolderDialogBodySingular: 'This folder contains 1 test case. What should happen to them?',\n  deleteFolderDialogBodyPlural: 'This folder contains {n} test cases. What should happen to them?',\n  deleteFolderDialogMoveToParentTitle: 'Move test cases to parent folder',\n  deleteFolderDialogMoveToParentDescription: 'Test cases move one level up — nothing is lost',\n  deleteFolderDialogMoveToUnorganisedTitle: 'Move test cases to Unorganised',\n  deleteFolderDialogMoveToUnorganisedDescription: 'Test cases return to the Unorganised section',\n  deleteFolderDialogCancel: 'Cancel',\n  deleteFolderDialogConfirm: 'Delete folder',\n\n  emptyNoTestsInFolderTitle: 'No Test Case Found',\n  emptyNoTestsInFolderDescription: 'This folder does not contain any test cases yet.',\n};\n\n/**\n * Emitted after a successful inline folder rename. Carries the full renamed node\n * (with the new name already applied) plus its parent id, so hosts can issue\n * a complete update request (e.g. `PUT /test_case_folders/{id}`) without a\n * secondary lookup against their cached tree.\n */\nexport interface FolderRenamedPayload {\n  folder: FolderNode;\n  parentId: number | null;\n  /** Previous name, useful for undo messages / audit logs. */\n  previousName: string;\n}\n\nexport interface FolderCreatedPayload {\n  parentId: number | null;\n  name: string;\n  color?: string;\n}\n\n/**\n * Delete strategies match the backend `strategy` query param values on\n * `DELETE /test_case_folders/{id}?strategy=…`. Only the two move strategies\n * are covered by the library's internal dialog; `DELETE_IF_EMPTY` is the\n * host's responsibility (precheck `count === 0 && totalCount === 0`).\n */\nexport type FolderDeleteStrategy = 'MOVE_TO_PARENT' | 'MOVE_TO_UNORGANISED';\n\nexport interface FolderDeleteRequestedPayload {\n  id: number;\n  name: string;\n  testCount: number;\n  hasParent: boolean;\n}\n\nexport interface FolderMoveRequestedPayload {\n  id: number;\n  name: string;\n  hasParent: boolean;\n}\n\nexport interface FolderMovedPayload {\n  id: number;\n  newParentId: number | null;\n}\n\nexport interface FolderDuplicateRequestedPayload {\n  id: number;\n  name: string;\n}\n\nexport interface FolderDeletedPayload {\n  id: number;\n  strategy?: FolderDeleteStrategy;\n}\n\nexport interface TestsMovedPayload {\n  testIds: Array<string | number>;\n  targetFolderId: number | null;\n}\n\nexport interface BulkActionInvokedPayload {\n  id: string;\n  selected: any[];\n}\n\nexport interface ReorderLabels {\n  reorderButton: string;\n  cancelButton: string;\n  doneButton: string;\n  savingButton: string;\n  bannerTitle: string;\n  bannerDescription: string;\n}\n\nexport const DEFAULT_REORDER_LABELS: ReorderLabels = {\n  reorderButton: 'Reorder',\n  cancelButton: 'Cancel',\n  doneButton: 'Done',\n  savingButton: 'Saving...',\n  bannerTitle: 'Reorder mode',\n  bannerDescription: 'Drag rows using the handle to rearrange.',\n};\n\nexport interface ReorderSavePayload {\n  orderedItems: any[];\n}\n\nexport const ROW_DRAG_MIME = 'application/x-cqa-test-ids';\n\n/** Custom MIME for folder-row drags in the sidebar. Payload is a JSON-stringified folder id. */\nexport const FOLDER_DRAG_MIME = 'application/x-cqa-folder-id';\n"]}