Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactor anchor tags that behave as buttons #13174

Open
rak-phillip opened this issue Jan 21, 2025 · 1 comment
Open

Refactor anchor tags that behave as buttons #13174

rak-phillip opened this issue Jan 21, 2025 · 1 comment
Labels
QA/dev-automation Issues that engineers have written automation around so QA doesn't have look at this research-needed Label for design issue that requires more technical research than what is in the issue description

Comments

@rak-phillip
Copy link
Member

rak-phillip commented Jan 21, 2025

There are several links that are displayed as buttons used throughout Rancher Dashboard. These links require special care to ensure that they behave in a way that a user would expect a button to behave. Requiring developers to take these edge cases into consideration opens the door to inconsistent behavior, as individual implementations can differ.

Notes

The following code snippets are good candidates for review. Both anchor tags and router-link can display as a button:

  • <a
    class="hand mr-20"
    tabindex="0"
    :aria-label="t('landing.landingPrefs.userPrefs')"
    @click.prevent.stop="showUserPrefs"
    @keyup.prevent.stop.enter="showUserPrefs"
    @keyup.prevent.stop.space="showUserPrefs"
    ><span v-clean-html="t('landing.landingPrefs.userPrefs')" /></a>
  • <router-link
    v-if="!!provClusterSchema"
    :to="manageLocation"
    class="btn btn-sm role-secondary"
    data-testid="cluster-management-manage-button"
    role="button"
    :aria-label="t('cluster.manageAction')"
    @keyup.space="$router.push(manageLocation)"
    >
    {{ t('cluster.manageAction') }}
    </router-link>
    <router-link
    v-if="canCreateCluster"
    :to="importLocation"
    class="btn btn-sm role-primary"
    data-testid="cluster-create-import-button"
    role="button"
    :aria-label="t('cluster.importAction')"
    @keyup.space="$router.push(importLocation)"
    >
    {{ t('cluster.importAction') }}
    </router-link>
    <router-link
    v-if="canCreateCluster"
    :to="createLocation"
    class="btn btn-sm role-primary"
    data-testid="cluster-create-button"
    role="button"
    :aria-label="t('generic.create')"
    @keyup.space="$router.push(createLocation)"
    >
    {{ t('generic.create') }}
    </router-link>
  • <router-link
    :to="{ name: 'diagnostic' }"
    class="btn role-primary"
    data-testid="about__diagnostics_button"
    role="button"
    :aria-label="t('about.diagnostic.title')"
    @keyup.space="$router.push({ name: 'diagnostic' })"
    >
    {{ t('about.diagnostic.title') }}
    </router-link>
@github-actions github-actions bot added the QA/dev-automation Issues that engineers have written automation around so QA doesn't have look at this label Jan 21, 2025
@richard-cox
Copy link
Member

We should look at each case, and maybe work with UX on this. Thinking specifically about buttons that only navigate the user to a new area (and not execute an action and then move the user). In those places right click --> open in new tab should continue to work.

@rak-phillip rak-phillip added the research-needed Label for design issue that requires more technical research than what is in the issue description label Jan 22, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
QA/dev-automation Issues that engineers have written automation around so QA doesn't have look at this research-needed Label for design issue that requires more technical research than what is in the issue description
Projects
None yet
Development

No branches or pull requests

2 participants