@rancher/shell 0.5.2 → 1.2.0

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 (338) hide show
  1. package/.DS_Store +0 -0
  2. package/assets/images/providers/aks-black.svg +28 -0
  3. package/assets/images/providers/aks.svg +31 -0
  4. package/assets/styles/global/_labeled-input.scss +1 -0
  5. package/assets/styles/global/_layout.scss +0 -99
  6. package/assets/translations/en-us.yaml +77 -71
  7. package/assets/translations/zh-hans.yaml +25 -23
  8. package/babel.config.js +1 -7
  9. package/chart/gatekeeper.vue +11 -2
  10. package/chart/istio.vue +10 -1
  11. package/chart/logging/index.vue +11 -2
  12. package/chart/monitoring/alerting/index.vue +21 -7
  13. package/chart/monitoring/grafana/index.vue +2 -57
  14. package/chart/monitoring/index.vue +26 -52
  15. package/chart/monitoring/prometheus/index.vue +43 -37
  16. package/chart/rancher-backup/index.vue +10 -3
  17. package/cloud-credential/azure.vue +17 -4
  18. package/components/AsyncButton.vue +0 -9
  19. package/components/Carousel.vue +0 -1
  20. package/components/ChartPsp.vue +76 -0
  21. package/components/CodeMirror.vue +21 -19
  22. package/components/CopyCode.vue +2 -6
  23. package/components/CopyToClipboard.vue +1 -2
  24. package/components/CopyToClipboardText.vue +9 -14
  25. package/components/CruResource.vue +0 -1
  26. package/components/EtcdInfoBanner.vue +5 -5
  27. package/components/ExplorerProjectsNamespaces.vue +1 -25
  28. package/components/IconOrSvg.vue +1 -1
  29. package/components/Markdown.vue +12 -16
  30. package/components/Questions/index.vue +1 -1
  31. package/components/ResourceDetail/Masthead.vue +9 -25
  32. package/components/ResourceList/Masthead.vue +18 -1
  33. package/components/ResourceTable.vue +2 -14
  34. package/components/ResourceYaml.vue +0 -5
  35. package/components/SideNav.vue +1 -1
  36. package/components/SortableTable/THead.vue +9 -7
  37. package/components/SortableTable/index.vue +3 -2
  38. package/components/StatusTable.vue +1 -5
  39. package/components/TabTitle.vue +84 -0
  40. package/components/Tabbed/index.vue +0 -12
  41. package/components/__tests__/ChartPsp.test.ts +75 -0
  42. package/components/__tests__/CopyCode.test.ts +4 -5
  43. package/components/fleet/FleetBundles.vue +11 -5
  44. package/components/fleet/FleetRepos.vue +27 -62
  45. package/components/fleet/FleetResources.vue +1 -6
  46. package/components/fleet/FleetStatus.vue +3 -3
  47. package/components/fleet/FleetSummary.vue +30 -35
  48. package/components/form/ArrayList.vue +8 -1
  49. package/components/form/ArrayListSelect.vue +9 -9
  50. package/components/form/KeyValue.vue +0 -1
  51. package/components/form/LabeledSelect.vue +0 -4
  52. package/components/form/Password.vue +1 -3
  53. package/components/form/Select.vue +1 -1
  54. package/components/form/SelectOrCreateAuthSecret.vue +4 -4
  55. package/components/form/__tests__/KeyValue.test.ts +1 -1
  56. package/components/formatter/Checked.vue +3 -11
  57. package/components/formatter/ClusterProvider.vue +18 -1
  58. package/components/formatter/FleetSummaryGraph.vue +11 -23
  59. package/components/formatter/LiveDate.vue +16 -0
  60. package/components/formatter/LiveDuration.vue +1 -1
  61. package/components/formatter/PercentageBar.vue +1 -1
  62. package/components/formatter/__tests__/ClusterProvider.test.ts +28 -0
  63. package/components/nav/Group.vue +2 -2
  64. package/components/nav/Header.vue +2 -1
  65. package/components/nav/TopLevelMenu.vue +3 -29
  66. package/components/nav/Type.vue +3 -1
  67. package/components/nav/WindowManager/ContainerLogs.vue +19 -120
  68. package/components/nav/WindowManager/ContainerShell.vue +1 -6
  69. package/components/nav/WindowManager/index.vue +10 -11
  70. package/components/nav/__tests__/TopLevelMenu.test.ts +0 -33
  71. package/components/nav/__tests__/Type.test.ts +1 -1
  72. package/components/nuxt/nuxt-child.js +78 -14
  73. package/components/nuxt/nuxt.js +1 -1
  74. package/components/user.retention/user-retention-header.vue +34 -0
  75. package/composables/useI18n.ts +26 -0
  76. package/composables/useStore.ts +16 -0
  77. package/config/harvester-manager-types.js +0 -2
  78. package/config/home-links.js +32 -2
  79. package/config/private-label.js +0 -22
  80. package/config/product/explorer.js +4 -4
  81. package/config/product/fleet.js +1 -6
  82. package/config/product/legacy.js +1 -84
  83. package/config/product/manager.js +15 -8
  84. package/config/query-params.js +0 -1
  85. package/config/router.js +368 -385
  86. package/config/settings.ts +9 -2
  87. package/config/store.js +1 -1
  88. package/config/system-namespaces.js +0 -3
  89. package/config/table-headers.js +27 -47
  90. package/config/types.js +5 -0
  91. package/config/uiplugins.js +1 -1
  92. package/core/plugin-helpers.js +5 -3
  93. package/core/plugin-routes.ts +114 -56
  94. package/core/plugin.ts +10 -16
  95. package/core/plugins-loader.js +9 -7
  96. package/core/plugins.js +3 -0
  97. package/core/types-provisioning.ts +0 -7
  98. package/creators/app/init +0 -19
  99. package/detail/fleet.cattle.io.cluster.vue +1 -11
  100. package/detail/node.vue +0 -42
  101. package/detail/pod.vue +1 -68
  102. package/detail/provisioning.cattle.io.cluster.vue +4 -6
  103. package/detail/workload/index.vue +1 -15
  104. package/dialog/ScaleMachineDownDialog.vue +17 -34
  105. package/edit/auth/googleoauth.vue +5 -1
  106. package/edit/catalog.cattle.io.clusterrepo.vue +7 -20
  107. package/edit/cloudcredential.vue +0 -2
  108. package/edit/fleet.cattle.io.gitrepo.vue +4 -3
  109. package/edit/management.cattle.io.project.vue +52 -1
  110. package/edit/management.cattle.io.setting.vue +2 -31
  111. package/edit/monitoring.coreos.com.prometheusrule/AlertingRule.vue +3 -12
  112. package/edit/monitoring.coreos.com.prometheusrule/GroupRules.vue +1 -2
  113. package/edit/networking.k8s.io.networkpolicy/__tests__/PolicyRuleTarget.spec.ts +1 -1
  114. package/edit/provisioning.cattle.io.cluster/{tabs/Basics.vue → Basics.vue} +126 -109
  115. package/edit/provisioning.cattle.io.cluster/{tabs/MachinePool.vue → MachinePool.vue} +7 -1
  116. package/edit/provisioning.cattle.io.cluster/{tabs/registries/RegistryConfigs.vue → RegistryConfigs.vue} +3 -1
  117. package/edit/provisioning.cattle.io.cluster/SelectCredential.vue +7 -15
  118. package/edit/provisioning.cattle.io.cluster/__tests__/Basics.tests.ts +237 -0
  119. package/edit/provisioning.cattle.io.cluster/__tests__/{CustomCommand.test.ts → CustomCommand.tests.ts} +0 -6
  120. package/edit/provisioning.cattle.io.cluster/__tests__/DrainOptions.test.ts +1 -1
  121. package/edit/provisioning.cattle.io.cluster/__tests__/rke2.test.ts +1 -7
  122. package/edit/provisioning.cattle.io.cluster/import.vue +2 -2
  123. package/edit/provisioning.cattle.io.cluster/index.vue +37 -99
  124. package/edit/provisioning.cattle.io.cluster/rke2.vue +690 -181
  125. package/edit/service.vue +0 -12
  126. package/edit/workload/Upgrading.vue +2 -3
  127. package/edit/workload/index.vue +1 -2
  128. package/edit/workload/mixins/workload.js +1 -1
  129. package/initialize/App.js +71 -25
  130. package/initialize/client.js +162 -21
  131. package/initialize/index.js +124 -47
  132. package/initialize/layouts.ts +26 -0
  133. package/{components/templates → layouts}/blank.vue +1 -1
  134. package/{components/templates → layouts}/default.vue +98 -8
  135. package/{components/templates → layouts}/error.vue +19 -10
  136. package/{components/templates → layouts}/home.vue +1 -4
  137. package/{components/templates → layouts}/plain.vue +1 -4
  138. package/{components/templates → layouts}/standalone.vue +1 -1
  139. package/{components/templates → layouts}/unauthenticated.vue +1 -1
  140. package/list/management.cattle.io.feature.vue +7 -1
  141. package/list/management.cattle.io.user.vue +25 -1
  142. package/list/node.vue +0 -1
  143. package/machine-config/__tests__/vmwarevsphere.test.ts +161 -56
  144. package/machine-config/amazonec2.vue +1 -0
  145. package/machine-config/azure.vue +37 -21
  146. package/machine-config/vmwarevsphere.vue +47 -42
  147. package/middleware/authenticated.js +19 -14
  148. package/mixins/auth-config.js +7 -2
  149. package/mixins/brand.js +41 -29
  150. package/mixins/fetch.server.js +73 -0
  151. package/mixins/labeled-form-element.ts +1 -6
  152. package/models/__tests__/management.cattle.io.node.ts +0 -85
  153. package/models/__tests__/namespace.test.ts +9 -49
  154. package/models/cluster/node.js +4 -4
  155. package/models/cluster.x-k8s.io.machine.js +1 -1
  156. package/models/cluster.x-k8s.io.machinedeployment.js +0 -14
  157. package/models/fleet.cattle.io.cluster.js +0 -4
  158. package/models/fleet.cattle.io.gitrepo.js +13 -56
  159. package/models/management.cattle.io.cluster.js +3 -11
  160. package/models/management.cattle.io.kontainerdriver.js +0 -1
  161. package/models/management.cattle.io.node.js +14 -18
  162. package/models/management.cattle.io.nodepool.js +0 -17
  163. package/models/management.cattle.io.project.js +36 -0
  164. package/models/management.cattle.io.setting.js +7 -11
  165. package/models/management.cattle.io.user.js +65 -0
  166. package/models/namespace.js +1 -1
  167. package/models/pod.js +0 -20
  168. package/models/provisioning.cattle.io.cluster.js +8 -55
  169. package/models/secret.js +18 -117
  170. package/models/workload.js +0 -16
  171. package/models/workload.service.js +0 -18
  172. package/package.json +10 -12
  173. package/pages/about.vue +1 -0
  174. package/pages/account/create-key.vue +1 -0
  175. package/pages/account/index.vue +1 -0
  176. package/pages/auth/login.vue +1 -0
  177. package/pages/auth/logout.vue +2 -0
  178. package/pages/auth/setup.vue +4 -37
  179. package/pages/auth/verify.vue +8 -14
  180. package/pages/c/_cluster/apps/charts/__tests__/install.helper.test.ts +17 -2
  181. package/pages/c/_cluster/apps/charts/index.vue +58 -64
  182. package/pages/c/_cluster/apps/charts/install.helpers.js +13 -2
  183. package/pages/c/_cluster/apps/charts/install.vue +5 -5
  184. package/pages/c/_cluster/apps/index.vue +2 -0
  185. package/pages/c/_cluster/auth/index.vue +2 -0
  186. package/pages/c/_cluster/auth/user.retention/index.vue +384 -0
  187. package/pages/c/_cluster/ecm/index.vue +2 -0
  188. package/pages/c/_cluster/explorer/index.vue +53 -56
  189. package/pages/c/_cluster/explorer/tools/index.vue +3 -171
  190. package/pages/c/_cluster/fleet/index.vue +1 -1
  191. package/pages/c/_cluster/index.vue +2 -0
  192. package/pages/c/_cluster/manager/pages/_page.vue +5 -4
  193. package/pages/c/_cluster/monitoring/index.vue +1 -17
  194. package/pages/c/_cluster/settings/DefaultLinksEditor.vue +1 -0
  195. package/pages/c/_cluster/settings/banners.vue +2 -0
  196. package/pages/c/_cluster/settings/brand.vue +2 -0
  197. package/pages/c/_cluster/settings/index.vue +2 -0
  198. package/pages/c/_cluster/settings/links.vue +3 -2
  199. package/pages/c/_cluster/settings/performance.vue +1 -0
  200. package/pages/c/_cluster/uiplugins/AddExtensionRepos.vue +4 -4
  201. package/pages/c/_cluster/uiplugins/CatalogList/CatalogLoadDialog.vue +1 -2
  202. package/pages/c/_cluster/uiplugins/CatalogList/index.vue +46 -10
  203. package/pages/c/_cluster/uiplugins/SetupUIPlugins.vue +5 -2
  204. package/pages/c/_cluster/uiplugins/__tests__/AddExtensionRepos.test.ts +96 -0
  205. package/pages/c/_cluster/uiplugins/__tests__/SetupUIPlugins.test.ts +128 -0
  206. package/pages/c/_cluster/uiplugins/index.vue +2 -0
  207. package/pages/c/index.vue +9 -0
  208. package/pages/diagnostic.vue +2 -1
  209. package/pages/fail-whale.vue +1 -0
  210. package/pages/prefs.vue +1 -0
  211. package/pages/rio/mesh.vue +508 -0
  212. package/pages/support/index.vue +8 -2
  213. package/pkg/auto-import.js +1 -1
  214. package/plugins/axios.js +36 -0
  215. package/plugins/back-button.js +5 -3
  216. package/plugins/clean-html-directive.js +19 -1
  217. package/plugins/clean-tooltip-directive.js +1 -1
  218. package/plugins/codemirror-loader.js +1 -1
  219. package/plugins/codemirror.js +0 -41
  220. package/plugins/dashboard-store/__tests__/actions.spec.ts +250 -0
  221. package/plugins/dashboard-store/__tests__/{mutations.test.ts → mutations.spec.ts} +1 -1
  222. package/plugins/dashboard-store/actions.js +21 -22
  223. package/plugins/dashboard-store/classify.js +18 -1
  224. package/plugins/dashboard-store/getters.js +5 -10
  225. package/plugins/dashboard-store/index.js +12 -0
  226. package/plugins/dashboard-store/mutations.js +4 -0
  227. package/plugins/dashboard-store/resource-class.js +18 -59
  228. package/plugins/i18n.js +1 -1
  229. package/plugins/steve/__tests__/getters.spec.ts +56 -24
  230. package/plugins/steve/__tests__/subscribe.spec.ts +106 -0
  231. package/plugins/steve/getters.js +30 -7
  232. package/plugins/steve/mutations.js +5 -2
  233. package/plugins/steve/norman-class.js +0 -19
  234. package/plugins/steve/steve-class.js +0 -22
  235. package/plugins/steve/subscribe.js +34 -13
  236. package/plugins/transitions.js +4 -0
  237. package/plugins/vue-clipboard2.js +4 -0
  238. package/rancher-components/Accordion/Accordion.vue +3 -2
  239. package/rancher-components/BadgeState/BadgeState.vue +3 -3
  240. package/rancher-components/Banner/Banner.test.ts +1 -5
  241. package/rancher-components/Banner/Banner.vue +2 -2
  242. package/rancher-components/Card/Card.vue +4 -4
  243. package/rancher-components/Form/Checkbox/Checkbox.vue +4 -3
  244. package/rancher-components/Form/LabeledInput/LabeledInput.test.ts +1 -1
  245. package/rancher-components/Form/LabeledInput/LabeledInput.vue +55 -24
  246. package/rancher-components/Form/Radio/RadioButton.test.ts +1 -3
  247. package/rancher-components/Form/Radio/RadioButton.vue +13 -7
  248. package/rancher-components/Form/Radio/RadioGroup.vue +4 -3
  249. package/rancher-components/Form/TextArea/TextAreaAutoGrow.vue +7 -5
  250. package/rancher-components/Form/ToggleSwitch/ToggleSwitch.vue +7 -4
  251. package/rancher-components/LabeledTooltip/LabeledTooltip.vue +9 -4
  252. package/rancher-components/StringList/StringList.vue +8 -8
  253. package/rancher-components/components/Accordion/Accordion.vue +3 -2
  254. package/rancher-components/components/BadgeState/BadgeState.test.ts +12 -0
  255. package/rancher-components/components/Form/LabeledInput/LabeledInput.test.ts +2 -19
  256. package/rancher-components/components/Form/LabeledInput/LabeledInput.vue +14 -11
  257. package/rancher-components/components/Form/TextArea/TextAreaAutoGrow.vue +1 -1
  258. package/rancher-components/components/StringList/StringList.test.ts +0 -270
  259. package/rancher-components/components/StringList/StringList.vue +18 -57
  260. package/scripts/extension/bundle +7 -19
  261. package/scripts/extension/helm/scripts/package +3 -11
  262. package/scripts/extension/parse-tag-name +4 -4
  263. package/scripts/extension/publish +9 -20
  264. package/scripts/publish-shell.sh +1 -11
  265. package/scripts/test-plugins-build.sh +9 -85
  266. package/store/catalog.js +1 -1
  267. package/store/features.js +0 -1
  268. package/store/i18n.js +0 -11
  269. package/store/index.js +11 -8
  270. package/store/prefs.js +38 -33
  271. package/store/type-map.js +8 -13
  272. package/tsconfig.default.json +46 -0
  273. package/tsconfig.json +9 -35
  274. package/types/shell/index.d.ts +404 -463
  275. package/utils/__tests__/create-yaml.test.ts +10 -0
  276. package/utils/axios.js +19 -0
  277. package/utils/create-yaml.js +6 -6
  278. package/utils/custom-validators.js +2 -0
  279. package/utils/error.js +1 -16
  280. package/utils/monitoring.js +2 -37
  281. package/utils/nuxt.js +39 -18
  282. package/utils/object.js +0 -14
  283. package/utils/router.scrollBehavior.js +14 -12
  284. package/utils/socket.js +1 -0
  285. package/utils/time.js +1 -1
  286. package/utils/title.ts +3 -0
  287. package/utils/url.ts +1 -1
  288. package/utils/validators/formRules/__tests__/index.test.ts +4 -49
  289. package/utils/validators/formRules/index.ts +9 -12
  290. package/utils/validators/setting.js +10 -6
  291. package/vue.config.js +3 -24
  292. package/chart/monitoring/steps/uninstall-v1.vue +0 -135
  293. package/components/Certificates.vue +0 -164
  294. package/components/fleet/__tests__/FleetSummary.test.ts +0 -316
  295. package/components/formatter/FleetClusterSummaryGraph.vue +0 -27
  296. package/components/formatter/__tests__/Checked.test.ts +0 -19
  297. package/components/nav/WindowManager/__tests__/ContainerLogs.test.ts +0 -186
  298. package/composables/useCompactInput.ts +0 -20
  299. package/composables/useLabeledFormElement.ts +0 -138
  300. package/creators/app/files/.gitlab-ci.yml +0 -14
  301. package/edit/__tests__/service.test.ts +0 -89
  302. package/edit/provisioning.cattle.io.cluster/__tests__/Advanced.test.ts +0 -112
  303. package/edit/provisioning.cattle.io.cluster/__tests__/Basics.test.ts +0 -473
  304. package/edit/provisioning.cattle.io.cluster/__tests__/index.test.ts +0 -73
  305. package/edit/provisioning.cattle.io.cluster/__tests__/utils/cluster.ts +0 -386
  306. package/edit/provisioning.cattle.io.cluster/tabs/AddOnConfig.vue +0 -137
  307. package/edit/provisioning.cattle.io.cluster/tabs/Advanced.vue +0 -157
  308. package/edit/provisioning.cattle.io.cluster/tabs/etcd/index.vue +0 -135
  309. package/edit/provisioning.cattle.io.cluster/tabs/networking/index.vue +0 -189
  310. package/edit/provisioning.cattle.io.cluster/tabs/registries/index.vue +0 -144
  311. package/edit/provisioning.cattle.io.cluster/tabs/upgrade/index.vue +0 -76
  312. package/mixins/v1-workload-metrics.js +0 -43
  313. package/models/__tests__/management.cattle.io.cluster.test.ts +0 -23
  314. package/models/__tests__/management.cattle.io.nodepool.ts +0 -83
  315. package/models/__tests__/provisioning.cattle.io.cluster.test.ts +0 -90
  316. package/models/__tests__/workload.test.ts +0 -91
  317. package/plugins/clean-html.js +0 -53
  318. package/plugins/dashboard-store/__tests__/actions.test.ts +0 -165
  319. package/plugins/dashboard-store/__tests__/resource-class.test.ts +0 -49
  320. package/plugins/dashboard-store/__tests__/utils/store-mocks.ts +0 -7
  321. package/plugins/index.js +0 -11
  322. package/plugins/steve/__tests__/steve-class.spec.ts +0 -59
  323. package/plugins/steve/__tests__/utils/steve-mocks.ts +0 -31
  324. package/scripts/.gitlab/workflows/build-extension-catalog.gitlab-ci.yml +0 -50
  325. package/server/har-file.js +0 -183
  326. package/tsconfig.paths.json +0 -18
  327. package/utils/azure.js +0 -24
  328. package/utils/clipboard.js +0 -5
  329. /package/components/form/__tests__/{NameNsDescription.test.ts → NameNsDescription.ts} +0 -0
  330. /package/edit/networking.k8s.io.networkpolicy/__tests__/utils/{selectors.test.ts → selectors.ts} +0 -0
  331. /package/edit/provisioning.cattle.io.cluster/{tabs/networking/ACE.vue → ACE.vue} +0 -0
  332. /package/edit/provisioning.cattle.io.cluster/{tabs/AgentConfiguration.vue → AgentConfiguration.vue} +0 -0
  333. /package/edit/provisioning.cattle.io.cluster/{tabs/upgrade/DrainOptions.vue → DrainOptions.vue} +0 -0
  334. /package/edit/provisioning.cattle.io.cluster/{tabs/MemberRoles.vue → MemberRoles.vue} +0 -0
  335. /package/edit/provisioning.cattle.io.cluster/{tabs/registries/RegistryMirrors.vue → RegistryMirrors.vue} +0 -0
  336. /package/edit/provisioning.cattle.io.cluster/{tabs/etcd/S3Config.vue → S3Config.vue} +0 -0
  337. /package/plugins/dashboard-store/__tests__/{getters.test.ts → getters.spec.ts} +0 -0
  338. /package/rancher-components/BadgeState/{BadgeState.spec.ts → BadgeState.test.ts} +0 -0
@@ -1,21 +1,27 @@
1
1
  <script lang="ts">
2
- import Vue, { VueConstructor } from 'vue';
3
- import CompactInput from '@shell/mixins/compact-input';
4
- import LabeledFormElement from '@shell/mixins/labeled-form-element';
2
+ import { defineComponent } from 'vue';
5
3
  import TextAreaAutoGrow from '@components/Form/TextArea/TextAreaAutoGrow.vue';
6
4
  import LabeledTooltip from '@components/LabeledTooltip/LabeledTooltip.vue';
7
5
  import { escapeHtml } from '@shell/utils/string';
8
6
  import cronstrue from 'cronstrue';
9
7
  import { isValidCron } from 'cron-validator';
10
8
  import { debounce } from 'lodash';
9
+ import { useLabeledFormElement, labeledFormElementProps } from '@shell/composables/useLabeledFormElement';
10
+ import { useCompactInput } from '@shell/composables/useCompactInput';
11
11
 
12
- export default (
13
- Vue as VueConstructor<Vue & InstanceType<typeof LabeledFormElement> & InstanceType<typeof CompactInput>>
14
- ).extend({
12
+ declare module 'vue/types/vue' {
13
+ interface Vue {
14
+ onInput: (event: Event) => void | ((event: Event) => void);
15
+ }
16
+ }
17
+
18
+ export default defineComponent({
15
19
  components: { LabeledTooltip, TextAreaAutoGrow },
16
- mixins: [LabeledFormElement, CompactInput],
20
+
21
+ inheritAttrs: false,
17
22
 
18
23
  props: {
24
+ ...labeledFormElementProps,
19
25
  /**
20
26
  * The type of the Labeled Input.
21
27
  * @values text, cron, multiline, multiline-password
@@ -93,21 +99,36 @@ export default (
93
99
  },
94
100
  },
95
101
 
102
+ setup(props, { emit }) {
103
+ const {
104
+ focused,
105
+ onFocusLabeled,
106
+ onBlurLabeled,
107
+ isDisabled,
108
+ validationMessage,
109
+ requiredField
110
+ } = useLabeledFormElement(props, emit);
111
+ const { isCompact } = useCompactInput(props);
112
+
113
+ return {
114
+ focused,
115
+ onFocusLabeled,
116
+ onBlurLabeled,
117
+ isDisabled,
118
+ validationMessage,
119
+ requiredField,
120
+ isCompact,
121
+ };
122
+ },
123
+
96
124
  data() {
97
125
  return {
98
126
  updated: false,
99
- validationErrors: ''
127
+ validationErrors: '',
100
128
  };
101
129
  },
102
130
 
103
131
  computed: {
104
- /**
105
- * Determines if the Labeled Input @input event should be debounced.
106
- */
107
- onInput(): ((value: string) => void) | void {
108
- return this.delay ? debounce(this.delayInput, this.delay) : this.delayInput;
109
- },
110
-
111
132
  /**
112
133
  * Determines if the Labeled Input should display a label.
113
134
  */
@@ -122,7 +143,7 @@ export default (
122
143
  return !!this.tooltip || !!this.tooltipKey;
123
144
  },
124
145
 
125
- tooltipValue(): string | undefined {
146
+ tooltipValue(): string | Record<string, unknown> | undefined {
126
147
  if (this.hasTooltip) {
127
148
  return this.tooltipKey ? this.t(this.tooltipKey) : this.tooltip;
128
149
  }
@@ -144,7 +165,7 @@ export default (
144
165
  if (this.type !== 'cron' || !this.value) {
145
166
  return;
146
167
  }
147
- if (!isValidCron(this.value)) {
168
+ if (typeof this.value === 'string' && !isValidCron(this.value)) {
148
169
  return this.t('generic.invalidCron');
149
170
  }
150
171
  try {
@@ -173,15 +194,22 @@ export default (
173
194
  /**
174
195
  * The max length for the Labeled Input.
175
196
  */
176
- _maxlength(): number | null {
197
+ _maxlength(): number | undefined {
177
198
  if (this.type === 'text' && this.maxlength) {
178
199
  return this.maxlength;
179
200
  }
180
201
 
181
- return null;
202
+ return undefined;
182
203
  },
183
204
  },
184
205
 
206
+ created() {
207
+ /**
208
+ * Determines if the Labeled Input @input event should be debounced.
209
+ */
210
+ this.onInput = this.delay ? debounce(this.delayInput, this.delay) : this.delayInput;
211
+ },
212
+
185
213
  methods: {
186
214
  /**
187
215
  * Attempts to give the Labeled Input focus.
@@ -220,7 +248,9 @@ export default (
220
248
  * NOTE: In multiline, TextAreaAutoGrow emits a string with the value
221
249
  * https://github.com/rancher/dashboard/issues/10249
222
250
  */
223
- delayInput(value: string): void {
251
+ delayInput(val: string | Event): void {
252
+ const value = typeof val === 'string' ? val : (val?.target as HTMLInputElement)?.value;
253
+
224
254
  this.$emit('input', value);
225
255
  },
226
256
 
@@ -237,7 +267,7 @@ export default (
237
267
  * event.
238
268
  * @see labeled-form-element.ts mixin for onBlurLabeled()
239
269
  */
240
- onBlur(event: string): void {
270
+ onBlur(event: string | FocusEvent): void {
241
271
  this.$emit('blur', event);
242
272
  this.onBlurLabeled();
243
273
  },
@@ -289,7 +319,7 @@ export default (
289
319
  :placeholder="_placeholder"
290
320
  autocapitalize="off"
291
321
  :class="{ conceal: type === 'multiline-password' }"
292
- @input="onInput($event)"
322
+ @input="onInput"
293
323
  @focus="onFocus"
294
324
  @blur="onBlur"
295
325
  />
@@ -306,7 +336,7 @@ export default (
306
336
  autocomplete="off"
307
337
  autocapitalize="off"
308
338
  :data-lpignore="ignorePasswordManagers"
309
- @input="onInput($event.target.value)"
339
+ @input="onInput"
310
340
  @focus="onFocus"
311
341
  @blur="onBlur"
312
342
  @change="onChange"
@@ -331,8 +361,9 @@ export default (
331
361
  >{{ cronHint }}</label>
332
362
  <label
333
363
  v-if="subLabel"
364
+ v-clean-html="subLabel"
334
365
  class="sub-label"
335
- >{{ subLabel }}</label>
366
+ />
336
367
  </div>
337
368
  </template>
338
369
  <style scoped lang="scss">
@@ -1,6 +1,5 @@
1
1
  import { shallowMount } from '@vue/test-utils';
2
2
  import { RadioButton } from './index';
3
- import { cleanHtmlDirective } from '@shell/plugins/clean-html-directive';
4
3
 
5
4
  describe('radioButton.vue', () => {
6
5
  it('renders label slot contents', () => {
@@ -13,8 +12,7 @@ describe('radioButton.vue', () => {
13
12
  const wrapper = shallowMount(
14
13
  RadioButton,
15
14
  {
16
- directives: { cleanHtmlDirective },
17
- propsData: {
15
+ propsData: {
18
16
  label: 'Test Label', val: {}, value: {}
19
17
  }
20
18
  });
@@ -1,8 +1,9 @@
1
1
  <script lang="ts">
2
- import Vue from 'vue';
2
+ import { defineComponent } from 'vue';
3
3
  import { _VIEW } from '@shell/config/query-params';
4
+ import { randomStr } from '@shell/utils/string';
4
5
 
5
- export default Vue.extend({
6
+ export default defineComponent({
6
7
  props: {
7
8
  /**
8
9
  * The name of the input, for grouping.
@@ -71,7 +72,10 @@ export default Vue.extend({
71
72
  },
72
73
 
73
74
  data() {
74
- return { isChecked: this.value === this.val };
75
+ return {
76
+ isChecked: this.value === this.val,
77
+ randomString: `${ randomStr() }-radio`,
78
+ };
75
79
  },
76
80
 
77
81
  computed: {
@@ -115,13 +119,15 @@ export default Vue.extend({
115
119
  /**
116
120
  * Emits the input event.
117
121
  */
118
- clicked({ target }: { target?: HTMLElement }) {
119
- if (this.isDisabled || target?.tagName === 'A') {
122
+ clicked(event: MouseEvent | KeyboardEvent) {
123
+ const target = event.target;
124
+
125
+ if (this.isDisabled || (target instanceof HTMLElement && target.tagName === 'A')) {
120
126
  return;
121
127
  }
122
128
 
123
129
  this.$emit('input', this.val);
124
- }
130
+ },
125
131
  }
126
132
  });
127
133
  </script>
@@ -134,7 +140,7 @@ export default Vue.extend({
134
140
  @click.stop="clicked($event)"
135
141
  >
136
142
  <input
137
- :id="_uid+'-radio'"
143
+ :id="randomString"
138
144
  :disabled="isDisabled"
139
145
  :name="name"
140
146
  :value="''+val"
@@ -1,14 +1,15 @@
1
1
  <script lang="ts">
2
- import Vue, { PropType } from 'vue';
2
+ import { PropType, defineComponent } from 'vue';
3
3
  import { _VIEW } from '@shell/config/query-params';
4
4
  import RadioButton from '@components/Form/Radio/RadioButton.vue';
5
5
 
6
6
  interface Option {
7
7
  value: unknown,
8
- label: string
8
+ label: string,
9
+ description?: string,
9
10
  }
10
11
 
11
- export default Vue.extend({
12
+ export default defineComponent({
12
13
  components: { RadioButton },
13
14
  props: {
14
15
  /**
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import Vue from 'vue';
2
+ import { defineComponent } from 'vue';
3
3
  import debounce from 'lodash/debounce';
4
4
  import { _EDIT, _VIEW } from '@shell/config/query-params';
5
5
 
@@ -10,7 +10,7 @@ declare module 'vue/types/vue' {
10
10
  }
11
11
  }
12
12
 
13
- export default Vue.extend({
13
+ export default defineComponent({
14
14
  inheritAttrs: false,
15
15
 
16
16
  props: {
@@ -115,7 +115,9 @@ export default Vue.extend({
115
115
  /**
116
116
  * Emits the input event and resizes the Text Area.
117
117
  */
118
- onInput(val: string): void {
118
+ onInput(event: Event): void {
119
+ const val = (event?.target as HTMLInputElement)?.value;
120
+
119
121
  this.$emit('input', val);
120
122
  this.queueResize();
121
123
  },
@@ -155,7 +157,7 @@ export default Vue.extend({
155
157
  <template>
156
158
  <textarea
157
159
  ref="ta"
158
- data-testid="text-area-auto-grow"
160
+ :data-testid="$attrs['data-testid'] ? $attrs['data-testid'] : 'text-area-auto-grow'"
159
161
  :disabled="isDisabled"
160
162
  :style="style"
161
163
  :placeholder="placeholder"
@@ -163,7 +165,7 @@ export default Vue.extend({
163
165
  v-bind="$attrs"
164
166
  :spellcheck="spellcheck"
165
167
  @paste="$emit('paste', $event)"
166
- @input="onInput($event.target.value)"
168
+ @input="onInput($event)"
167
169
  @focus="$emit('focus', $event)"
168
170
  @blur="$emit('blur', $event)"
169
171
  />
@@ -1,6 +1,9 @@
1
1
  <script lang="ts">
2
- import Vue from 'vue';
3
- export default Vue.extend({
2
+ import { defineComponent } from 'vue';
3
+
4
+ type StateType = boolean | 'true' | 'false' | undefined;
5
+
6
+ export default defineComponent({
4
7
  props: {
5
8
  value: {
6
9
  type: [Boolean, String, Number],
@@ -28,7 +31,7 @@ export default Vue.extend({
28
31
  },
29
32
  },
30
33
  data() {
31
- return { state: false as boolean | string | number };
34
+ return { state: false as StateType };
32
35
  },
33
36
 
34
37
  watch: {
@@ -41,7 +44,7 @@ export default Vue.extend({
41
44
  },
42
45
 
43
46
  methods: {
44
- toggle(neu: boolean | string | number) {
47
+ toggle(neu: StateType | null) {
45
48
  this.state = neu === null ? !this.state : neu;
46
49
  this.$emit('input', this.state ? this.onValue : this.offValue);
47
50
  }
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
- import Vue from 'vue';
2
+ import { defineComponent } from 'vue';
3
3
 
4
- export default Vue.extend({
4
+ export default defineComponent({
5
5
  props: {
6
6
  /**
7
7
  * The Labeled Tooltip value.
@@ -29,9 +29,14 @@ export default Vue.extend({
29
29
  }
30
30
  },
31
31
  computed: {
32
- iconClass() {
32
+ iconClass(): string {
33
33
  return this.status === 'error' ? 'icon-warning' : 'icon-info';
34
34
  }
35
+ },
36
+ methods: {
37
+ isObject(value: string | Record<string, unknown>): value is Record<string, unknown> {
38
+ return typeof value === 'object' && value !== null && !!value.content;
39
+ }
35
40
  }
36
41
  });
37
42
  </script>
@@ -44,7 +49,7 @@ export default Vue.extend({
44
49
  >
45
50
  <template v-if="hover">
46
51
  <i
47
- v-clean-tooltip="value.content ? { ...{content: value.content, classes: [`tooltip-${status}`]}, ...value } : value"
52
+ v-clean-tooltip="isObject(value) ? { ...{content: value.content, classes: [`tooltip-${status}`]}, ...value } : value"
48
53
  :class="{'hover':!value, [iconClass]: true}"
49
54
  class="icon status-icon"
50
55
  />
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import Vue, { PropType } from 'vue';
2
+ import Vue, { PropType, defineComponent } from 'vue';
3
3
 
4
4
  import LabeledInput from '@components/Form/LabeledInput/LabeledInput.vue';
5
5
  import { findStringIndex, hasDuplicatedStrings } from '@shell/utils/array';
@@ -29,7 +29,7 @@ const CLASS = {
29
29
  /**
30
30
  * Manage a list of strings
31
31
  */
32
- export default Vue.extend({
32
+ export default defineComponent({
33
33
 
34
34
  name: 'StringList',
35
35
  components: { LabeledInput },
@@ -92,9 +92,9 @@ export default Vue.extend({
92
92
  },
93
93
  data() {
94
94
  return {
95
- value: null as string | null,
95
+ value: undefined as string | undefined,
96
96
  selected: null as string | null,
97
- editedItem: null as string | null,
97
+ editedItem: undefined as string | undefined,
98
98
  isCreateItem: false,
99
99
  errors: { duplicate: false } as Record<Error, boolean>
100
100
  };
@@ -281,7 +281,7 @@ export default Vue.extend({
281
281
  this.isCreateItem = true;
282
282
  this.setFocus(INPUT.create);
283
283
  } else {
284
- this.value = null;
284
+ this.value = undefined;
285
285
  this.toggleError('duplicate', false);
286
286
  this.onSelectLeave();
287
287
 
@@ -303,11 +303,11 @@ export default Vue.extend({
303
303
  this.editedItem = item || '';
304
304
  this.setFocus(INPUT.edit);
305
305
  } else {
306
- this.value = null;
306
+ this.value = undefined;
307
307
  this.toggleError('duplicate', false);
308
308
  this.onSelectLeave();
309
309
 
310
- this.editedItem = null;
310
+ this.editedItem = undefined;
311
311
  }
312
312
  },
313
313
 
@@ -502,7 +502,7 @@ export default Vue.extend({
502
502
  <button
503
503
  data-testid="button-add"
504
504
  class="btn btn-sm role-tertiary add-button"
505
- :disabled="isCreateItem || editedItem"
505
+ :disabled="!!isCreateItem || !!editedItem"
506
506
  @click.prevent="onClickPlusButton"
507
507
  >
508
508
  <span class="icon icon-plus icon-sm" />
@@ -1,7 +1,8 @@
1
1
  <script lang="ts">
2
- import Vue from 'vue';
2
+ import { defineComponent } from 'vue';
3
3
  import { mapGetters } from 'vuex';
4
- export default Vue.extend({
4
+
5
+ export default defineComponent({
5
6
  props: {
6
7
  title: {
7
8
  type: String,
@@ -0,0 +1,12 @@
1
+ import { shallowMount } from '@vue/test-utils';
2
+ import { BadgeState } from './index';
3
+
4
+ describe('BadgeState.vue', () => {
5
+ it('renders props.msg when passed', () => {
6
+ const label = 'Hello, World!';
7
+
8
+ const wrapper = shallowMount(BadgeState, { propsData: { label } });
9
+
10
+ expect(wrapper.find('span').text()).toMatch(label);
11
+ });
12
+ });
@@ -1,3 +1,4 @@
1
+
1
2
  import { mount } from '@vue/test-utils';
2
3
  import { LabeledInput } from './index';
3
4
 
@@ -5,7 +6,7 @@ describe('component: LabeledInput', () => {
5
6
  it('should emit input only once', () => {
6
7
  const value = '2';
7
8
  const delay = 1;
8
- const wrapper = mount(LabeledInput as any, {
9
+ const wrapper = mount(LabeledInput, {
9
10
  propsData: { delay },
10
11
  mocks: { $store: { getters: { 'i18n/t': jest.fn() } } }
11
12
  });
@@ -19,22 +20,4 @@ describe('component: LabeledInput', () => {
19
20
  expect(wrapper.emitted('input')).toHaveLength(1);
20
21
  expect(wrapper.emitted('input')![0][0]).toBe(value);
21
22
  });
22
-
23
- it('using mode "multiline" should emit input value correctly', () => {
24
- const value = 'any-string';
25
- const delay = 1;
26
- const wrapper = mount(LabeledInput as any, {
27
- propsData: { delay, multiline: true },
28
- mocks: { $store: { getters: { 'i18n/t': jest.fn() } } }
29
- });
30
-
31
- jest.useFakeTimers();
32
- wrapper.find('input').setValue('1');
33
- wrapper.find('input').setValue(value);
34
- jest.advanceTimersByTime(delay);
35
- jest.useRealTimers();
36
-
37
- expect(wrapper.emitted('input')).toHaveLength(1);
38
- expect(wrapper.emitted('input')![0][0]).toBe(value);
39
- });
40
23
  });
@@ -90,7 +90,7 @@ export default (
90
90
  delay: {
91
91
  type: Number,
92
92
  default: 0
93
- },
93
+ }
94
94
  },
95
95
 
96
96
  data() {
@@ -216,9 +216,6 @@ export default (
216
216
  /**
217
217
  * Emit on input with delay. Note: Arrow function is avoided due context
218
218
  * binding.
219
- *
220
- * NOTE: In multiline, TextAreaAutoGrow emits a string with the value
221
- * https://github.com/rancher/dashboard/issues/10249
222
219
  */
223
220
  delayInput(value: string): void {
224
221
  this.$emit('input', value);
@@ -325,14 +322,20 @@ export default (
325
322
  :hover="hoverTooltip"
326
323
  :value="validationMessage"
327
324
  />
328
- <label
329
- v-if="cronHint"
330
- class="cron-label"
331
- >{{ cronHint }}</label>
332
- <label
333
- v-if="subLabel"
325
+ <div
326
+ v-if="cronHint || subLabel"
334
327
  class="sub-label"
335
- >{{ subLabel }}</label>
328
+ >
329
+ <div
330
+ v-if="cronHint"
331
+ >
332
+ {{ cronHint }}
333
+ </div>
334
+ <div
335
+ v-if="subLabel"
336
+ v-clean-html="subLabel"
337
+ />
338
+ </div>
336
339
  </div>
337
340
  </template>
338
341
  <style scoped lang="scss">
@@ -155,7 +155,7 @@ export default Vue.extend({
155
155
  <template>
156
156
  <textarea
157
157
  ref="ta"
158
- data-testid="text-area-auto-grow"
158
+ :data-testid="$attrs['data-testid'] ? $attrs['data-testid'] : 'text-area-auto-grow'"
159
159
  :disabled="isDisabled"
160
160
  :style="style"
161
161
  :placeholder="placeholder"