@genexus/genexus-ide-ui 1.1.39 → 1.1.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/genexus-ide-ui.cjs.js +1 -1
- package/dist/cjs/gx-ide-server-selector.cjs.entry.js +12 -28
- package/dist/cjs/gx-ide-server-selector.cjs.entry.js.map +1 -1
- package/dist/cjs/{gx-ide-status-message.cjs.entry.js → gx-ide-sign-in-result.cjs.entry.js} +10 -9
- package/dist/cjs/gx-ide-sign-in-result.cjs.entry.js.map +1 -0
- package/dist/cjs/gx-ide-team-dev-bring-changes.cjs.entry.js +20 -4
- package/dist/cjs/gx-ide-team-dev-bring-changes.cjs.entry.js.map +1 -1
- package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js +99 -238
- package/dist/cjs/gx-ide-team-dev-commit.cjs.entry.js.map +1 -1
- package/dist/cjs/gx-ide-team-dev-history.cjs.entry.js +9 -7
- package/dist/cjs/gx-ide-team-dev-history.cjs.entry.js.map +1 -1
- package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js +60 -10
- package/dist/cjs/gx-ide-team-dev-update.cjs.entry.js.map +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/tabular-grid-column-sort-5ca06dc1.js +43 -0
- package/dist/cjs/tabular-grid-column-sort-5ca06dc1.js.map +1 -0
- package/dist/cjs/tabular-grid-render-4350dbaf.js +223 -0
- package/dist/cjs/tabular-grid-render-4350dbaf.js.map +1 -0
- package/dist/cjs/uncheck-ignored-77ca69fe.js +43 -0
- package/dist/cjs/uncheck-ignored-77ca69fe.js.map +1 -0
- package/dist/collection/collection-manifest.json +1 -1
- package/dist/collection/common/chameleon/tabular-grid-column-sort.js +39 -0
- package/dist/collection/common/chameleon/tabular-grid-column-sort.js.map +1 -0
- package/dist/collection/components/{status-message/status-message.css → sign-in-result/sign-in-result.css} +2 -0
- package/dist/collection/components/{status-message/status-message.js → sign-in-result/sign-in-result.js} +10 -9
- package/dist/collection/components/sign-in-result/sign-in-result.js.map +1 -0
- package/dist/collection/components/team-dev/bring-changes/bring-changes.js +18 -4
- package/dist/collection/components/team-dev/bring-changes/bring-changes.js.map +1 -1
- package/dist/collection/components/team-dev/history/history.js +10 -8
- package/dist/collection/components/team-dev/history/history.js.map +1 -1
- package/dist/collection/components/team-dev/server-selector/server-selector.css +18 -14
- package/dist/collection/components/team-dev/server-selector/server-selector.js +11 -27
- package/dist/collection/components/team-dev/server-selector/server-selector.js.map +1 -1
- package/dist/collection/components/team-dev/update/update.css +1 -0
- package/dist/collection/components/team-dev/update/update.js +62 -9
- package/dist/collection/components/team-dev/update/update.js.map +1 -1
- package/dist/collection/components/team-dev/version-control/commit/commit.css +1 -0
- package/dist/collection/components/team-dev/version-control/commit/commit.js +79 -20
- package/dist/collection/components/team-dev/version-control/commit/commit.js.map +1 -1
- package/dist/collection/components/team-dev/version-control/common/are-sets-equal.js +21 -0
- package/dist/collection/components/team-dev/version-control/common/are-sets-equal.js.map +1 -0
- package/dist/collection/components/team-dev/version-control/common/tabular-grid-render.js +13 -3
- package/dist/collection/components/team-dev/version-control/common/tabular-grid-render.js.map +1 -1
- package/dist/collection/components/team-dev/version-control/common/uncheck-ignored.js +18 -0
- package/dist/collection/components/team-dev/version-control/common/uncheck-ignored.js.map +1 -0
- package/dist/collection/testing/locale.e2e.js +1 -1
- package/dist/collection/testing/locale.e2e.js.map +1 -1
- package/dist/components/gx-ide-server-selector.js +12 -28
- package/dist/components/gx-ide-server-selector.js.map +1 -1
- package/dist/components/{gx-ide-status-message.d.ts → gx-ide-sign-in-result.d.ts} +4 -4
- package/dist/components/{gx-ide-status-message.js → gx-ide-sign-in-result.js} +15 -14
- package/dist/components/gx-ide-sign-in-result.js.map +1 -0
- package/dist/components/gx-ide-team-dev-bring-changes.js +18 -4
- package/dist/components/gx-ide-team-dev-bring-changes.js.map +1 -1
- package/dist/components/gx-ide-team-dev-commit.js +78 -221
- package/dist/components/gx-ide-team-dev-commit.js.map +1 -1
- package/dist/components/gx-ide-team-dev-history.js +9 -7
- package/dist/components/gx-ide-team-dev-history.js.map +1 -1
- package/dist/components/gx-ide-team-dev-update.js +61 -10
- package/dist/components/gx-ide-team-dev-update.js.map +1 -1
- package/dist/components/tabular-grid-column-sort.js +41 -0
- package/dist/components/tabular-grid-column-sort.js.map +1 -0
- package/dist/components/tabular-grid-render.js +216 -0
- package/dist/components/tabular-grid-render.js.map +1 -0
- package/dist/components/uncheck-ignored.js +40 -0
- package/dist/components/uncheck-ignored.js.map +1 -0
- package/dist/esm/genexus-ide-ui.js +1 -1
- package/dist/esm/gx-ide-server-selector.entry.js +12 -28
- package/dist/esm/gx-ide-server-selector.entry.js.map +1 -1
- package/dist/esm/{gx-ide-status-message.entry.js → gx-ide-sign-in-result.entry.js} +10 -9
- package/dist/esm/gx-ide-sign-in-result.entry.js.map +1 -0
- package/dist/esm/gx-ide-team-dev-bring-changes.entry.js +20 -4
- package/dist/esm/gx-ide-team-dev-bring-changes.entry.js.map +1 -1
- package/dist/esm/gx-ide-team-dev-commit.entry.js +81 -220
- package/dist/esm/gx-ide-team-dev-commit.entry.js.map +1 -1
- package/dist/esm/gx-ide-team-dev-history.entry.js +9 -7
- package/dist/esm/gx-ide-team-dev-history.entry.js.map +1 -1
- package/dist/esm/gx-ide-team-dev-update.entry.js +60 -10
- package/dist/esm/gx-ide-team-dev-update.entry.js.map +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/esm/tabular-grid-column-sort-1d503b27.js +41 -0
- package/dist/esm/tabular-grid-column-sort-1d503b27.js.map +1 -0
- package/dist/esm/tabular-grid-render-f7eb612b.js +216 -0
- package/dist/esm/tabular-grid-render-f7eb612b.js.map +1 -0
- package/dist/esm/uncheck-ignored-4ba48c9e.js +40 -0
- package/dist/esm/uncheck-ignored-4ba48c9e.js.map +1 -0
- package/dist/genexus-ide-ui/genexus-ide-ui.esm.js +1 -1
- package/dist/genexus-ide-ui/genexus-ide-ui.esm.js.map +1 -1
- package/dist/genexus-ide-ui/p-02fb496a.js +36 -0
- package/dist/genexus-ide-ui/p-02fb496a.js.map +1 -0
- package/dist/genexus-ide-ui/p-06e8d9d6.entry.js +63 -0
- package/dist/genexus-ide-ui/p-06e8d9d6.entry.js.map +1 -0
- package/dist/genexus-ide-ui/{p-585fac4a.entry.js → p-2b38e18e.entry.js} +15 -13
- package/dist/genexus-ide-ui/p-2b38e18e.entry.js.map +1 -0
- package/dist/genexus-ide-ui/{p-970e89ac.entry.js → p-4b06b578.entry.js} +100 -115
- package/dist/genexus-ide-ui/p-4b06b578.entry.js.map +1 -0
- package/dist/genexus-ide-ui/{p-34447b77.entry.js → p-4e3ad78d.entry.js} +261 -234
- package/dist/genexus-ide-ui/p-4e3ad78d.entry.js.map +1 -0
- package/dist/genexus-ide-ui/p-77c2e69d.js +314 -0
- package/dist/genexus-ide-ui/p-77c2e69d.js.map +1 -0
- package/dist/genexus-ide-ui/p-a7883e6b.entry.js +691 -0
- package/dist/genexus-ide-ui/p-a7883e6b.entry.js.map +1 -0
- package/dist/genexus-ide-ui/p-c9b9e260.js +36 -0
- package/dist/genexus-ide-ui/p-c9b9e260.js.map +1 -0
- package/dist/genexus-ide-ui/{p-42f37527.entry.js → p-e1a2550e.entry.js} +351 -289
- package/dist/genexus-ide-ui/p-e1a2550e.entry.js.map +1 -0
- package/dist/types/common/chameleon/tabular-grid-column-sort.d.ts +4 -0
- package/dist/types/components/{status-message/status-message.d.ts → sign-in-result/sign-in-result.d.ts} +2 -2
- package/dist/types/components/team-dev/history/history.d.ts +2 -2
- package/dist/types/components/team-dev/update/update.d.ts +6 -0
- package/dist/types/components/team-dev/version-control/commit/commit.d.ts +15 -13
- package/dist/types/components/team-dev/version-control/common/are-sets-equal.d.ts +12 -0
- package/dist/types/components/team-dev/version-control/common/tabular-grid-render.d.ts +13 -1
- package/dist/types/components/team-dev/version-control/common/uncheck-ignored.d.ts +13 -0
- package/dist/types/components.d.ts +13 -13
- package/package.json +1 -1
- package/dist/cjs/gx-ide-status-message.cjs.entry.js.map +0 -1
- package/dist/collection/components/status-message/status-message.js.map +0 -1
- package/dist/components/gx-ide-status-message.js.map +0 -1
- package/dist/esm/gx-ide-status-message.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-34447b77.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-42f37527.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-50253b96.entry.js +0 -61
- package/dist/genexus-ide-ui/p-50253b96.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-585fac4a.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-723d25ae.entry.js +0 -912
- package/dist/genexus-ide-ui/p-723d25ae.entry.js.map +0 -1
- package/dist/genexus-ide-ui/p-970e89ac.entry.js.map +0 -1
- /package/dist/collection/components/{status-message/gx-ide-assets/status-message → sign-in-result/gx-ide-assets/sign-in-result}/images/genexus-next-logo.svg +0 -0
- /package/dist/collection/components/{status-message/gx-ide-assets/status-message → sign-in-result/gx-ide-assets/sign-in-result}/images/left-side-illustration.svg +0 -0
- /package/dist/collection/components/{status-message/gx-ide-assets/status-message → sign-in-result/gx-ide-assets/sign-in-result}/images/right-side-illustration.svg +0 -0
- /package/dist/collection/components/{status-message/gx-ide-assets/status-message/langs/status-message.lang.en.json → sign-in-result/gx-ide-assets/sign-in-result/langs/sign-in-result.lang.en.json} +0 -0
- /package/dist/collection/components/{status-message/gx-ide-assets/status-message/langs/status-message.lang.ja.json → sign-in-result/gx-ide-assets/sign-in-result/langs/sign-in-result.lang.ja.json} +0 -0
- /package/dist/collection/components/{status-message/gx-ide-assets/status-message/langs/status-message.lang.zh.json → sign-in-result/gx-ide-assets/sign-in-result/langs/sign-in-result.lang.zh.json} +0 -0
- /package/dist/genexus-ide-ui/gx-ide-assets/{status-message → sign-in-result}/images/genexus-next-logo.svg +0 -0
- /package/dist/genexus-ide-ui/gx-ide-assets/{status-message → sign-in-result}/images/left-side-illustration.svg +0 -0
- /package/dist/genexus-ide-ui/gx-ide-assets/{status-message → sign-in-result}/images/right-side-illustration.svg +0 -0
- /package/dist/genexus-ide-ui/gx-ide-assets/{status-message/langs/status-message.lang.en.json → sign-in-result/langs/sign-in-result.lang.en.json} +0 -0
- /package/dist/genexus-ide-ui/gx-ide-assets/{status-message/langs/status-message.lang.ja.json → sign-in-result/langs/sign-in-result.lang.ja.json} +0 -0
- /package/dist/genexus-ide-ui/gx-ide-assets/{status-message/langs/status-message.lang.zh.json → sign-in-result/langs/sign-in-result.lang.zh.json} +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["bringChangesCss","CSS_BUNDLES","COMBO_BOX_ALL_VALUE","DETAIL_LABEL_CLASSES","ADD_ICON","getIconPath","category","name","colorType","EDITED_ICON","FILTER_ICON","SEARCH_ICON","SUBSTRACT_ICON","WARNING_ICON","ERROR_ICON","GxIdeTeamDevBringChanges","_GxIdeTeamDevBringChanges_componentLocale","set","this","_GxIdeTeamDevBringChanges_commitLabel","_GxIdeTeamDevBringChanges_comboBoxStatesModel","_GxIdeTeamDevBringChanges_checkedObjectsIdsArray","_GxIdeTeamDevBringChanges_formatComments","commitInformation","length","comment","mergedComment","map","commit","i","isLast","afterCommentBreakline","id","_GxIdeTeamDevBringChanges_mergeCheckedClickedHandler","async","merging","newobjectsStatesMap","Map","objectsStatesMap","__classPrivateFieldGet","forEach","checkedObjectId","operationType","mergeObjectsCallback","_GxIdeTeamDevBringChanges_mergeSingleObject","objectId","_GxIdeTeamDevBringChanges_renderActionCellContent","actionTaken","icon","caption","iconColor","objects","actions","delete","insert","modify","h","class","type","src","style","backgroundColor","_GxIdeTeamDevBringChanges_renderCommitsNumbers","onlyNumbers","_a","_b","loading","_GxIdeTeamDevBringChanges_renderFormatedDate","date","dateObject","Date","lang","navigator","languages","language","toLocaleDateString","toLocaleTimeString","hour","minute","hour12","_GxIdeTeamDevBringChanges_renderObjectStateWithIcon","objectType","states","reverting","classes","revertPillAsButton","onClick","call","statesForButton","_GxIdeTeamDevBringChanges_renderObjectsRows","objectsFiltered","commitObject","marked","markedObjectsSet","has","alreadyMerged","alreadyMergedObjectsIdsArray","find","errorOrWarningMessage","commitObjectsMessagesMap","get","state","MESSAGE_ICON","key","rowid","ref","el","setAttribute","size","renderObjectTypeWithIcon","description","_GxIdeTeamDevBringChanges_rowContextMenuHandler","ev","preventDefault","selectedRowsIds","tabularGridEl","getSelectedRows","contextMenuCallback","selection","clientX","detail","clientY","_GxIdeTeamDevBringChanges_rowMarkingChangedHandler","event","newobjectsMarkedSet","Set","markedRowsIds","rowsId","checkedObjectsIgnoringAlreadyMerged","filter","markedObjectId","includes","__classPrivateFieldSet","add","atLeastOneObjectIsChecked","objectCurrentState","markedRowIndex","findIndex","splice","_GxIdeTeamDevBringChanges_searchInputHandler","searchValue","toLowerCase","_GxIdeTeamDevBringChanges_updateFilteredObjects","_GxIdeTeamDevBringChanges_stateChangedHandler","stateFilterValue","filteredObjects","commitObjects","object","objectState","includesName","includesType","includesDescription","_GxIdeTeamDevBringChanges_sortTabularGridColumnCallback","e","columnId","objectProperty","dateType","COLUMNS_IDS","sortTabularGridColumn","objectsStatesMapChanged","newCommitObjectsStateMap","someObjectIsMerging","entries","commitObjectsChanged","newCommitObjects","componentWillLoad","Locale","getComponentStrings","commmits","commmit","all","value","warning","error","reverted","merged","updateObjectState","newState","message","checkedObject","push","markRow","render","enableRichRowSelector","disableControls","Host","model","commitDetail","revertChangesDetail","bringChangesDetail","genexusServer","href","target","knowledgeBase","currentVersion","mergeFromVersion","title","ids","from","to","htmlFor","comments","multiline","readonly","hideFilters","disabled","startImgSrc","placeholder","searchPlaceholder","onInput","statePlaceholder","revertSelected","mergeSelected","keyboardNavigationMode","rowSelectionMode","onRowMarkingChanged","onRowContextMenu","columnName","columnType","richRowSelector","richRowSelectorMode","settingable","sortable","onColumnSortChanged","config","tabularGrid","colSize","action","status","isAnimated","stateIconSrc","stateTitle","cancelLabel","loader","loaderTitle","show"],"sources":["src/components/team-dev/bring-changes/bring-changes.scss?tag=gx-ide-team-dev-bring-changes&encapsulation=shadow","src/components/team-dev/bring-changes/bring-changes.tsx"],"sourcesContent":["@import \"../common/styles.scss\";\n@import \"../../../../node_modules/@genexus/mercury/dist/assets/scss/helpers.scss\";\n@import \"../../../global/gx-ide-mixins.scss\";\n\n:host {\n --pill-border-radius: 12px;\n --pill-padding-inline: 8px;\n --pill-padding-block: 2px;\n --pill-font-size: var(--font-size-body-s);\n\n display: grid;\n block-size: 100%;\n overflow: auto;\n grid-template-rows: max-content max-content 1fr;\n}\n$header-item-common-inline-padding: 24px;\n$header-item-common-separator-border: 1px solid\n var(--mer-border-color__on-elevation--01);\n\n%header-item-common-inline-sizes {\n max-inline-size: 250px;\n min-inline-size: 180px;\n}\n%header-item-common {\n padding-inline: $header-item-common-inline-padding;\n border-inline-end: $header-item-common-separator-border;\n @extend %header-item-common-inline-sizes;\n}\n%header-item-common-start {\n padding-inline-end: $header-item-common-inline-padding;\n border-inline-end: $header-item-common-separator-border;\n}\n%header-item-common-end {\n padding-inline-start: $header-item-common-inline-padding;\n}\n\n.section {\n display: contents;\n}\n\n.header {\n display: grid;\n gap: 24px;\n}\n\n// header detail\n.header__detail {\n display: grid;\n grid-template-areas:\n \"detail-title detail-title detail-title detail-title\"\n \"detail-commit-name detail-commit-name detail-commit-name detail-commit-name\"\n \"detail-genexus-server detail-knowledge-base detail-current-version detail-merge-from-version\";\n row-gap: 16px;\n // grid-auto-columns: max-content;\n // grid-template-columns: max-content auto auto auto;\n grid-template-columns: minmax(250px, 350px) repeat(3, minmax(180px, 250px));\n}\n.detail__label {\n color: var(--mer-color__neutral-gray--400);\n}\n.detail__title {\n grid-area: detail-title;\n}\n.detail__commit-name {\n grid-area: detail-commit-name;\n}\n.detail__genexus-server {\n grid-area: detail-genexus-server;\n @extend %header-item-common-start;\n\n > a {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n display: inline-block;\n }\n}\n.detail__link {\n align-items: start;\n color: var(--mer-text__primary);\n text-decoration: underline;\n &:hover {\n color: var(--mer-text__primary--hover);\n }\n &:active {\n color: var(--mer-text__primary--active);\n }\n}\n.detail__knowledge-base {\n grid-area: detail-knowledge-base;\n @extend %header-item-common;\n}\n.detail__current-version {\n grid-area: detail-current-version;\n @extend %header-item-common;\n}\n.detail__merge-from-version {\n grid-area: detail-merge-from-version;\n @extend %header-item-common-end;\n}\n\n// header information\n.header__information {\n display: grid;\n row-gap: 10px;\n grid-template-areas:\n \"information-title information-title\"\n \"information-col-1 information-col-2\";\n grid-template-columns: max-content 1fr;\n grid-template-rows: max-content 64px;\n}\n.information__title {\n grid-area: information-title;\n}\n.information__col-1 {\n grid-area: information-col-1;\n display: flex;\n gap: 24px;\n @extend %header-item-common-start;\n}\n.information__col-2 {\n display: grid;\n grid-area: information-col-2;\n @extend %header-item-common-end;\n}\n\n// filter / controls-container\n.controls-container {\n display: grid;\n margin-block-start: 24px;\n}\n.filter {\n grid-template-columns: 232px 186px 1fr;\n gap: 12px;\n}\n.button-merge-checked {\n margin-inline-start: auto;\n}\n\n// main\n.main {\n position: relative;\n display: grid;\n overflow: auto;\n}\n.loader {\n position: relative;\n inline-size: 100%;\n block-size: 100%;\n inset-block-start: 0;\n}\n.tabular-grid {\n border-radius: 4px;\n overflow: hidden;\n}\n\n.empty-state {\n block-size: 100%;\n}\n.loader {\n --elevation-background-color: var(--mer-surface__elevation--01);\n}\n\n.warning-error-description {\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 8px;\n max-inline-size: 800px;\n line-height: 1.5; // WA. Line height looks too tight.\n}\n.warning-error-icon {\n flex-shrink: 0;\n}\n\n.tabular-grid.empty-result::part(main) {\n // WA to avoid scrollbar flickering when displaying the empty-state message\n overflow: hidden;\n}\n\n// - - - - - - - - - - - - - -\n// WA (WORK AROUNDS)\n// - - - - - - - - - - - - - -\n\n.input-comments-container {\n position: relative;\n}\n// ch-edit for comments WA's\n// Figma design for this component displays the textarea witout border, and with a little more line-height.\n// The following styles are a temporary WA that should be brouhgt to Mercury DS.\n.input-comments {\n --control__border-color: transparent;\n padding-block: 0 !important;\n padding-inline: 0 !important;\n --line-height-tight: 1.4;\n block-size: 100%;\n background-color: var(--mer-surface);\n transition:\n var(--mer-timing--super-fast) block-size,\n var(--mer-timing--super-fast) background-color,\n var(--mer-timing--super-fast) padding-block,\n var(--mer-timing--super-fast) padding-inline;\n}\n.input-comments:focus {\n position: absolute;\n block-size: 200px;\n inline-size: 100%;\n z-index: 99;\n background-color: var(--mer-surface__elevation--01);\n padding-block: var(--control__padding-block) !important;\n padding-inline: var(--control__padding-inline) !important;\n}\n\nch-tabular-grid-cell.tabular-grid-cell::part(actions-icon) {\n background-size: contain; //force icon fit container\n margin-inline-end: 0;\n --icon-path: var(--icon__gemini-tools_show-more-vertical_neutral--enabled);\n cursor: pointer;\n &:hover {\n --icon-path: var(--icon__gemini-tools_show-more-vertical_neutral--hover);\n }\n &:active {\n --icon-path: var(--icon__gemini-tools_show-more-vertical_neutral--active);\n }\n}\n\n.tabular-grid-row-actions::part(main),\n.property-grid-row-actions::part(main) {\n // gap not required since buttons are tertiary.\n // extra space perceived.\n gap: 0 !important;\n}\n\n.tabular-grid-row-actions {\n // Butons are center by default, but design dictates start alignemnt\n > button {\n justify-content: start;\n }\n}\n\n// These static type of pills do not exist on Mercury yet.\n// They should be defined on Mercury. The actual pills on Mercury\n// are combo-boxes. Not what we need for this case.\n\n.pill {\n --pill-background-color: transparent;\n --pill-color: transparent;\n --pill-border-color: transparent;\n\n background-color: var(--pill-background-color);\n color: var(--pill-color);\n border: 1px solid var(--pill-border-color);\n inline-size: 100%;\n padding: var(--pill-padding-block) var(--pill-padding-inline);\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: var(--pill-border-radius);\n position: relative;\n font-weight: var(--font-weight-semi-bold);\n\n &--to-merge,\n &--to-revert {\n --pill-background-color: var(--mer-color__tinted-primary--8);\n --pill-color: var(--mer-border-color__primary);\n --pill-border-color: var(--mer-color__tinted-primary--50);\n }\n &--to-merge-marked {\n --pill-background-color: var();\n --pill-color: var(--mer-border-color__primary);\n --pill-border-color: var();\n }\n &--pending {\n --pill-background-color: var(--mer-color__tinted-primary--8);\n --pill-color: var(--mer-border-color__primary);\n --pill-border-color: var(--mer-color__tinted-primary--50);\n }\n &--warning {\n --pill-background-color: var(--mer-color__tinted-yellow--5);\n --pill-color: var(--mer-border-color__warning);\n --pill-border-color: var(--mer-color__tinted-yellow--60);\n }\n &--error {\n --pill-background-color: var(--mer-color__tinted-red--5);\n --pill-color: var(--mer-border-color__error);\n --pill-border-color: var(--mer-color__tinted-red--60);\n }\n &--merged,\n &--reverted {\n --pill-background-color: var(--mer-color__tinted-green--5);\n --pill-color: var(--mer-border-color__success);\n --pill-border-color: var(--mer-color__tinted-green--60);\n }\n &--transitioning {\n // used to hide the text, before updating the caption (smooth transtion)\n --pill-color: transparent;\n }\n}\n.merging-spinner-caption {\n display: flex;\n align-items: center;\n gap: 6px;\n $size: 14px;\n --status-circle-color: transparent;\n --status-circle-size: $size;\n --status-circle-inset-inline-start: 14px;\n --pill-color: var(--mer-border-color__primary);\n &::before {\n display: inline-block;\n content: \"\";\n\n @include spinner(\n $size,\n var(--mer-color__primary--300),\n var(--mer-color__tinted-primary--50)\n );\n }\n}\n.tabular-grid .button-secondary {\n --control__padding-block: var(--pill-padding-block);\n --control__padding-inline: var(--pill-padding-inline);\n font-size: inherit;\n font-weight: inherit;\n /* font-size: var(--pill-font-size); */\n}\n\n.tabular-grid .tabular-grid-cell--for-pill {\n --grid-cell__padding-block: 4px;\n align-items: center;\n justify-content: center;\n\n // --grid-cell__padding-inline: 0;\n}\n\n.tabular-grid.disabled-custom-selector .tabular-grid-cell::part(selector-label),\n.tabular-grid.disabled-custom-selector .tabular-grid-column::part(bar-selector),\n.tabular-grid.disabled-custom-selector .tabular-grid-cell::part(actions-icon) {\n pointer-events: none;\n opacity: 0.5;\n}\n.tabular-grid-column--settings-custom-selector,\n.tabular-grid-cell--settings-custom-selector {\n --grid-cell__padding-inline: 0;\n --grid-cell__padding-block: 0;\n}\n.tabular-grid-cell::part(actions-icon) {\n padding-block: 6px;\n}\nch-tabular-grid-cell.tabular-grid-cell::part(actions-icon) {\n block-size: 100%;\n display: block;\n background-size: 14px;\n padding-inline: 16px;\n}\n\n.tabular-grid-cell.no-checkbox-custom-selector::part(selector-label) {\n visibility: hidden;\n}\n\n.tabular-grid-row-actions::part(window) {\n background-color: var(--mer-surface__elevation--02) !important;\n}\n\n.tabular-grid-row .tabular-grid-cell:nth-child(3) {\n min-inline-size: 400px;\n}\n\n// - - - - - - - - - - - - - -\n// END OF WA\n// - - - - - - - - - - - - - -\n","import {\n Component,\n Host,\n h,\n Prop,\n Element,\n State,\n Method,\n JSX,\n Watch\n} from \"@stencil/core\";\n\nimport { MercuryBundles, getIconPath } from \"@genexus/mercury\";\nimport { Locale } from \"../../../common/locale\";\nimport {\n ChEditCustomEvent,\n TabularGridMarkingChangedEvent,\n TabularGridColumnSortChangedEvent,\n TabularGridRowContextMenuEvent\n} from \"@genexus/chameleon-controls-library\";\nimport { ObjectType } from \"../../../components\";\n\nimport { config } from \"../../../common/config\";\n\nimport { ContextMenuCallback } from \"../../../components\";\n\nimport { renderObjectTypeWithIcon } from \"../common/utilities\";\n\nimport { COLUMNS_IDS } from \"../version-control/common/tabular-grid-render\";\nimport sortTabularGridColumn, {\n type SortTabularGridColumnDataType\n} from \"../../../common/chameleon/tabular-grid-column-sort\";\n\nconst CSS_BUNDLES: MercuryBundles = [\n \"resets/box-sizing\",\n \"components/tabular-grid\",\n \"utils/form--full\",\n \"utils/layout\",\n \"utils/typography\",\n \"utils/spacing\",\n \"chameleon/scrollbar\"\n];\n\nconst COMBO_BOX_ALL_VALUE = \"all\";\n\nconst DETAIL_LABEL_CLASSES = \"detail__label body-semi-bold-s\";\n\nconst ADD_ICON = getIconPath({\n category: \"system\",\n name: \"add\",\n colorType: \"on-elevation\"\n});\nconst EDITED_ICON = getIconPath({\n category: \"system\",\n name: \"edit\",\n colorType: \"on-elevation\"\n});\nconst FILTER_ICON = getIconPath({\n category: \"window-tools\",\n name: \"filter\",\n colorType: \"on-elevation\"\n});\nconst SEARCH_ICON = getIconPath({\n category: \"system\",\n name: \"search\",\n colorType: \"on-elevation\"\n});\nconst SUBSTRACT_ICON = getIconPath({\n category: \"system\",\n name: \"substract\",\n colorType: \"on-elevation\"\n});\nconst WARNING_ICON = getIconPath({\n category: \"system\",\n name: \"warning\",\n colorType: \"warning\"\n});\nconst ERROR_ICON = getIconPath({\n category: \"system\",\n name: \"error\",\n colorType: \"error\"\n});\n\n@Component({\n tag: \"gx-ide-team-dev-bring-changes\",\n styleUrl: \"bring-changes.scss\",\n shadow: true,\n assetsDirs: [\"gx-ide-assets/team-dev-bring-changes\"]\n})\nexport class GxIdeTeamDevBringChanges {\n /**\n * The component hard-coded strings translations.\n */\n // eslint-disable-next-line @stencil-community/own-props-must-be-private\n #componentLocale: any;\n #commitLabel: string;\n #comboBoxStatesModel: { caption: string; value: ObjectStateForFilter }[];\n #checkedObjectsIdsArray: string[] = [];\n\n @Element() el: HTMLGxIdeTeamDevBringChangesElement;\n\n private tabularGridEl!: HTMLChTabularGridElement;\n\n /**\n * An array that holds the id's of the objects that have been merged already.\n */\n @State() alreadyMergedObjectsIdsArray: string[] = [];\n\n /**\n * It hols a boolean indicating if at least one object from the tabular-grid is checked, for merging.\n */\n @State() atLeastOneObjectIsChecked: boolean = false;\n\n /**\n * True while commitObjects hasn't been loaded or is empty. Used to display a loader.\n */\n @State() loading: boolean = true;\n\n /**\n * It hols a boolean indicating if at least one object from the tabular-grid is checked, for merging.\n */\n @State() objectsFiltered: CommitObject[] = [];\n\n /**\n * The current search filter value\n */\n @State() searchValue: string = \"\";\n\n /**\n * The current state filter value\n */\n @State() stateFilterValue: ObjectStateForFilter = COMBO_BOX_ALL_VALUE;\n\n /**\n * A set that stores the marked state of each object cell. This is necessary because filtering the grid * causes marked cells to lose their state.\n */\n @State() markedObjectsSet: Set<string> = new Set<string>();\n\n /**\n * A map that holds the current commit objects states (\"pending\" | \"warning\" | \"error\" | \"merged\" | \"reverted\")\n */\n @State() objectsStatesMap: Map<string, ObjectState> = new Map();\n @Watch(\"objectsStatesMap\")\n objectsStatesMapChanged(newCommitObjectsStateMap: Map<string, ObjectState>) {\n const someObjectIsMerging = [...newCommitObjectsStateMap.entries()].find(\n ([, state]) => state === \"merging\" || state === \"reverting\"\n );\n\n if (!someObjectIsMerging) {\n this.merging = false;\n }\n }\n\n /**\n * A map that holds object messages, if any, for objects that could not be merged (these objects are in a \"warning\" or \"error\" state)\n */\n @State() commitObjectsMessagesMap: Map<string, string> = new Map();\n\n /**\n * Set to true when objects are being mered. This helps disabling controls until all objects are done.\n */\n @State() merging: boolean = false;\n\n /**\n * Detail about the commit\n */\n @Prop() readonly commitDetail: CommitDetail;\n\n /**\n * Commit information\n */\n @Prop() readonly commitInformation: CommitInformation[] = [];\n\n /**\n * Array of commit\n */\n @Prop() readonly commitObjects: CommitObject[] = [];\n @Watch(\"commitObjects\")\n commitObjectsChanged(newCommitObjects: CommitObject[]) {\n if (newCommitObjects.length) {\n // This is the first and only objects asignment\n this.loading = false;\n\n // All commit objects begin as \"pending to merge\"\n newCommitObjects.forEach(commitObject => {\n this.objectsStatesMap.set(\n commitObject.id,\n this.operationType === \"revert\" ? \"to-revert\" : \"to-merge\"\n );\n });\n\n this.objectsFiltered = this.commitObjects;\n }\n }\n\n /**\n * Determines whether the filters are rendered or not.\n */\n @Prop() readonly hideFilters: boolean = false;\n\n /**\n * The type of operation to perform: \"merge\" or \"revert\".\n */\n @Prop() readonly operationType: OperationType = \"merge\";\n\n /**\n * The callback that is triggered when the user wants to merge more than one commit.\n */\n @Prop() readonly mergeObjectsCallback!: MergeObjectsCallback;\n\n /**\n * If true, the \"Action\" column will display a button instead of a pill, only when the action is\n */\n @Prop() readonly revertPillAsButton: boolean = false;\n\n /**\n * Invoked when user activates the context menu on th grid.\n */\n @Prop() readonly contextMenuCallback!: ContextMenuCallback;\n\n async componentWillLoad() {\n this.#componentLocale = await Locale.getComponentStrings(this.el);\n this.#commitLabel =\n this.commitInformation.length > 1\n ? this.#componentLocale.commmits\n : this.#componentLocale.commmit;\n\n // Initiate \"states\" combo box filter\n this.#comboBoxStatesModel = [\n {\n caption: this.#componentLocale.states.all,\n value: COMBO_BOX_ALL_VALUE\n },\n {\n caption:\n this.operationType === \"revert\"\n ? this.#componentLocale.states[\"to-revert\"]\n : this.#componentLocale.states[\"to-merge\"],\n value: this.operationType === \"revert\" ? \"to-revert\" : \"to-merge\"\n },\n {\n caption: this.#componentLocale.states.warning,\n value: \"warning\"\n },\n {\n caption: this.#componentLocale.states.error,\n value: \"error\"\n },\n {\n caption:\n this.operationType === \"revert\"\n ? this.#componentLocale.states.reverted\n : this.#componentLocale.states.merged,\n value: this.operationType === \"revert\" ? \"reverted\" : \"merged\"\n }\n ];\n\n if (this.commitObjects?.length) {\n // if commitObjects already set...\n this.commitObjectsChanged(this.commitObjects);\n }\n }\n\n #formatComments = (): string => {\n if (this.commitInformation.length === 1) {\n // return comment without revison number\n return this.commitInformation[0].comment;\n }\n\n // return comments with revison number\n let mergedComment = \"\";\n this.commitInformation.map((commit, i) => {\n const isLast = i === this.commitInformation.length - 1;\n const afterCommentBreakline = isLast ? \"\" : \"\\n\\n\";\n mergedComment += `Commit ${commit.id}:\\n${commit.comment}${afterCommentBreakline}`;\n });\n\n return mergedComment;\n };\n\n #mergeCheckedClickedHandler = async () => {\n this.merging = true;\n const newobjectsStatesMap = new Map(this.objectsStatesMap);\n this.#checkedObjectsIdsArray.forEach(checkedObjectId => {\n newobjectsStatesMap.set(\n checkedObjectId,\n this.operationType === \"revert\" ? \"reverting\" : \"merging\"\n );\n });\n\n this.objectsStatesMap = newobjectsStatesMap;\n await this.mergeObjectsCallback(this.#checkedObjectsIdsArray);\n };\n\n #mergeSingleObject: (objectId: string) => () => void =\n objectId => async () => {\n this.merging = true;\n const newobjectsStatesMap = new Map(this.objectsStatesMap);\n newobjectsStatesMap.set(\n objectId,\n this.operationType === \"revert\" ? \"reverting\" : \"merging\"\n );\n this.objectsStatesMap = newobjectsStatesMap;\n await this.mergeObjectsCallback([objectId]);\n };\n\n #renderActionCellContent = (\n actionTaken: ObjectActionTaken\n ): JSX.Element[] => {\n let icon: string;\n let caption: string;\n let iconColor: string;\n\n if (actionTaken === \"Deleted\") {\n icon = SUBSTRACT_ICON;\n caption = this.#componentLocale.objects.actions.delete;\n iconColor = \"--mer-icon__error\";\n } else if (actionTaken === \"Inserted\") {\n icon = ADD_ICON;\n caption = this.#componentLocale.objects.actions.insert;\n iconColor = \"--mer-icon__success\";\n } else {\n // modified\n icon = EDITED_ICON;\n caption = this.#componentLocale.objects.actions.modify;\n iconColor = \"--mer-icon__warning\";\n }\n\n return (\n <span class=\"custom-icon-text-wrapper\">\n <ch-image\n type=\"mask\"\n class=\"icon-md\"\n src={icon}\n style={{ backgroundColor: `var(${iconColor})` }}\n ></ch-image>\n {`${caption}`}\n </span>\n );\n };\n\n #renderCommitsNumbers = (onlyNumbers: boolean = false): string => {\n if (this.commitInformation?.length > 1) {\n // more than one commit\n return onlyNumbers\n ? `${this.commitInformation[0].id} ... ${\n this.commitInformation[this.commitInformation.length - 1].id\n }`\n : `${this.#commitLabel} ${this.commitInformation[0].id} ... ${\n this.commitInformation[this.commitInformation.length - 1].id\n }`;\n } else if (this.commitInformation?.length === 1) {\n // just one commit\n return onlyNumbers\n ? this.commitInformation[0].id\n : `${this.#commitLabel} ${this.commitInformation[0].id}`;\n } else {\n // Probably commits have not been loaded yet (loading state)\n return onlyNumbers\n ? `${this.#componentLocale.loading}`\n : `${this.#commitLabel} ${this.#componentLocale.loading}`;\n }\n };\n\n #renderFormatedDate = (date: Date): string => {\n const dateObject = new Date(date);\n const lang = navigator.languages?.[0] || navigator.language;\n\n return `${dateObject.toLocaleDateString(\n lang\n )} ${dateObject.toLocaleTimeString(lang, {\n hour: \"2-digit\",\n minute: \"2-digit\",\n hour12: false\n })}`;\n };\n\n #renderObjectStateWithIcon = (\n objectType: ObjectState,\n objectId: string\n ): JSX.Element[] => {\n if (objectType === \"merging\" || objectType === \"reverting\") {\n return (\n <span class=\"merging-spinner-caption\">\n {this.operationType === \"revert\"\n ? this.#componentLocale.states.reverting\n : this.#componentLocale.states.merging}\n </span>\n );\n }\n const classes = `pill pill--${objectType}`;\n if (\n this.revertPillAsButton &&\n (objectType === \"to-merge\" ||\n objectType === \"to-merge-marked\" ||\n objectType === \"to-revert\")\n ) {\n return (\n <button\n class={{ [classes]: true, \"button-secondary\": true }}\n onClick={this.#mergeSingleObject(objectId)}\n >\n {this.#componentLocale.statesForButton[objectType]}\n </button>\n );\n } else {\n return (\n <span class={classes}>{this.#componentLocale.states[objectType]}</span>\n );\n }\n };\n\n #renderObjectsRows = (): JSX.Element[] => {\n return this.objectsFiltered.map(commitObject => {\n const marked = this.markedObjectsSet.has(commitObject.id);\n\n const alreadyMerged = this.alreadyMergedObjectsIdsArray.find(\n checkedObjectId => checkedObjectId === commitObject.id\n );\n const errorOrWarningMessage = this.commitObjectsMessagesMap.get(\n commitObject.id\n );\n const state = this.objectsStatesMap.get(commitObject.id);\n\n let MESSAGE_ICON;\n if (state === \"error\") {\n MESSAGE_ICON = ERROR_ICON;\n } else if (state === \"warning\") {\n MESSAGE_ICON = WARNING_ICON;\n }\n\n return (\n <ch-tabular-grid-row\n class=\"tabular-grid-row\"\n key={commitObject.id}\n rowid={commitObject.id}\n ref={(el: HTMLElement) =>\n marked && el?.setAttribute(\"marked\", \"true\")\n }\n >\n <ch-tabular-grid-cell\n cell-type=\"rich\"\n row-selector=\"true\"\n class={{\n \"tabular-grid-cell\": true,\n \"no-checkbox-custom-selector\": alreadyMerged\n }}\n size=\"max-content\"\n >\n {commitObject.name}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {renderObjectTypeWithIcon(commitObject.type)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {commitObject.description}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {this.#renderActionCellContent(commitObject.actionTaken)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell tabular-grid-cell--for-pill\">\n {this.#renderObjectStateWithIcon(\n this.objectsStatesMap.get(commitObject.id),\n commitObject.id\n )}\n </ch-tabular-grid-cell>\n {errorOrWarningMessage && (\n <ch-tabular-grid-rowset class=\"tabular-grid-rowset\">\n <ch-tabular-grid-rowset-empty\n class={{ \"tabular-grid-rowset-empty\": true, [state]: true }}\n >\n <p class=\"warning-error-description\">\n <ch-image\n class=\"icon-md warning-error-icon\"\n src={MESSAGE_ICON}\n ></ch-image>\n {errorOrWarningMessage}\n </p>\n </ch-tabular-grid-rowset-empty>\n </ch-tabular-grid-rowset>\n )}\n </ch-tabular-grid-row>\n );\n });\n };\n\n #rowContextMenuHandler = async (\n ev: CustomEvent<TabularGridRowContextMenuEvent>\n ) => {\n ev.preventDefault();\n const selectedRowsIds = await this.tabularGridEl.getSelectedRows();\n\n await this.contextMenuCallback({\n selection: selectedRowsIds,\n clientX: ev.detail.clientX,\n clientY: ev.detail.clientY\n });\n };\n\n #rowMarkingChangedHandler = (\n event: CustomEvent<TabularGridMarkingChangedEvent>\n ) => {\n const newobjectsMarkedSet = new Set<string>();\n const newobjectsStatesMap = new Map(this.objectsStatesMap);\n const markedRowsIds = event.detail.rowsId;\n const checkedObjectsIgnoringAlreadyMerged = markedRowsIds.filter(\n markedObjectId =>\n !this.alreadyMergedObjectsIdsArray.includes(markedObjectId)\n );\n this.#checkedObjectsIdsArray = [...checkedObjectsIgnoringAlreadyMerged];\n\n // Update markedObjectsSet\n this.#checkedObjectsIdsArray.forEach(checkedObjectId => {\n newobjectsMarkedSet.add(checkedObjectId);\n });\n this.markedObjectsSet = newobjectsMarkedSet;\n\n this.atLeastOneObjectIsChecked = markedRowsIds.length > 0;\n\n newobjectsStatesMap.forEach(objectId => {\n const objectCurrentState = this.objectsStatesMap.get(objectId);\n if (\n objectCurrentState !== \"to-merge\" &&\n objectCurrentState !== \"to-merge-marked\"\n ) {\n return;\n }\n\n const markedRowIndex = markedRowsIds.findIndex(id => id === objectId);\n if (markedRowIndex !== -1) {\n newobjectsStatesMap.set(objectId, \"to-merge-marked\");\n markedRowsIds.splice(markedRowIndex, 1);\n markedRowsIds;\n } else {\n newobjectsStatesMap.set(objectId, \"to-merge\");\n }\n });\n\n this.objectsStatesMap = newobjectsStatesMap;\n };\n\n #searchInputHandler = (event: ChEditCustomEvent<string> | InputEvent) => {\n this.searchValue = (event.detail as string).toLowerCase();\n this.#updateFilteredObjects();\n };\n\n #stateChangedHandler = (event: CustomEvent<string> | InputEvent) => {\n this.stateFilterValue = event.detail as ObjectStateForFilter;\n this.#updateFilteredObjects();\n };\n\n #updateFilteredObjects = () => {\n let filteredObjects = [...this.commitObjects];\n\n // filter by state (ch-combo-box-render) ...\n if (this.stateFilterValue !== \"all\") {\n filteredObjects = filteredObjects.filter(object => {\n const objectState = this.objectsStatesMap.get(object.id);\n return objectState === this.stateFilterValue;\n });\n }\n\n // and filter by value (ch-edit) as well\n filteredObjects = filteredObjects.filter(object => {\n const includesName = object.name.toLowerCase().includes(this.searchValue);\n\n const includesType = object.type.name\n .toLowerCase()\n .includes(this.searchValue);\n\n const includesDescription = object.description\n .toLowerCase()\n .includes(this.searchValue);\n\n if (includesName || includesType || includesDescription) {\n return true;\n }\n return false;\n });\n\n this.objectsFiltered = filteredObjects;\n };\n\n /**\n * It allows the host updating an object state, by providing the object id.\n * @param objectId The ID of the object to update.\n * @param newState The new state to set on the object.\n * @param message Optional message explaining the change.\n *\n * @example\n * bringChanges.updateObjectState('obj-24', \"merging\", null);\n * bringChanges.updateObjectState('obj-27', \"error\", \"The server did not respond.\");\n */\n @Method()\n async updateObjectState(\n objectId: string,\n newState: ObjectState,\n message: string\n ) {\n // update object state\n const newobjectsStatesMap = new Map(this.objectsStatesMap);\n newobjectsStatesMap.set(objectId, newState);\n this.objectsStatesMap = newobjectsStatesMap;\n\n // add message if state is \"warning\" or \"error\"\n if (message?.length > 0) {\n this.commitObjectsMessagesMap.set(objectId, message);\n }\n\n if (newState === \"merged\" || newState === \"reverted\") {\n // remove from checked\n this.#checkedObjectsIdsArray = this.#checkedObjectsIdsArray.filter(\n checkedObject => checkedObject !== objectId\n );\n\n // add to \"already merged\". This will hide the checkbox\n this.alreadyMergedObjectsIdsArray.push(objectId);\n\n // unmark checkbox:\n this.tabularGridEl.markRow(objectId, false);\n\n // remove message if any\n this.commitObjectsMessagesMap.delete(objectId);\n }\n }\n\n #sortTabularGridColumnCallback = (\n e: CustomEvent<TabularGridColumnSortChangedEvent>\n ) => {\n const columnId = e.detail.columnId;\n\n let objectProperty;\n let dateType: SortTabularGridColumnDataType = \"string\";\n if (columnId === COLUMNS_IDS.type) {\n objectProperty = \"name\"; // the type name\n dateType = \"object\";\n }\n\n this.objectsFiltered = [\n ...sortTabularGridColumn(\n e,\n this.objectsFiltered,\n dateType,\n objectProperty\n )\n ];\n };\n\n render() {\n const enableRichRowSelector =\n this.alreadyMergedObjectsIdsArray.length !== this.commitObjects.length;\n\n const disableControls = this.merging || this.loading;\n return (\n <Host class=\"widget\">\n <ch-theme model={CSS_BUNDLES}></ch-theme>\n <section class=\"section\">\n <header class=\"header spacing-body-inline spacing-body-block-start\">\n <div\n // header details\n class=\"header__detail\"\n >\n <p class=\"detail__title subtitle-semi-bold-xs\">\n {this.operationType === \"revert\"\n ? this.#componentLocale.commitDetail.revertChangesDetail\n : this.#componentLocale.commitDetail.bringChangesDetail}\n </p>\n <p class=\"detail__commit-name subtitle-semi-bold-s\">\n {this.#renderCommitsNumbers()}\n </p>\n <div\n // genexus server\n class=\"detail__genexus-server field field-block\"\n >\n <span class={DETAIL_LABEL_CLASSES}>\n {this.#componentLocale.commitDetail.genexusServer}\n </span>\n <a\n class=\"detail__link body-regular-s\"\n href={this.commitDetail.genexusServer}\n target=\"_blank\"\n >\n {this.commitDetail.genexusServer}\n </a>\n </div>\n\n <div\n // knowledge base\n class=\"detail__knowledge-base field field-block\"\n >\n <span class={DETAIL_LABEL_CLASSES}>\n {this.#componentLocale.commitDetail.knowledgeBase}\n </span>\n <p class=\"body-regular-s\">{this.commitDetail.knowledgeBase}</p>\n </div>\n\n <div\n // current version\n class=\"detail__current-version field field-block\"\n >\n <span class={DETAIL_LABEL_CLASSES}>\n {this.#componentLocale.commitDetail.currentVersion}\n </span>\n <a class=\"body-regular-s\">{this.commitDetail.currentVersion}</a>\n </div>\n {this.operationType === \"merge\" && (\n <div\n // merge from version\n class=\"detail__merge-from-version field field-block\"\n >\n <span class={DETAIL_LABEL_CLASSES}>\n {this.#componentLocale.commitDetail.mergeFromVersion}\n </span>\n <p class=\"body-regular-s\">\n {this.commitDetail.mergeFromVersion}\n </p>\n </div>\n )}\n </div>\n <div\n // header information\n class=\"header__information\"\n >\n <p class=\"information__title subtitle-semi-bold-xs\">\n {this.#componentLocale.commitInformation.title}\n </p>\n <div\n // header information (col-1)\n class=\"information__col-1\"\n >\n <div\n // IDs\n class=\"field field-block\"\n >\n <span class={DETAIL_LABEL_CLASSES}>\n {this.commitInformation.length === 1\n ? this.#componentLocale.commitInformation.id\n : this.#componentLocale.commitInformation.ids}\n </span>\n <p class=\"body-regular-s\">\n {this.#renderCommitsNumbers(true)}\n </p>\n </div>\n {this.commitInformation.length === 1 ? (\n <div class=\"field field-block\">\n <span class={DETAIL_LABEL_CLASSES}>\n {this.#componentLocale.commitInformation.date}\n </span>\n <p class=\"body-regular-s\">\n {this.#renderFormatedDate(this.commitInformation[0].date)}\n </p>\n </div>\n ) : (\n [\n <div class=\"field field-block\">\n <span class={DETAIL_LABEL_CLASSES}>\n {this.#componentLocale.commitInformation.from}\n </span>\n <p class=\"body-regular-s\">\n {this.#renderFormatedDate(\n this.commitInformation[0].date\n )}\n </p>\n </div>,\n <div class=\"field field-block\">\n <span class={DETAIL_LABEL_CLASSES}>\n {this.#componentLocale.commitInformation.to}\n </span>\n <p class=\"body-regular-s\">\n {this.#renderFormatedDate(\n this.commitInformation[\n this.commitInformation.length - 1\n ].date\n )}\n </p>\n </div>\n ]\n )}\n </div>\n\n <div\n // header information (col-2)\n class=\"information__col-2\"\n >\n <div\n // To\n class=\"field field-block\"\n >\n <label class={DETAIL_LABEL_CLASSES} htmlFor=\"commit-comments\">\n {this.commitInformation.length > 1\n ? this.#componentLocale.commitInformation.comments\n : this.#componentLocale.commitInformation.comment}\n </label>\n <div class=\"input-comments-container\">\n <ch-edit\n id=\"commit-comments\"\n class=\"input scrollable input-comments body-regular-s\"\n type=\"text\"\n multiline\n readonly\n value={this.#formatComments()}\n ></ch-edit>\n </div>\n </div>\n </div>\n </div>\n </header>\n <div\n class={{\n \"controls-container\": true,\n \"filter\": !this.hideFilters,\n \"spacing-body-inline\": true\n }}\n >\n {!this.hideFilters && [\n <ch-edit\n class=\"input\"\n disabled={disableControls}\n startImgSrc={SEARCH_ICON}\n placeholder={this.#componentLocale.filter.searchPlaceholder}\n type=\"search\"\n onInput={this.#searchInputHandler}\n ></ch-edit>,\n <ch-combo-box-render\n class=\"combo-box\"\n disabled={disableControls}\n model={this.#comboBoxStatesModel}\n value={this.stateFilterValue}\n onInput={this.#stateChangedHandler}\n placeholder={this.#componentLocale.filter.statePlaceholder}\n ></ch-combo-box-render>\n ]}\n\n <button\n class=\"button-primary button-merge-checked\"\n disabled={!this.atLeastOneObjectIsChecked || disableControls}\n onClick={this.#mergeCheckedClickedHandler}\n >\n {this.operationType === \"revert\"\n ? this.#componentLocale.filter.revertSelected\n : this.#componentLocale.filter.mergeSelected}\n </button>\n </div>\n <div class=\"main spacing-body\">\n {this.commitObjects.length ? (\n <ch-tabular-grid\n class={{\n \"tabular-grid\": true,\n \"objects-tabular-grid\": true,\n \"disabled-custom-selector\": this.merging,\n \"empty-result\": this.objectsFiltered.length === 0\n }}\n keyboardNavigationMode=\"focus\"\n rowSelectionMode=\"multiple\"\n onRowMarkingChanged={this.#rowMarkingChangedHandler}\n onRowContextMenu={this.#rowContextMenuHandler}\n ref={(el: HTMLChTabularGridElement) =>\n (this.tabularGridEl = el as HTMLChTabularGridElement)\n }\n >\n <ch-tabular-grid-columnset class=\"tabular-grid-column-set\">\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.name}\n columnName={this.#componentLocale.objects.name}\n columnType=\"rich\"\n richRowSelector={enableRichRowSelector}\n richRowSelectorMode=\"mark\"\n settingable={false}\n sortable={true}\n onColumnSortChanged={this.#sortTabularGridColumnCallback}\n size=\"max-content\"\n />\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.type}\n columnName={this.#componentLocale.objects.type}\n settingable={false}\n sortable={true}\n onColumnSortChanged={this.#sortTabularGridColumnCallback}\n size=\"max-content\"\n />\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.description}\n columnName={this.#componentLocale.objects.description}\n settingable={false}\n sortable={true}\n onColumnSortChanged={this.#sortTabularGridColumnCallback}\n size={config.tabularGrid.colSize.description}\n />\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.action}\n columnName={this.#componentLocale.objects.action}\n settingable={false}\n sortable={false}\n size=\"max-content\"\n />\n <ch-tabular-grid-column\n // size of this column should the enough for the largest pill, and no more.\n // this prevents layout shifts when pills state changes.\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.status}\n columnName={this.#componentLocale.objects.status}\n settingable={false}\n sortable={false}\n size=\"100px\"\n />\n </ch-tabular-grid-columnset>\n {this.#renderObjectsRows()}\n\n <ch-tabular-grid-rowset class=\"tabular-grid-rowset\">\n {this.objectsFiltered.length === 0 && (\n <ch-tabular-grid-rowset-empty>\n <gx-ide-empty-state\n class=\"empty-state\"\n isAnimated\n stateIconSrc={FILTER_ICON}\n stateTitle=\"No object matched your filter\"\n ></gx-ide-empty-state>\n </ch-tabular-grid-rowset-empty>\n )}\n </ch-tabular-grid-rowset>\n </ch-tabular-grid>\n ) : (\n <gx-ide-loader\n cancelLabel={this.#componentLocale.loader.cancelLabel}\n loaderTitle={this.#componentLocale.loader.title}\n description={this.#componentLocale.loader.description}\n show\n class=\"loader\"\n ></gx-ide-loader>\n )}\n </div>\n </section>\n </Host>\n );\n }\n}\n\nexport type OperationType = \"merge\" | \"revert\";\n\nexport type CommitDetail = {\n genexusServer: string;\n knowledgeBase: string;\n currentVersion: string;\n mergeFromVersion: string;\n};\n\nexport type CommitInformation = {\n id: string;\n comment: string;\n date: Date;\n};\n\nexport type CommitObject = {\n id: string;\n date: Date;\n name: string;\n type: ObjectType;\n description: string;\n actionTaken: ObjectActionTaken;\n};\n\nexport type ObjectActionTaken =\n | \"Inserted\"\n | \"Deleted\"\n | \"Modified\"\n | \"Unchanged\"\n | \"Unknown\";\n\nexport type ObjectState =\n | \"to-merge\"\n | \"to-merge-marked\"\n | \"to-revert\"\n | \"merging\"\n | \"pending\"\n | \"warning\"\n | \"error\"\n | \"merged\"\n | \"reverted\"\n | \"reverting\";\n\ntype ObjectStateForFilter =\n | Extract<\n ObjectState,\n \"to-merge\" | \"to-revert\" | \"warning\" | \"error\" | \"merged\" | \"reverted\"\n >\n | \"all\";\n\nexport type MergeObjectsCallback = (objectsIds: string[]) => Promise<void>;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,314 @@
|
|
|
1
|
+
import { h as e } from "./p-97107ecc.js";
|
|
2
|
+
|
|
3
|
+
import { g as l } from "./p-401bfc97.js";
|
|
4
|
+
|
|
5
|
+
import { r as a } from "./p-a24571ca.js";
|
|
6
|
+
|
|
7
|
+
import { f as r } from "./p-8c15538c.js";
|
|
8
|
+
|
|
9
|
+
import { h as t } from "./p-edcd0022.js";
|
|
10
|
+
|
|
11
|
+
import { c as o } from "./p-9a03ac9f.js";
|
|
12
|
+
|
|
13
|
+
const s = "All";
|
|
14
|
+
|
|
15
|
+
const c = {
|
|
16
|
+
HEADER: "header spacing-body-inline spacing-body-block-start field-group",
|
|
17
|
+
HEADER_DETAILS: "header__details",
|
|
18
|
+
FILTER: "filter",
|
|
19
|
+
MAIN: "main spacing-body",
|
|
20
|
+
GRID_CELL_DESCRIPTION: "tabular-grid-cell-description-custom-selector"
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
const n = {
|
|
24
|
+
add: l({
|
|
25
|
+
category: "system",
|
|
26
|
+
name: "add",
|
|
27
|
+
colorType: "on-elevation"
|
|
28
|
+
}),
|
|
29
|
+
edit: l({
|
|
30
|
+
category: "system",
|
|
31
|
+
name: "edit",
|
|
32
|
+
colorType: "on-elevation"
|
|
33
|
+
}),
|
|
34
|
+
error: l({
|
|
35
|
+
category: "system",
|
|
36
|
+
name: "error",
|
|
37
|
+
colorType: "error"
|
|
38
|
+
}),
|
|
39
|
+
filter: l({
|
|
40
|
+
category: "window-tools",
|
|
41
|
+
name: "filter",
|
|
42
|
+
colorType: "neutral"
|
|
43
|
+
}),
|
|
44
|
+
filterWithConditions: l({
|
|
45
|
+
category: "window-tools",
|
|
46
|
+
name: "filter-conditions",
|
|
47
|
+
colorType: "neutral"
|
|
48
|
+
}),
|
|
49
|
+
info: l({
|
|
50
|
+
category: "system",
|
|
51
|
+
name: "information",
|
|
52
|
+
colorType: "on-elevation"
|
|
53
|
+
}),
|
|
54
|
+
refresh: l({
|
|
55
|
+
category: "gemini-tools",
|
|
56
|
+
name: "reset",
|
|
57
|
+
colorType: "neutral"
|
|
58
|
+
}),
|
|
59
|
+
search: l({
|
|
60
|
+
category: "system",
|
|
61
|
+
name: "search",
|
|
62
|
+
colorType: "on-elevation"
|
|
63
|
+
}),
|
|
64
|
+
success: l({
|
|
65
|
+
category: "system",
|
|
66
|
+
name: "check",
|
|
67
|
+
colorType: "success"
|
|
68
|
+
}),
|
|
69
|
+
substract: l({
|
|
70
|
+
category: "system",
|
|
71
|
+
name: "substract",
|
|
72
|
+
colorType: "on-elevation"
|
|
73
|
+
}),
|
|
74
|
+
warning: l({
|
|
75
|
+
category: "system",
|
|
76
|
+
name: "warning",
|
|
77
|
+
colorType: "warning"
|
|
78
|
+
})
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
// stencil
|
|
82
|
+
const i = "button-action-custom-selector";
|
|
83
|
+
|
|
84
|
+
const u = {
|
|
85
|
+
action: "action",
|
|
86
|
+
description: "description",
|
|
87
|
+
lastSynchronized: "lastSynchronized",
|
|
88
|
+
localState: "localState",
|
|
89
|
+
modifiedOn: "modifiedOn",
|
|
90
|
+
module: "module",
|
|
91
|
+
name: "name",
|
|
92
|
+
status: "status",
|
|
93
|
+
type: "type"
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
const renderStateCellContent = (l, a) => {
|
|
97
|
+
let r;
|
|
98
|
+
let t;
|
|
99
|
+
let o;
|
|
100
|
+
if (l === "deleted") {
|
|
101
|
+
r = n.substract;
|
|
102
|
+
t = a.states.deleted;
|
|
103
|
+
o = "--mer-icon__error";
|
|
104
|
+
} else if (l === "inserted") {
|
|
105
|
+
r = n.add;
|
|
106
|
+
t = a.states.inserted;
|
|
107
|
+
o = "--mer-icon__success";
|
|
108
|
+
} else if (l === "modified") {
|
|
109
|
+
r = n.edit;
|
|
110
|
+
t = a.states.modified;
|
|
111
|
+
o = "--mer-icon__warning";
|
|
112
|
+
} else if (l === "conflicted") {
|
|
113
|
+
r = n.warning;
|
|
114
|
+
t = a.states.conflicted;
|
|
115
|
+
o = "--mer-icon__warning";
|
|
116
|
+
} else if (!l) {
|
|
117
|
+
// proably is "ignored"
|
|
118
|
+
return null;
|
|
119
|
+
}
|
|
120
|
+
return e("span", {
|
|
121
|
+
class: "custom-icon-text-wrapper"
|
|
122
|
+
}, e("ch-image", {
|
|
123
|
+
type: "mask",
|
|
124
|
+
class: "icon-md",
|
|
125
|
+
src: r,
|
|
126
|
+
style: {
|
|
127
|
+
backgroundColor: `var(${o})`
|
|
128
|
+
}
|
|
129
|
+
}), `${t}`);
|
|
130
|
+
};
|
|
131
|
+
|
|
132
|
+
const renderObjectStatus = (l, a, r, t, o) => {
|
|
133
|
+
const s = a.get(l);
|
|
134
|
+
const c = s === "pending" && r ? o.status.commit : o.status[s];
|
|
135
|
+
if (s === "commiting") {
|
|
136
|
+
return e("span", {
|
|
137
|
+
class: "spinner-caption"
|
|
138
|
+
}, c);
|
|
139
|
+
}
|
|
140
|
+
const n = `pill pill--${s}`;
|
|
141
|
+
if (r && s === "pending") {
|
|
142
|
+
return e("button", {
|
|
143
|
+
class: {
|
|
144
|
+
"button-secondary": true,
|
|
145
|
+
"button-icon-and-text": true,
|
|
146
|
+
pill: true,
|
|
147
|
+
"pill--update": true,
|
|
148
|
+
[i]: true
|
|
149
|
+
},
|
|
150
|
+
onClick: t(l)
|
|
151
|
+
}, c);
|
|
152
|
+
} else {
|
|
153
|
+
return e("span", {
|
|
154
|
+
class: n
|
|
155
|
+
}, c);
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
const renderTabularGridRows = (l, o, s, i, u, d, m, g, b, p, f) => {
|
|
160
|
+
let y;
|
|
161
|
+
if (l === "pending") {
|
|
162
|
+
y = o;
|
|
163
|
+
} else if (l === "ignored") {
|
|
164
|
+
y = s;
|
|
165
|
+
}
|
|
166
|
+
p = p.toLowerCase();
|
|
167
|
+
const h = y.map((o => {
|
|
168
|
+
const s = i.has(o.id);
|
|
169
|
+
const y = s || l === "ignored";
|
|
170
|
+
const h = u.has(o.id);
|
|
171
|
+
const w = d.get(o.id);
|
|
172
|
+
return e("ch-tabular-grid-row", {
|
|
173
|
+
class: "tabular-grid-row",
|
|
174
|
+
key: o.id,
|
|
175
|
+
rowid: o.id,
|
|
176
|
+
ref: e => h && (e === null || e === void 0 ? void 0 : e.setAttribute("marked", "true"))
|
|
177
|
+
}, e("ch-tabular-grid-cell", {
|
|
178
|
+
"cell-type": "rich",
|
|
179
|
+
"row-selector": "true",
|
|
180
|
+
class: {
|
|
181
|
+
"tabular-grid-cell": true,
|
|
182
|
+
"no-checkbox-custom-selector": y
|
|
183
|
+
},
|
|
184
|
+
size: "max-content"
|
|
185
|
+
}, e("div", null, t(o.name, p))), e("ch-tabular-grid-cell", {
|
|
186
|
+
class: "tabular-grid-cell"
|
|
187
|
+
}, a(o.type)), e("ch-tabular-grid-cell", {
|
|
188
|
+
class: {
|
|
189
|
+
"tabular-grid-cell": true,
|
|
190
|
+
[c.GRID_CELL_DESCRIPTION]: true
|
|
191
|
+
}
|
|
192
|
+
}, e("div", null, t(o.description, p))), e("ch-tabular-grid-cell", {
|
|
193
|
+
class: "tabular-grid-cell"
|
|
194
|
+
}, r(o.modifiedOn)), e("ch-tabular-grid-cell", {
|
|
195
|
+
class: "tabular-grid-cell"
|
|
196
|
+
}, o.module), e("ch-tabular-grid-cell", {
|
|
197
|
+
class: "tabular-grid-cell"
|
|
198
|
+
}, renderStateCellContent(o.state, f)), e("ch-tabular-grid-cell", {
|
|
199
|
+
class: "tabular-grid-cell"
|
|
200
|
+
}, r(o.lastSynchronized)), e("ch-tabular-grid-cell", {
|
|
201
|
+
class: "tabular-grid-cell tabular-grid-cell--for-pill"
|
|
202
|
+
}, renderObjectStatus(o.id, b, m, g, f)), (w === null || w === void 0 ? void 0 : w.length) && e("ch-tabular-grid-rowset", {
|
|
203
|
+
class: "tabular-grid-rowset"
|
|
204
|
+
}, e("ch-tabular-grid-rowset-empty", {
|
|
205
|
+
class: {
|
|
206
|
+
"tabular-grid-rowset-empty": true
|
|
207
|
+
}
|
|
208
|
+
}, e("ul", {
|
|
209
|
+
class: "messages-list"
|
|
210
|
+
}, w.map((l => {
|
|
211
|
+
let a;
|
|
212
|
+
if (l.type === "error") {
|
|
213
|
+
a = n.error;
|
|
214
|
+
} else if (l.type === "warning") {
|
|
215
|
+
a = n.warning;
|
|
216
|
+
} else if (l.type === "success") {
|
|
217
|
+
a = n.success;
|
|
218
|
+
} else {
|
|
219
|
+
// info
|
|
220
|
+
a = n.info;
|
|
221
|
+
}
|
|
222
|
+
return e("li", {
|
|
223
|
+
class: "message-description"
|
|
224
|
+
}, e("ch-image", {
|
|
225
|
+
class: "icon-md message-icon",
|
|
226
|
+
src: a
|
|
227
|
+
}), l.text);
|
|
228
|
+
}))))));
|
|
229
|
+
}));
|
|
230
|
+
return h;
|
|
231
|
+
};
|
|
232
|
+
|
|
233
|
+
const renderTabularGridColumns = (l, a = false, r, t, s, c) => {
|
|
234
|
+
const n = a ? o.tabularGrid.colSize.auto : o.tabularGrid.colSize.maxContent;
|
|
235
|
+
return e("ch-tabular-grid-columnset", {
|
|
236
|
+
class: "tabular-grid-column-set"
|
|
237
|
+
}, !l.includes("name") && e("ch-tabular-grid-column", {
|
|
238
|
+
class: "tabular-grid-column",
|
|
239
|
+
columnId: u.name,
|
|
240
|
+
columnName: s.objects.name,
|
|
241
|
+
columnType: "rich",
|
|
242
|
+
richRowSelector: c,
|
|
243
|
+
richRowSelectorMode: "mark",
|
|
244
|
+
settingable: false,
|
|
245
|
+
sortable: true,
|
|
246
|
+
onColumnSortChanged: r,
|
|
247
|
+
onColumnSelectorClicked: t,
|
|
248
|
+
size: n
|
|
249
|
+
}), !l.includes("type") && e("ch-tabular-grid-column", {
|
|
250
|
+
class: "tabular-grid-column",
|
|
251
|
+
columnId: u.type,
|
|
252
|
+
columnName: s.objects.type,
|
|
253
|
+
settingable: false,
|
|
254
|
+
sortable: true,
|
|
255
|
+
onColumnSortChanged: r,
|
|
256
|
+
size: n
|
|
257
|
+
}), !l.includes("description") && e("ch-tabular-grid-column", {
|
|
258
|
+
class: "tabular-grid-column",
|
|
259
|
+
columnId: u.description,
|
|
260
|
+
columnName: s.objects.description,
|
|
261
|
+
settingable: false,
|
|
262
|
+
sortable: true,
|
|
263
|
+
onColumnSortChanged: r,
|
|
264
|
+
size: o.tabularGrid.colSize.description
|
|
265
|
+
}), !l.includes("modifiedOn") && e("ch-tabular-grid-column", {
|
|
266
|
+
class: "tabular-grid-column",
|
|
267
|
+
columnId: u.modifiedOn,
|
|
268
|
+
columnName: s.objects.modifiedOn,
|
|
269
|
+
sortable: true,
|
|
270
|
+
onColumnSortChanged: r,
|
|
271
|
+
settingable: false,
|
|
272
|
+
size: n
|
|
273
|
+
}), !l.includes("module") && e("ch-tabular-grid-column", {
|
|
274
|
+
class: "tabular-grid-column",
|
|
275
|
+
columnId: u.module,
|
|
276
|
+
columnName: s.objects.module,
|
|
277
|
+
sortable: true,
|
|
278
|
+
onColumnSortChanged: r,
|
|
279
|
+
settingable: false,
|
|
280
|
+
size: n
|
|
281
|
+
}), !l.includes("localState") && e("ch-tabular-grid-column", {
|
|
282
|
+
class: "tabular-grid-column",
|
|
283
|
+
columnId: u.localState,
|
|
284
|
+
columnName: s.objects.localState,
|
|
285
|
+
sortable: false,
|
|
286
|
+
settingable: false,
|
|
287
|
+
size: n
|
|
288
|
+
}), !l.includes("lastSynchronized") && e("ch-tabular-grid-column", {
|
|
289
|
+
class: "tabular-grid-column",
|
|
290
|
+
columnId: u.lastSynchronized,
|
|
291
|
+
columnName: s.objects.lastSynchronized,
|
|
292
|
+
settingable: false,
|
|
293
|
+
sortable: true,
|
|
294
|
+
onColumnSortChanged: r,
|
|
295
|
+
size: n
|
|
296
|
+
}), !l.includes("action") && e("ch-tabular-grid-column", {
|
|
297
|
+
class: "tabular-grid-column",
|
|
298
|
+
columnId: u.action,
|
|
299
|
+
columnName: s.objects.action,
|
|
300
|
+
sortable: false,
|
|
301
|
+
settingable: false,
|
|
302
|
+
size: n
|
|
303
|
+
}), !l.includes("status") && e("ch-tabular-grid-column", {
|
|
304
|
+
class: "tabular-grid-column",
|
|
305
|
+
columnId: u.status,
|
|
306
|
+
columnName: s.objects.status,
|
|
307
|
+
sortable: false,
|
|
308
|
+
settingable: false,
|
|
309
|
+
size: a ? "auto" : "100px"
|
|
310
|
+
}));
|
|
311
|
+
};
|
|
312
|
+
|
|
313
|
+
export { s as A, u as C, n as I, c as a, renderTabularGridRows as b, renderTabularGridColumns as r };
|
|
314
|
+
//# sourceMappingURL=p-77c2e69d.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["ALL_VALUE","CSS_SELECTORS","HEADER","HEADER_DETAILS","FILTER","MAIN","GRID_CELL_DESCRIPTION","ICONS","add","getIconPath","category","name","colorType","edit","error","filter","filterWithConditions","info","refresh","search","success","substract","warning","BUTTON_ACTION_SELECTOR","COLUMNS_IDS","action","description","lastSynchronized","localState","modifiedOn","module","status","type","renderStateCellContent","componentLocale","icon","caption","iconColor","states","deleted","inserted","modified","conflicted","h","class","src","style","backgroundColor","renderObjectStatus","objectId","objectsStatusMap","updatePillAsButton","commitSingleObject","get","commit","classes","pill","onClick","renderTabularGridRows","pendingObjectsAfterFilter","ignoredObjectsAfterFilter","alreadyUpdatedObjectsIdsSet","markedObjectsSet","objectsMessagesDataMap","searchValue","objects","toLowerCase","filteredRows","map","object","alreadyUpdated","has","id","hideCheckbox","marked","messages","key","rowid","ref","el","setAttribute","size","hiChar","renderObjectTypeWithIcon","CLASSES","formatDate","state","length","message","MESSAGE_ICON","text","renderTabularGridColumns","ignoredGridColumns","gridIsEmpty","sortTabularGridColumnCallback","columnSelectorClickedCallback","showRichRowSelector","colSize","config","tabularGrid","auto","maxContent","includes","columnId","columnName","columnType","richRowSelector","richRowSelectorMode","settingable","sortable","onColumnSortChanged","onColumnSelectorClicked"],"sources":["src/components/team-dev/version-control/common/constants.ts","src/components/team-dev/version-control/common/tabular-grid-render.tsx"],"sourcesContent":["import { getIconPath } from \"@genexus/mercury\";\n\nexport const ALL_VALUE = \"All\";\nexport const ALL_MODULES = \"All Modules\";\nexport const ALL_TYPES = \"All Types\";\n\nexport const CSS_SELECTORS = {\n HEADER: \"header spacing-body-inline spacing-body-block-start field-group\",\n HEADER_DETAILS: \"header__details\",\n FILTER: \"filter\",\n MAIN: \"main spacing-body\",\n GRID_CELL_DESCRIPTION: \"tabular-grid-cell-description-custom-selector\"\n};\n\nconst ICONS = {\n add: getIconPath({\n category: \"system\",\n name: \"add\",\n colorType: \"on-elevation\"\n }),\n edit: getIconPath({\n category: \"system\",\n name: \"edit\",\n colorType: \"on-elevation\"\n }),\n error: getIconPath({\n category: \"system\",\n name: \"error\",\n colorType: \"error\"\n }),\n filter: getIconPath({\n category: \"window-tools\",\n name: \"filter\",\n colorType: \"neutral\"\n }),\n filterWithConditions: getIconPath({\n category: \"window-tools\",\n name: \"filter-conditions\",\n colorType: \"neutral\"\n }),\n info: getIconPath({\n category: \"system\",\n name: \"information\",\n colorType: \"on-elevation\"\n }),\n refresh: getIconPath({\n category: \"gemini-tools\",\n name: \"reset\",\n colorType: \"neutral\"\n }),\n search: getIconPath({\n category: \"system\",\n name: \"search\",\n colorType: \"on-elevation\"\n }),\n success: getIconPath({\n category: \"system\",\n name: \"check\",\n colorType: \"success\"\n }),\n substract: getIconPath({\n category: \"system\",\n name: \"substract\",\n colorType: \"on-elevation\"\n }),\n warning: getIconPath({\n category: \"system\",\n name: \"warning\",\n colorType: \"warning\"\n })\n};\nexport default ICONS;\n","// stencil\nimport { h, JSX } from \"@stencil/core\";\n\n// external libraries\nimport HTMLChTabularGridRowElement from \"@genexus/chameleon-controls-library/dist/types/components/tabular-grid/row/tabular-grid-row\";\n\n// local\nimport {\n MessageData,\n ModifiedObjectData,\n SourceType,\n StatusInternal\n} from \"./types\";\nimport { ObjectState } from \"../common/types\";\nimport ICONS from \"./constants\";\nimport { renderObjectTypeWithIcon } from \"../../common/utilities\";\nimport { formatDate } from \"../../../../common/helpers\";\nimport { CSS_SELECTORS as CLASSES } from \"./constants\";\nimport { hiChar } from \"../../../ww-files/helpers\";\nimport { config } from \"../../../../common/config\";\nimport {\n TabularGridColumnSelectorClickedEvent,\n TabularGridColumnSortChangedEvent\n} from \"@genexus/chameleon-controls-library\";\n\nconst BUTTON_ACTION_SELECTOR = \"button-action-custom-selector\";\nexport const COLUMNS_IDS = {\n action: \"action\",\n description: \"description\",\n lastSynchronized: \"lastSynchronized\",\n localState: \"localState\",\n modifiedOn: \"modifiedOn\",\n module: \"module\",\n name: \"name\",\n status: \"status\",\n type: \"type\"\n};\n\nconst renderStateCellContent = (\n action: ObjectState,\n componentLocale: any\n): JSX.Element[] | null | string => {\n let icon: string;\n let caption: string;\n let iconColor: string;\n\n if (action === \"deleted\") {\n icon = ICONS.substract;\n caption = componentLocale.states.deleted;\n iconColor = \"--mer-icon__error\";\n } else if (action === \"inserted\") {\n icon = ICONS.add;\n caption = componentLocale.states.inserted;\n iconColor = \"--mer-icon__success\";\n } else if (action === \"modified\") {\n icon = ICONS.edit;\n caption = componentLocale.states.modified;\n iconColor = \"--mer-icon__warning\";\n } else if (action === \"conflicted\") {\n icon = ICONS.warning;\n caption = componentLocale.states.conflicted;\n iconColor = \"--mer-icon__warning\";\n } else if (!action) {\n // proably is \"ignored\"\n return null;\n }\n\n return (\n <span class=\"custom-icon-text-wrapper\">\n <ch-image\n type=\"mask\"\n class=\"icon-md\"\n src={icon}\n style={{ backgroundColor: `var(${iconColor})` }}\n ></ch-image>\n {`${caption}`}\n </span>\n );\n};\n\nconst renderObjectStatus = (\n objectId: string,\n objectsStatusMap: Map<string, StatusInternal>,\n updatePillAsButton: boolean,\n commitSingleObject: (objectId: string) => () => void,\n componentLocale: any\n): JSX.Element[] => {\n const status = objectsStatusMap.get(objectId);\n const caption =\n status === \"pending\" && updatePillAsButton\n ? componentLocale.status.commit\n : componentLocale.status[status];\n\n if (status === \"commiting\") {\n return <span class=\"spinner-caption\">{caption}</span>;\n }\n\n const classes = `pill pill--${status}`;\n if (updatePillAsButton && status === \"pending\") {\n return (\n <button\n class={{\n \"button-secondary\": true,\n \"button-icon-and-text\": true,\n \"pill\": true,\n \"pill--update\": true,\n [BUTTON_ACTION_SELECTOR]: true\n }}\n onClick={commitSingleObject(objectId)}\n >\n {caption}\n </button>\n );\n } else {\n return <span class={classes}>{caption}</span>;\n }\n};\n\nconst renderTabularGridRows = (\n type: SourceType,\n pendingObjectsAfterFilter: ModifiedObjectData[],\n ignoredObjectsAfterFilter: ModifiedObjectData[],\n alreadyUpdatedObjectsIdsSet: Set<string>,\n markedObjectsSet: Set<string>,\n objectsMessagesDataMap: Map<string, MessageData[]>,\n updatePillAsButton: boolean,\n commitSingleObject: (objectId: string) => () => void,\n objectsStatusMap: Map<string, StatusInternal>,\n searchValue: string,\n componentLocale: any\n): HTMLChTabularGridRowElement[] => {\n let objects: ModifiedObjectData[];\n if (type === \"pending\") {\n objects = pendingObjectsAfterFilter;\n } else if (type === \"ignored\") {\n objects = ignoredObjectsAfterFilter;\n }\n\n searchValue = searchValue.toLowerCase();\n\n const filteredRows = objects.map(object => {\n const alreadyUpdated = alreadyUpdatedObjectsIdsSet.has(object.id);\n const hideCheckbox = alreadyUpdated || type === \"ignored\";\n const marked = markedObjectsSet.has(object.id);\n const messages = objectsMessagesDataMap.get(object.id);\n\n return (\n <ch-tabular-grid-row\n class=\"tabular-grid-row\"\n key={object.id}\n rowid={object.id}\n ref={(el: HTMLElement) => marked && el?.setAttribute(\"marked\", \"true\")}\n >\n <ch-tabular-grid-cell\n cell-type=\"rich\"\n row-selector=\"true\"\n class={{\n \"tabular-grid-cell\": true,\n \"no-checkbox-custom-selector\": hideCheckbox\n }}\n size=\"max-content\"\n >\n <div\n // This div is a WA to prevent the cell display:flex to\n // apply columns when hiChar is applied. hiChar creates\n // a span for every match.\n >\n {hiChar(object.name, searchValue)}\n </div>\n {/* {object.name} */}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {renderObjectTypeWithIcon(object.type)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell\n class={{\n \"tabular-grid-cell\": true,\n [CLASSES.GRID_CELL_DESCRIPTION]: true\n }}\n >\n <div\n // This div is a WA to prevent the cell display:flex to\n // apply columns when hiChar is applied. hiChar creates\n // a span for every match.\n >\n {hiChar(object.description, searchValue)}\n </div>\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {formatDate(object.modifiedOn)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {object.module}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {renderStateCellContent(object.state, componentLocale)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell\">\n {formatDate(object.lastSynchronized)}\n </ch-tabular-grid-cell>\n <ch-tabular-grid-cell class=\"tabular-grid-cell tabular-grid-cell--for-pill\">\n {renderObjectStatus(\n object.id,\n objectsStatusMap,\n updatePillAsButton,\n commitSingleObject,\n componentLocale\n )}\n </ch-tabular-grid-cell>\n\n {messages?.length && (\n <ch-tabular-grid-rowset class=\"tabular-grid-rowset\">\n <ch-tabular-grid-rowset-empty\n class={{\n \"tabular-grid-rowset-empty\": true\n }}\n >\n <ul class=\"messages-list\">\n {messages.map(message => {\n let MESSAGE_ICON;\n if (message.type === \"error\") {\n MESSAGE_ICON = ICONS.error;\n } else if (message.type === \"warning\") {\n MESSAGE_ICON = ICONS.warning;\n } else if (message.type === \"success\") {\n MESSAGE_ICON = ICONS.success;\n } else {\n // info\n MESSAGE_ICON = ICONS.info;\n }\n\n return (\n <li class=\"message-description\">\n <ch-image\n class=\"icon-md message-icon\"\n src={MESSAGE_ICON}\n ></ch-image>\n {message.text}\n </li>\n );\n })}\n </ul>\n </ch-tabular-grid-rowset-empty>\n </ch-tabular-grid-rowset>\n )}\n </ch-tabular-grid-row>\n );\n });\n\n return filteredRows;\n};\n\nexport default renderTabularGridRows;\n\nexport type GridColumnType =\n | \"action\"\n | \"description\"\n | \"lastSynchronized\"\n | \"localState\"\n | \"modifiedOn\"\n | \"module\"\n | \"name\"\n | \"status\"\n | \"type\";\n\nexport type GridColumnSet = Partial<Record<GridColumnType, true>>;\n\nexport const renderTabularGridColumns = (\n ignoredGridColumns: GridColumnType[],\n gridIsEmpty: boolean = false,\n sortTabularGridColumnCallback: (\n e: CustomEvent<TabularGridColumnSortChangedEvent>\n ) => void,\n columnSelectorClickedCallback: (\n e: CustomEvent<TabularGridColumnSelectorClickedEvent>\n ) => void,\n componentLocale: any,\n showRichRowSelector: boolean\n): JSX.Element => {\n const colSize = gridIsEmpty\n ? config.tabularGrid.colSize.auto\n : config.tabularGrid.colSize.maxContent;\n\n return (\n <ch-tabular-grid-columnset class=\"tabular-grid-column-set\">\n {!ignoredGridColumns.includes(\"name\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.name}\n columnName={componentLocale.objects.name}\n columnType=\"rich\"\n richRowSelector={showRichRowSelector}\n richRowSelectorMode=\"mark\"\n settingable={false}\n sortable={true}\n onColumnSortChanged={sortTabularGridColumnCallback}\n onColumnSelectorClicked={columnSelectorClickedCallback}\n size={colSize}\n />\n )}\n\n {!ignoredGridColumns.includes(\"type\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.type}\n columnName={componentLocale.objects.type}\n settingable={false}\n sortable={true}\n onColumnSortChanged={sortTabularGridColumnCallback}\n size={colSize}\n />\n )}\n\n {!ignoredGridColumns.includes(\"description\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.description}\n columnName={componentLocale.objects.description}\n settingable={false}\n sortable={true}\n onColumnSortChanged={sortTabularGridColumnCallback}\n size={config.tabularGrid.colSize.description}\n />\n )}\n\n {!ignoredGridColumns.includes(\"modifiedOn\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.modifiedOn}\n columnName={componentLocale.objects.modifiedOn}\n sortable={true}\n onColumnSortChanged={sortTabularGridColumnCallback}\n settingable={false}\n size={colSize}\n />\n )}\n\n {!ignoredGridColumns.includes(\"module\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.module}\n columnName={componentLocale.objects.module}\n sortable={true}\n onColumnSortChanged={sortTabularGridColumnCallback}\n settingable={false}\n size={colSize}\n />\n )}\n\n {!ignoredGridColumns.includes(\"localState\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.localState}\n columnName={componentLocale.objects.localState}\n sortable={false}\n settingable={false}\n size={colSize}\n />\n )}\n\n {!ignoredGridColumns.includes(\"lastSynchronized\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.lastSynchronized}\n columnName={componentLocale.objects.lastSynchronized}\n settingable={false}\n sortable={true}\n onColumnSortChanged={sortTabularGridColumnCallback}\n size={colSize}\n />\n )}\n\n {!ignoredGridColumns.includes(\"action\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.action}\n columnName={componentLocale.objects.action}\n sortable={false}\n settingable={false}\n size={colSize}\n />\n )}\n\n {!ignoredGridColumns.includes(\"status\") && (\n <ch-tabular-grid-column\n class=\"tabular-grid-column\"\n columnId={COLUMNS_IDS.status}\n columnName={componentLocale.objects.status}\n sortable={false}\n settingable={false}\n size={gridIsEmpty ? \"auto\" : \"100px\"}\n />\n )}\n </ch-tabular-grid-columnset>\n );\n};\n"],"mappings":"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"}
|