dashboard-shell-shell 1.0.1000000117 → 1.0.1000000118

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 (124) hide show
  1. package/assets/styles/base/_functions.scss +0 -0
  2. package/assets/styles/base/_mixins.scss +1 -1
  3. package/assets/styles/global/_button.scss +10 -17
  4. package/assets/styles/global/_form.scss +2 -2
  5. package/assets/styles/global/_labeled-input.scss +2 -6
  6. package/assets/styles/global/_select.scss +7 -6
  7. package/assets/styles/global/_table.scss +2 -3
  8. package/assets/styles/global/_tooltip.scss +1 -8
  9. package/assets/styles/themes/_dark.scss +0 -2
  10. package/assets/styles/themes/_light.scss +2 -5
  11. package/assets/styles/vendor/vue-select.scss +1 -2
  12. package/assets/translations/en-us.yaml +3 -1
  13. package/assets/translations/zh-hans.yaml +28 -51
  14. package/components/ActionDropdown.vue +0 -1
  15. package/components/ActionMenuShell.vue +3 -6
  16. package/components/BrandImage.vue +0 -22
  17. package/components/ClusterIconMenu.vue +1 -1
  18. package/components/CodeMirror.vue +0 -1
  19. package/components/CruResource.vue +1 -1
  20. package/components/CruResourceFooter.vue +1 -1
  21. package/components/ExplorerProjectsNamespaces.vue +24 -4
  22. package/components/GlobalRoleBindings.vue +48 -112
  23. package/components/IndentedPanel.vue +10 -4
  24. package/components/PromptRemove.vue +3 -3
  25. package/components/ResourceDetail/Masthead.vue +242 -190
  26. package/components/ResourceDetail/index.vue +5 -20
  27. package/components/ResourceList/Masthead.vue +84 -146
  28. package/components/ResourceList/ResourceLoadingIndicator.vue +2 -5
  29. package/components/ResourceTable.vue +1 -76
  30. package/components/SideNav.vue +29 -66
  31. package/components/SortableTable/THead.vue +0 -6
  32. package/components/SortableTable/index.vue +388 -481
  33. package/components/Tabbed/index.vue +5 -4
  34. package/components/auth/Principal.vue +2 -3
  35. package/components/auth/RoleDetailEdit.vue +5 -58
  36. package/components/auth/SelectPrincipal.vue +0 -1
  37. package/components/form/BannerSettings.vue +16 -18
  38. package/components/form/ChangePassword.vue +4 -4
  39. package/components/form/ColorInput.vue +8 -32
  40. package/components/form/Footer.vue +1 -1
  41. package/components/form/InputWithSelect.vue +0 -2
  42. package/components/form/KeyValue.vue +7 -31
  43. package/components/form/LabeledSelect.vue +178 -178
  44. package/components/form/Members/ClusterPermissionsEditor.vue +2 -1
  45. package/components/form/Members/MembershipEditor.vue +1 -1
  46. package/components/form/NameNsDescription.vue +11 -24
  47. package/components/form/Password.vue +2 -6
  48. package/components/form/ResourceQuota/Namespace.vue +1 -1
  49. package/components/form/ResourceQuota/NamespaceRow.vue +10 -13
  50. package/components/form/ResourceQuota/ProjectRow.vue +1 -0
  51. package/components/form/Select.vue +2 -2
  52. package/components/nav/Favorite.vue +1 -5
  53. package/components/nav/Group.vue +23 -69
  54. package/components/nav/Header.vue +17 -82
  55. package/components/nav/HeaderPageActionMenu.vue +0 -1
  56. package/components/nav/NamespaceFilter.vue +3 -0
  57. package/components/nav/TopLevelMenu.vue +119 -182
  58. package/components/nav/Type.vue +11 -48
  59. package/components/rancherResourceDetail/Masthead.vue +769 -0
  60. package/components/rancherResourceDetail/__tests__/Masthead.test.ts +65 -0
  61. package/components/rancherResourceDetail/index.vue +591 -0
  62. package/components/rancherResourceList/Masthead.vue +375 -0
  63. package/components/rancherResourceList/ResourceLoadingIndicator.vue +140 -0
  64. package/components/rancherResourceList/index.vue +307 -0
  65. package/components/rancherResourceList/resource-list.config.js +7 -0
  66. package/components/rancherResourceTable.vue +783 -0
  67. package/components/rancherSortableTable/THead.vue +561 -0
  68. package/components/rancherSortableTable/actions.js +153 -0
  69. package/components/rancherSortableTable/advanced-filtering.js +272 -0
  70. package/components/rancherSortableTable/debug.js +117 -0
  71. package/components/rancherSortableTable/filtering.js +290 -0
  72. package/components/rancherSortableTable/grouping.js +48 -0
  73. package/components/rancherSortableTable/index.vue +2712 -0
  74. package/components/rancherSortableTable/paging.js +155 -0
  75. package/components/rancherSortableTable/selection.js +629 -0
  76. package/components/rancherSortableTable/sortable-config.ts +4 -0
  77. package/components/rancherSortableTable/sorting.js +129 -0
  78. package/composables/useClickOutside.ts +1 -1
  79. package/config/product/auth.js +7 -16
  80. package/config/product/explorer.js +1 -1
  81. package/config/product/settings.js +8 -17
  82. package/config/settings.ts +0 -28
  83. package/edit/management.cattle.io.user.vue +4 -17
  84. package/edit/networking.k8s.io.ingress/RulePath.vue +1 -1
  85. package/edit/token.vue +1 -1
  86. package/list/harvesterhci.io.management.cluster.vue +0 -17
  87. package/list/management.cattle.io.setting.vue +13 -22
  88. package/list/management.cattle.io.user.vue +14 -25
  89. package/list/provisioning.cattle.io.cluster.vue +7 -6
  90. package/mixins/brand.js +0 -17
  91. package/package.json +1 -1
  92. package/pages/auth/login.vue +29 -84
  93. package/pages/c/_cluster/auth/roles/index.vue +14 -61
  94. package/pages/c/_cluster/settings/banners.vue +101 -174
  95. package/pages/c/_cluster/settings/brand.vue +301 -348
  96. package/pages/c/_cluster/settings/performance.vue +38 -61
  97. package/pages/home.vue +21 -70
  98. package/pages/prefs.vue +23 -25
  99. package/pkg/tsconfig.json +9 -9
  100. package/pkg/vue.config.js +1 -1
  101. package/promptRemove/mixin/roleDeletionCheck.js +2 -2
  102. package/scripts/clean +0 -0
  103. package/scripts/extension/bundle +0 -0
  104. package/scripts/extension/helm/scripts/package +0 -0
  105. package/scripts/extension/helm/scripts/patch +0 -0
  106. package/scripts/extension/helm/scripts/version +0 -0
  107. package/scripts/extension/helmpatch +0 -0
  108. package/scripts/extension/parse-tag-name +0 -0
  109. package/scripts/extension/publish +0 -0
  110. package/scripts/publish-shell.sh +60 -86
  111. package/scripts/serve-pkgs +0 -0
  112. package/scripts/sync-shell-deps +0 -0
  113. package/scripts/typegen.sh +28 -44
  114. package/store/i18n.js +5 -5
  115. package/store/prefs.js +5 -17
  116. package/store/type-map.js +1 -2
  117. package/types/cloud-shell/index.d.ts +11014 -0
  118. package/types/shell/index.d.ts +1 -1
  119. package/utils/error.js +0 -4
  120. package/utils/router.js +3 -3
  121. package/vue.config.js +6 -1
  122. package/assets/images/action.svg +0 -6
  123. package/assets/images/pl/logo.png +0 -0
  124. /package/components/{ResourceList → rancherResourceList}/Masthead-btn.vue +0 -0
@@ -1,13 +1,13 @@
1
1
  <script>
2
2
  import { mapGetters, useStore } from 'vuex';
3
- import ResourceTable, { defaultTableSortGenerationFn } from '@shell/components/ResourceTable';
3
+ import ResourceTable, { defaultTableSortGenerationFn } from '@shell/components/rancherResourceTable';
4
4
  import { STATE, AGE, NAME, NS_SNAPSHOT_QUOTA } from '@shell/config/table-headers';
5
5
  import { uniq } from '@shell/utils/array';
6
6
  import { MANAGEMENT, NAMESPACE, VIRTUAL_TYPES, HCI } from '@shell/config/types';
7
7
  import { PROJECT_ID, FLAT_VIEW } from '@shell/config/query-params';
8
8
  import { PanelLocation, ExtensionPoint } from '@shell/core/types';
9
9
  import ExtensionPanel from '@shell/components/ExtensionPanel';
10
- import Masthead from '@shell/components/ResourceList/Masthead';
10
+ import Masthead from '@shell/components/rancherResourceList/Masthead';
11
11
  import { mapPref, GROUP_RESOURCES, ALL_NAMESPACES, DEV } from '@shell/store/prefs';
12
12
  import MoveModal from '@shell/components/MoveModal';
13
13
  import ButtonMultiAction from '@shell/components/ButtonMultiAction.vue';
@@ -505,11 +505,29 @@ export default {
505
505
  <div class="right">
506
506
  <router-link
507
507
  v-if="isNamespaceCreatable && (canSeeProjectlessNamespaces || group.group.key !== notInProjectKey)"
508
- class="create-namespace btn btn-sm mr-5"
508
+ class="create-namespace"
509
+ style="margin-bottom: 3px;"
509
510
  :to="createNamespaceLocation(group.group)"
510
- >1
511
+ >
511
512
  {{ t('projectNamespaces.createNamespace') }}
512
513
  </router-link>
514
+ <span style="color: var(--link);margin-bottom: 3px;">|</span>
515
+ <template v-if="featureDropdownMenu">
516
+ <ActionMenu
517
+ :showIcon="true"
518
+ :resource="getProjectActions(group.group)"
519
+ :button-aria-label="t('projectNamespaces.tableActionsLabel', { resource: projectResource(group.group) })"
520
+ />
521
+ </template>
522
+ <template v-else>
523
+ <ButtonMultiAction
524
+ class="project-action"
525
+ :borderless="true"
526
+ :aria-label="t('projectNamespaces.tableActionsLabel', { resource: projectResource(group.group) })"
527
+ :invisible="!showProjectActionButton(group.group)"
528
+ @click="showProjectAction($event, group.group)"
529
+ />
530
+ </template>
513
531
  </div>
514
532
  </div>
515
533
  </template>
@@ -575,6 +593,7 @@ export default {
575
593
  </template>
576
594
  <style lang="scss" scoped>
577
595
  .invisible {
596
+ width: 42px;
578
597
  display: inline-block;
579
598
  }
580
599
 
@@ -601,6 +620,7 @@ export default {
601
620
 
602
621
  .create-namespace {
603
622
  color: var(--link);
623
+ padding: 0 18px;
604
624
  }
605
625
 
606
626
  .group-tab {
@@ -108,12 +108,7 @@ export default {
108
108
  } catch (e) { }
109
109
  },
110
110
  data() {
111
-
112
- const topLevelPermissions = sessionStorage.getItem('TOPLEVELPERMISSIONS') || ''
113
-
114
111
  return {
115
- topLevelPermissions,
116
-
117
112
  // This not only identifies global roles but the order here is the order we want to display them in the UI
118
113
  globalPermissions: [
119
114
  'admin',
@@ -333,119 +328,60 @@ export default {
333
328
 
334
329
  <div v-else>
335
330
  <form v-if="selectedRoles">
336
- <template v-if="topLevelPermissions && topLevelPermissions !== 'superadmin'">
337
- <div
338
- v-for="(sortedRole, roleType) in sortedRoles"
339
- :key="roleType"
340
- class="role-group mb-10"
341
- >
342
- <Card
343
- v-if="Object.keys(sortedRole).length"
344
- :show-highlight-border="false"
345
- :show-actions="false"
346
- >
347
- <template v-slot:title>
348
- <div class="type-title">
349
- <h3>{{ t(`rbac.globalRoles.types.${roleType}.label`) }}</h3>
350
- <div class="type-description">
351
- {{ t(`rbac.globalRoles.types.${roleType}.description`, { isUser }) }}
352
- </div>
353
- </div>
354
- </template>
355
- <template v-slot:body>
356
- <div
357
- class="checkbox-section"
358
- :class="'checkbox-section--' + roleType"
359
- >
360
- <div
361
- v-for="(role, i) in sortedRoles[roleType]"
362
- :key="i"
363
- class="checkbox mb-10 mr-10"
364
- >
365
- <Checkbox
366
- v-model:value="selectedRoles"
367
- :value-when-true="role.id"
368
- :disabled="!!assignOnlyRoles[role.id]"
369
- :label="role.nameDisplay"
370
- :description="role.descriptionDisplay"
371
- :mode="mode"
372
- :data-testId="'grb-checkbox-' + role.id"
373
- @update:value="checkboxChanged"
374
- >
375
- <template #label>
376
- <div class="checkbox-label-slot">
377
- <span class="checkbox-label">{{ role.nameDisplay }}</span>
378
- <i
379
- v-if="!!assignOnlyRoles[role.id]"
380
- v-clean-tooltip="t('rbac.globalRoles.assignOnlyRole')"
381
- class="checkbox-info icon icon-info icon-lg"
382
- />
383
- </div>
384
- </template>
385
- </Checkbox>
386
- </div>
387
- </div>
388
- </template>
389
- </Card>
390
- </div>
391
- </template>
392
-
393
- <template v-else>
394
- <div
395
- v-for="(sortedRole, roleType) in { global: sortedRoles['global'] }"
396
- :key="roleType"
397
- class="role-group mb-10"
331
+ <div
332
+ v-for="(sortedRole, roleType) in sortedRoles"
333
+ :key="roleType"
334
+ class="role-group mb-10"
335
+ >
336
+ <Card
337
+ v-if="Object.keys(sortedRole).length"
338
+ :show-highlight-border="false"
339
+ :show-actions="false"
398
340
  >
399
- <Card
400
- v-if="Object.keys(sortedRole).length"
401
- :show-highlight-border="false"
402
- :show-actions="false"
403
- >
404
- <template v-slot:title>
405
- <div class="type-title">
406
- <h3>{{ t(`rbac.globalRoles.types.${roleType}.label`) }}</h3>
407
- <div class="type-description">
408
- {{ t(`rbac.globalRoles.types.${roleType}.description`, { isUser }) }}
409
- </div>
341
+ <template v-slot:title>
342
+ <div class="type-title">
343
+ <h3>{{ t(`rbac.globalRoles.types.${roleType}.label`) }}</h3>
344
+ <div class="type-description">
345
+ {{ t(`rbac.globalRoles.types.${roleType}.description`, { isUser }) }}
410
346
  </div>
411
- </template>
412
- <template v-slot:body>
347
+ </div>
348
+ </template>
349
+ <template v-slot:body>
350
+ <div
351
+ class="checkbox-section"
352
+ :class="'checkbox-section--' + roleType"
353
+ >
413
354
  <div
414
- class="checkbox-section"
415
- :class="'checkbox-section--' + roleType"
355
+ v-for="(role, i) in sortedRoles[roleType]"
356
+ :key="i"
357
+ class="checkbox mb-10 mr-10"
416
358
  >
417
- <div
418
- v-for="(role, i) in sortedRoles[roleType]"
419
- :key="i"
420
- class="checkbox mb-10 mr-10"
359
+ <Checkbox
360
+ v-model:value="selectedRoles"
361
+ :value-when-true="role.id"
362
+ :disabled="!!assignOnlyRoles[role.id]"
363
+ :label="role.nameDisplay"
364
+ :description="role.descriptionDisplay"
365
+ :mode="mode"
366
+ :data-testId="'grb-checkbox-' + role.id"
367
+ @update:value="checkboxChanged"
421
368
  >
422
- <Checkbox
423
- v-model:value="selectedRoles"
424
- :value-when-true="role.id"
425
- :disabled="!!assignOnlyRoles[role.id]"
426
- :label="role.nameDisplay"
427
- :description="role.descriptionDisplay"
428
- :mode="mode"
429
- :data-testId="'grb-checkbox-' + role.id"
430
- @update:value="checkboxChanged"
431
- >
432
- <template #label>
433
- <div class="checkbox-label-slot">
434
- <span class="checkbox-label">{{ role.nameDisplay }}</span>
435
- <i
436
- v-if="!!assignOnlyRoles[role.id]"
437
- v-clean-tooltip="t('rbac.globalRoles.assignOnlyRole')"
438
- class="checkbox-info icon icon-info icon-lg"
439
- />
440
- </div>
441
- </template>
442
- </Checkbox>
443
- </div>
369
+ <template #label>
370
+ <div class="checkbox-label-slot">
371
+ <span class="checkbox-label">{{ role.nameDisplay }}</span>
372
+ <i
373
+ v-if="!!assignOnlyRoles[role.id]"
374
+ v-clean-tooltip="t('rbac.globalRoles.assignOnlyRole')"
375
+ class="checkbox-info icon icon-info icon-lg"
376
+ />
377
+ </div>
378
+ </template>
379
+ </Checkbox>
444
380
  </div>
445
- </template>
446
- </Card>
447
- </div>
448
- </template>
381
+ </div>
382
+ </template>
383
+ </Card>
384
+ </div>
449
385
  </form>
450
386
  </div>
451
387
  </template>
@@ -4,17 +4,23 @@ export default {};
4
4
 
5
5
  <template>
6
6
  <div
7
- class="indented-panels"
7
+ class="indented-panel"
8
8
  >
9
9
  <slot />
10
10
  </div>
11
11
  </template>
12
12
 
13
13
  <style lang="scss">
14
- .indented-panels {
14
+ .indented-panel {
15
15
  height: 100%;
16
- width: 100%;
17
- padding: 0 20px;
16
+ width: 90%;
17
+ margin-left: 5%;
18
18
  }
19
19
 
20
+ @media only screen and (max-width: map-get($breakpoints, '--viewport-9')) {
21
+ .indented-panel {
22
+ margin: 0 20px;
23
+ width: initial;
24
+ }
25
+ }
20
26
  </style>
@@ -386,7 +386,7 @@ export default {
386
386
  class="mt-10"
387
387
  >
388
388
  <span
389
- v-clean-html="t('promptRemove.confirmName', { nameToMatch: escapeHtml(nameToMatch) })"
389
+ v-clean-html="t('promptRemove.confirmName', { nameToMatch: escapeHtml(nameToMatch) }, true)"
390
390
  />
391
391
  </div>
392
392
  </div>
@@ -460,8 +460,8 @@ export default {
460
460
  box-shadow: none;
461
461
  }
462
462
  #confirm {
463
- width: 100%;
464
- // margin-left: 3px;
463
+ width: 90%;
464
+ margin-left: 3px;
465
465
  }
466
466
 
467
467
  .actions {