3db9f11c37
* Extend variables under the nomad path prefix to allow for job-templates (#15570) * Extend variables under the nomad path prefix to allow for job-templates * Add job-templates to error message hinting * RadioCard component for Job Templates (#15582) * chore: add * test: component API * ui: component template * refact: remove bc naming collission * styles: remove SASS var causing conflicts * Disallow specific variable at nomad/job-templates (#15681) * Disallows variables at exactly nomad/job-templates * idiomatic refactor * Expanding nomad job init to accept a template flag (#15571) * Adding a string flag for templates on job init * data-down actions-up version of a custom template editor within variable * Dont force grid on job template editor * list-templates flag started * Correctly slice from end of path name * Pre-review cleanup * Variable form acceptance test for job template editing * Some review cleanup * List Job templates test * Example from template test * Using must.assertions instead of require etc * ui: add choose template button (#15596) * ui: add new routes * chore: update file directory * ui: add choose template button * test: button and page navigation * refact: update var name * ui: use `Button` component from `HDS` (#15607) * ui: integrate buttons * refact: remove helper * ui: remove icons on non-tertiary buttons * refact: update normalize method for key/value pairs (#15612) * `revert`: `onCancel` for `JobDefinition` The `onCancel` method isn't included in the component API for `JobEditor` and the primary cancel behavior exists outside of the component. With the exception of the `JobDefinition` page where we include this button in the top right of the component instead of next to the `Plan` button. * style: increase button size * style: keep lime green * ui: select template (#15613) * ui: deprecate unused component * ui: deprecate tests * ui: jobs.run.templates.index * ui: update logic to handle templates * refact: revert key/value changes * style: padding for cards + buttons * temp: fixtures for mirage testing * Revert "refact: revert key/value changes" This reverts commit 124e95d12140be38fc921f7e15243034092c4063. * ui: guard template for unsaved job * ui: handle reading template variable * Revert "refact: update normalize method for key/value pairs (#15612)" This reverts commit 6f5ffc9b610702aee7c47fbff742cc81f819ab74. * revert: remove test fixtures * revert: prettier problems * refact: test doesnt need filter expression * styling: button sizes and responsive cards * refact: remove route guarding * ui: update variable adapter * refact: remove model editing behavior * refact: model should query variables to populate editor * ui: clear qp on exit * refact: cleanup deprecated API * refact: query all namespaces * refact: deprecate action * ui: rely on collection * refact: patch deprecate transition API * refact: patch test to expect namespace qp * styling: padding, conditionals * ui: flashMessage on 404 * test: update for o(n+1) query * ui: create new job template (#15744) * refact: remove unused code * refact: add type safety * test: select template flow * test: add data-test attrs * chore: remove dead code * test: create new job flow * ui: add create button * ui: create job template * refact: no need for wildcard * refact: record instead of delete * styling: spacing * ui: add error handling and form validation to job create template (#15767) * ui: handle server side errors * ui: show error to prevent duplicate * refact: conditional namespace * ui: save as template flow (#15787) * bug: patches failing tests associated with `pretender` (#15812) * refact: update assertion * refact: test set-up * ui: job templates manager view (#15815) * ui: manager list view * test: edit flow * refact: deprecate column-helper * ui: template edit and delete flow (#15823) * ui: manager list view * refact: update title * refact: update permissions * ui: template edit page * bug: typo * refact: update toast messages * bug: clear selections on exit (#15827) * bug: clear controllers on exit * test: mirage config changes (#15828) * refact: deprecate column-helper * style: update z-index for HDS * Revert "style: update z-index for HDS" This reverts commit d3d87ceab6d083f7164941587448607838944fc1. * refact: update delete button * refact: edit redirect * refact: patch reactivity issues * styling: fixed width * refact: override defaults * styling: edit text causing overflow * styling: add inline text Co-authored-by: Phil Renaud <phil.renaud@hashicorp.com> * bug: edit `text` to `template` Co-authored-by: Phil Renaud <phil.renaud@hashicorp.com> Co-authored-by: Phil Renaud <phil.renaud@hashicorp.com> * test: delete flow job templates (#15896) * refact: edit names * bug: set correct ref to store * chore: trim whitespace: * test: delete flow * bug: reactively update view (#15904) * Initialized default jobs (#15856) * Initialized default jobs * More jobs scaffolded * Better commenting on a couple example job specs * Adapter doing the work * fall back to epic config * Label format helper and custom serialization logic * Test updates to account for a never-empty state * Test suite uses settled and maintain RecordArray in adapter return * Updates to hello-world and variables example jobspecs * Parameterized job gets optional payload output * Formatting changes for param and service discovery job templates * Multi-group service discovery job * Basic test for default templates (#15965) * Basic test for default templates * Percy snapshot for manage page * Some late-breaking design changes * Some copy edits to the header paragraphs for job templates (#15967) * Added some init options for job templates (#15994) * Async method for populating default job templates from the variable adapter --------- Co-authored-by: Jai <41024828+ChaiWithJai@users.noreply.github.com>
213 lines
4.1 KiB
SCSS
213 lines
4.1 KiB
SCSS
.ember-power-select-trigger,
|
|
.dropdown-trigger {
|
|
position: relative;
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 0.375em 16px 0.375em 0.3em;
|
|
line-height: 1;
|
|
border-radius: $radius;
|
|
box-shadow: $button-box-shadow-standard;
|
|
background: $white-bis;
|
|
border: 1px solid $grey-light;
|
|
height: 2.25em;
|
|
font-size: 1rem;
|
|
outline: none;
|
|
cursor: pointer;
|
|
|
|
&:focus {
|
|
box-shadow: $button-box-shadow-standard, inset 0 0 0 2px $grey-lighter;
|
|
}
|
|
|
|
&.is-outlined {
|
|
border-color: rgba($white, 0.5);
|
|
color: $white;
|
|
background: transparent;
|
|
box-shadow: $button-box-shadow-standard, 0 0 2px 2px rgba($black, 0.1);
|
|
|
|
.ember-power-select-status-icon {
|
|
border-top-color: rgba($white, 0.75);
|
|
}
|
|
|
|
.ember-power-select-prefix {
|
|
color: rgba($white, 0.75);
|
|
}
|
|
}
|
|
|
|
&.is-compact {
|
|
margin: -0.25em 0;
|
|
|
|
&.pull-right {
|
|
margin-right: -1em;
|
|
}
|
|
|
|
&.pull-left {
|
|
margin-left: -1em;
|
|
}
|
|
}
|
|
}
|
|
|
|
.button-bar {
|
|
display: inline-flex;
|
|
flex-direction: row;
|
|
box-shadow: $button-box-shadow-standard;
|
|
|
|
.dropdown,
|
|
.button {
|
|
display: flex;
|
|
position: relative;
|
|
|
|
& + .dropdown,
|
|
& + .button {
|
|
margin-left: -1px;
|
|
}
|
|
}
|
|
|
|
.ember-power-select-trigger,
|
|
.dropdown-trigger,
|
|
.button {
|
|
border-radius: 0;
|
|
box-shadow: none;
|
|
|
|
&:focus {
|
|
box-shadow: inset 0 0 0 2px $grey-lighter;
|
|
}
|
|
}
|
|
|
|
// Buttons have their own focus treatment that needs to be overrided here.
|
|
// Since .button.is-color takes precedence over .button-bar .button, each
|
|
// color needs the override.
|
|
.button {
|
|
@each $name, $pair in $colors {
|
|
&.is-#{$name}:focus {
|
|
box-shadow: inset 0 0 0 2px $grey-lighter;
|
|
}
|
|
}
|
|
}
|
|
|
|
.dropdown:first-child .ember-power-select-trigger,
|
|
.dropdown:first-child .dropdown-trigger,
|
|
.button:first-child {
|
|
border-top-left-radius: $radius;
|
|
border-bottom-left-radius: $radius;
|
|
}
|
|
|
|
.dropdown:last-child .ember-power-select-trigger,
|
|
.dropdown:last-child .dropdown-trigger,
|
|
.button:last-child {
|
|
border-top-right-radius: $radius;
|
|
border-bottom-right-radius: $radius;
|
|
}
|
|
|
|
&.is-shadowless {
|
|
box-shadow: none;
|
|
}
|
|
|
|
// Used to minimize any extra height the buttons would add to an otherwise
|
|
// text only container.
|
|
&.is-text {
|
|
margin-top: -0.5em;
|
|
margin-bottom: -0.5em;
|
|
vertical-align: middle;
|
|
}
|
|
}
|
|
|
|
.ember-power-select-selected-item,
|
|
.dropdown-trigger-label {
|
|
margin-left: 8px;
|
|
margin-right: 8px;
|
|
display: inline-block;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.ember-power-select-selected-item,
|
|
.dropdown-item {
|
|
text-overflow: ellipsis;
|
|
overflow: hidden;
|
|
white-space: nowrap;
|
|
}
|
|
|
|
.ember-power-select-prefix,
|
|
.dropdown-prefix {
|
|
color: $grey;
|
|
}
|
|
|
|
.ember-power-select-option,
|
|
.dropdown-option {
|
|
.ember-power-select-prefix,
|
|
.dropdown-prefix {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
.dropdown-options,
|
|
.ember-power-select-options {
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
// Bulma override
|
|
.menu-list li ul.ember-power-select-options {
|
|
margin: 0;
|
|
padding: 0;
|
|
}
|
|
|
|
.dropdown-options {
|
|
border: 1px solid $grey-light;
|
|
margin-top: -1px;
|
|
max-height: 400px;
|
|
overflow: auto;
|
|
|
|
& > ul {
|
|
width: 100%;
|
|
}
|
|
|
|
// ember-power-select@v4.1.3: There is currently no way to set a class
|
|
// on an individual option, so .ember-power-select-option must be included
|
|
// in these selectors.
|
|
.dropdown-option,
|
|
.ember-power-select-option {
|
|
margin: 0;
|
|
padding: 0;
|
|
white-space: nowrap;
|
|
line-height: 1.75;
|
|
|
|
label,
|
|
.dropdown-label {
|
|
display: block;
|
|
padding: 3px 8px;
|
|
min-width: 100px;
|
|
cursor: pointer;
|
|
}
|
|
|
|
& + .dropdown-option,
|
|
& + .ember-power-select-option {
|
|
border-top: 1px solid $grey-lighter;
|
|
}
|
|
|
|
&:hover,
|
|
&:focus,
|
|
&[aria-current='true'],
|
|
&[aria-selected='true'] {
|
|
background: $white-bis;
|
|
color: $black;
|
|
outline: none;
|
|
border-left: 2px solid $blue;
|
|
label,
|
|
.dropdown-label {
|
|
padding-left: 6px;
|
|
min-width: 98px;
|
|
}
|
|
}
|
|
|
|
&[aria-selected='true'] {
|
|
background: $blue-050;
|
|
}
|
|
}
|
|
|
|
.dropdown-empty {
|
|
display: block;
|
|
padding: 8px 12px;
|
|
color: $grey-light;
|
|
}
|
|
}
|