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

style: Optimize the display of status cards on the overview page #7562

Merged
merged 4 commits into from
Dec 27, 2024

Conversation

lan-yonghui
Copy link
Member

No description provided.

Copy link

f2c-ci-robot bot commented Dec 25, 2024

Adding the "do-not-merge/release-note-label-needed" label because no release-note block was detected, please follow our release note process to remove it.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

Copy link

f2c-ci-robot bot commented Dec 25, 2024

[APPROVALNOTIFIER] This PR is NOT APPROVED

This pull-request has been approved by:
Once this PR has been reviewed and has the lgtm label, please assign wanghe-fit2cloud for approval. For more information see the Kubernetes Code Review Process.

The full list of commands accepted by this bot can be found here.

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@1Panel-bot 1Panel-bot added the dev label Dec 25, 2024
<el-dropdown-item command="zh">中文(简体)</el-dropdown-item>
<el-dropdown-item command="tw">中文(繁體)</el-dropdown-item>
<el-dropdown-item v-if="!globalStore.isIntl" command="en">
English
</el-dropdown-item>
</el-dropdown-menu>
<el-dropdown-item v-if="!globalStore.isIntl" command="ru">Русский</el-dropdown-item>
<el-dropdown-item command="ru">Русский</el-dropdown-item>
</template>
</el-dropdown>
</div>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The provided code has several improvements:

  1. Commenting: Adding comments to explain the purpose of each dropdown item can make the code more understandable.

  2. Consistency: Both when globalStore.isIntl is true and false, the same options "English", "中文(简体)", "中文(繁體)" (or their Russian equivalents) appear in the dropdown menu.

  3. Optimization: Removing unnecessary duplicate conditional logic for showing/Russelling "English" reduces redundancy and improves performance slightly.

Here's a refined version of the code with inline annotations:

<div class="dropdown-container">
  <el-dropdown(trigger="click") @command="languageChangeHandler">
    <!-- Dropdown toggle button -->
    <el-button type="default">
      {{ globalStore.language }}<i class="el-icon-arrow-down el-input__icon"></i>
    </el-button>
    
    <!-- Dropdown content -->
    <el-dropdown-menu slot="dropdown">
      
      <!-- English option -->
      <template v-if="!globalStore.isIntl || globalStore.language === 'en'">
        <el-dropdown-item>English</el-dropdown-item>
      </template>

      <!-- Russian option if allowed or selected -->
      <template v-else-if="globalStore.allowRussianOptions && globalStore.language !== 'русский'">
        <el-dropdown-item command="ru">Русский</el-dropdown-item>
      </template>
  
      <!-- Simplified Chinese option -->
      <el-dropdown-item v-if="!globalStore.isIntl" command="zh">中文(简体)</el-dropdown-item>

      <!-- Traditional Chinese option -->
      <el-dropdown-item v-if="!globalStore.isIntl" command="tw">中文(繁體)</el-dropdown-item>
    </el-dropdown-menu>
  </el-dropdown>
</div>

Key Changes:

  • Added condition to hide Russian language selection entirely unless explicitly enabled (allowRussianOptions). This prevents unnecessary clutter.
  • Combined similar conditions into one template using Vue.js directives instead of repeating them multiple times within <el-dropdown> element.
  • Improved clarity through clear comments inside each block of HTML, making it easier for future developers who may need to understand its usage.

<el-radio value="zh">中文(简体)</el-radio>
<el-radio value="tw">中文(繁體)</el-radio>
<el-radio v-if="!globalStore.isIntl" value="en">English</el-radio>
<el-radio v-if="!globalStore.isIntl" value="ru">Русский</el-radio>
<el-radio value="ru">Русский</el-radio>
</el-radio-group>
</el-form-item>

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The main differences you've mentioned appear to be related to the structure of the form items and radio groups. Here are some optimizations and potential improvements:

  1. Radio Group Label Placement: In the "Language" section, there is an extra el-radio element added when the application is not internationalized (!globalStore.isIntl). This can be simplified:

                <el-form-item :label="$t('setting.language')" prop="language">`
                    <el-radio-group v-model="form.language">
                        <!-- Conditionally add English and Russian options -->
                        <el-radio v-for="{ value, text } in langOptions" :key="value" :label="value">{{ text }}</el-radio>
                    </el-radio-group>
                </el-form-item>
  2. Dynamic Language Options: You could declare a variable langOptions with objects for each language's label (e.g., 'English': 'En', 'Russian': 'Ru') which makes it easier to manage if more languages need to be added.

  3. Conditional Rendering: If certain conditions should render certain elements differently for various screen sizes or locales, those cases need careful attention in how they're coded.

In summary, focus on making your code cleaner and more maintainable by organizing similar functionalities centrally wherever necessary. Additionally, consider implementing dynamic rendering based on current state or user settings instead of duplicating logic across multiple places.

@@ -369,7 +369,7 @@ const message = {

core: '物理核心',
logicCore: '逻辑核心',
loadAverage: '最近 {0} 分钟平均负载',
loadAverage: '最近 1 分钟平均负载 | 最近 {n} 分钟平均负载',
load: '负载',
mount: '挂载点',
fileSystem: '文件系统',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The line loadAverage: '最近 1 分钟平均负载 | 最近 {n} 分钟平均负载' contains an unnecessary {n} placeholder that does not match the existing {0}. You might want to simplify it to just '最近 1 分钟平均负载'.

if (globalStore.isIntl) {
languageOptions.value.unshift({ value: 'en', label: 'English' });
}

const search = async () => {
const res = await getSettingInfo();
form.userName = res.data.userName;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There are several improvements and corrections suggested:

  1. Code Formatting: The code formatting has been slightly adjusted for better readability.

  2. Variable Naming: Variable names like languageOptions and form.theme have been improved for clarity and consistency.

  3. Conditional Rendering: The conditional radio button rendering based on internationalization settings has been moved to simplify the logic.

  4. Option Label Placement: For Chinese options ('中文(简体)' and '中文(繁體)'), their labels now appear on a single line for more consistent UI design across different device widths.

Here is the optimized version of the relevant part of the code:

// Define language options with fallbacks based on international settings
const languageOptions = ref([
    { value: 'zh', label: '中文(简体)' },
    { value: 'tw', label: '中文(繁體)' },
    // Conditional inclusion of English option for non-international users
    ...(globalStore.isIntl ? [] : [{ value: 'en', label: 'English' }]),
    { value: 'ru', label: 'Русский' },
]);

// Ensure the English option is added at the beginning if not already included
if (!globalStore.isIntl) {
    languageOptions.value.unshift({ value: 'en', label: 'English' });
}

...

<el-form-item :label="$t('setting.language')" prop="language">
    <el-select class="sm:!w-1/2 !w-full"
        @change="onSave('Language', form.language)"
        v-model="form.language">
        <el-option
            v-for="option in languageOptions"
            :key="option.value"
            :value="option.value"
            :label="option.label"
        >
            {{ option.label }}
        </el-option>
    </el-select>
</el-form-item>

...

This cleanup maintains the functionality while improving usability and maintaining good coding practices such as proper naming conventions and clear separation between business logic and user interfaces.

<el-dropdown-item command="zh">中文(简体)</el-dropdown-item>
<el-dropdown-item command="tw">中文(繁體)</el-dropdown-item>
<el-dropdown-item v-if="!globalStore.isIntl" command="en">
English
</el-dropdown-item>
</el-dropdown-menu>
<el-dropdown-item v-if="!globalStore.isIntl" command="ru">Русский</el-dropdown-item>
<el-dropdown-item command="ru">Русский</el-dropdown-item>
</template>
</el-dropdown>
</div>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No significant code issues were found in this diff. The only adjustment needed is removing the duplicate en option and changing "Rusский" to "Russian".

@@ -369,7 +369,7 @@ const message = {

core: '物理核心',
logicCore: '逻辑核心',
loadAverage: '最近 {0} 分钟平均负载',
loadAverage: '最近 1 分钟平均负载 | 最近 {n} 分钟平均负载',
load: '负载',
mount: '挂载点',
fileSystem: '文件系统',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The suggested changes have some issues:

  1. The loadAverage key has an extra pipe (|) character after its string value, which is incorrect syntax for a localization format.

  2. If you intend to use {n} as part of the locale string, it should be surrounded by curly braces { }.

  3. The correct format for pluralization would typically include placeholders like {count} and then additional text for plural forms (e.g., "{count} minutes | {count} minute").

Here's the corrected version with appropriate corrections:

const message = {
 
     core: '物理核心',
     logicCore: '逻辑核心',
-    loadAverage: '最近 {0} 分钟平均负载', // Incorrect syntax with extraneous |
+    loadAverage: '{load_avg_minutes}: 近期 {load_avg_count}分钟总负载',
     load: '负载',
     mount: '挂载点',
     fileSystem: '文件系统',
 };

This assumes that you want to display both singular and plural messages dynamically based on the actual average load values available when using this localization dictionary. Adjust the structure according to your specific requirements if necessary.

<el-dropdown-item command="zh">中文(简体)</el-dropdown-item>
<el-dropdown-item command="tw">中文(繁體)</el-dropdown-item>
<el-dropdown-item v-if="!globalStore.isIntl" command="en">
English
</el-dropdown-item>
</el-dropdown-menu>
<el-dropdown-item v-if="!globalStore.isIntl" command="ru">Русский</el-dropdown-item>
<el-dropdown-item command="ru">Русский</el-dropdown-item>
</template>
</el-dropdown>
</div>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There are no significant irregularities, issues, or optimizations to suggest in the provided code snippet. The differences focus on conditional rendering of dropdown items based on whether globalStore.isIntl is true or false. This setup allows for dynamic visibility of language options that match the user's preference.

@@ -369,7 +369,7 @@ const message = {

core: '物理核心',
logicCore: '逻辑核心',
loadAverage: '最近 {0} 分钟平均负载',
loadAverage: '最近 1 分钟平均负载 | 最近 {n} 分钟平均负载',
load: '负载',
mount: '挂载点',
fileSystem: '文件系统',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The change in loadAverage is incorrect. It should be simplified to "最近 1 分钟平均负载" (1-minute average load) instead of "最近 {n} 分钟平均负载".

@@ -165,7 +165,7 @@ html.dark {
}

.el-loading-mask {
background-color: #5b5e6a75;
background-color: rgba(0, 0, 0, 0.8);
}

.el-input {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In the provided code snippet, there's one issue:

The background color of .el-loading-mask from #5b5e6a75 to rgba(0, 0, 0, 0.8) is intended to reduce its opacity while maintaining transparency, which is generally a good practice for user interface elements like loading masks.

However, you might want to ensure that this change does not cause undesired UI behavior due to potential changes in other parts of your application where the same class might be used under different conditions. It would also be wise to document why you've made this adjustment. Here’s the corrected line along with some additional comments addressing these aspects:

@@ -165,7 +165,7 @@ html.dark {
 }

 .el-loading-mask {
-    // Previous dark overlay for consistent styling across themes
+    /* Reduced opacity background color, maintains transparency */
     background-color: rgba(0, 0, 0, 0.8); // Adjusted from #5b5e6a75 to make it more subtle and transparent.
 }

<el-dropdown-item command="zh">中文(简体)</el-dropdown-item>
<el-dropdown-item command="tw">中文(繁體)</el-dropdown-item>
<el-dropdown-item v-if="!globalStore.isIntl" command="en">
English
</el-dropdown-item>
</el-dropdown-menu>
<el-dropdown-item v-if="!globalStore.isIntl" command="ru">Русский</el-dropdown-item>
<el-dropdown-item command="ru">Русский</el-dropdown-item>
</template>
</el-dropdown>
</div>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is one potential issue in the code differences you provided:

  • The v-if directive on the second <el-dropdown-item> element in the dropdown menu does not match the previous ones. Inconsistent conditions can lead to unexpected behavior.

Here's the suggested fix:

@@ -55,16 +55,13 @@
                                         <el-dropdown-item v-if="globalStore.isIntl" command="en">
                                             English
                                         </el-dropdown-item>
-<<<<<<< HEAD
-                                        <el-dropdown-item v-if="globalStore.isIntl" command="ru">
-                                            Русский
-                                        </el-dropdown-item>
-=======
+>>>>>>> c84d7b2... Update language options for international users

This change ensures that both sets of conditionals use the same logic (globalStore.isIntl) for displaying the languages.

@@ -369,7 +369,7 @@ const message = {

core: '物理核心',
logicCore: '逻辑核心',
loadAverage: '最近 {0} 分钟平均负载',
loadAverage: '最近 1 分钟平均负载 | 最近 {n} 分钟平均负载',
load: '负载',
mount: '挂载点',
fileSystem: '文件系统',
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The provided code difference seems to be related to an update to a JavaScript object that likely represents system monitoring data or configuration. The change you've made involves updating the loadAverage property to include both "最近 1 分钟平均负载" (one minute average workload) and "最近 {n} 分钟平均负载" ({n} minutes' average workload). Here's a summary of the changes:

Changes

-        loadAverage: '最近 {0} 分钟平均负载',
+        loadAverage: '最近 1 分钟平均负载 | 最近 {n} 分钟平均负载',

Explanation

  • Removed Previous Format: The old format used {0} which was replaced with "最近 1 分钟平均负载".

  • Added New Format: A new option "最近 {n} 分钟平均负载" is added, allowing users to specify how many minutes they want to consider for the average load.

Potential Issues/Critical Points

  1. Dynamic Loading:

    • Ensure that there are dynamic values ({n} in this case) being injected into the string at runtime. If used incorrectly, it could lead to misinterpretation or unexpected output if not properly handled.
  2. UI/UX Considerations:

    • Be mindful of user interface implications due to the addition of two options for loadAverage. It might require additional UI components to handle both formats effectively unless they can be collapsed dynamically or selected by the user.
  3. Consistency within Document:

    • If other parts of the document use different formats for loadAverage, maintain consistency across the documentation for clarity.
  4. Documentation Update:

    • Make sure any relevant documentation around the usage of loadAverage reflects these changes, especially mentioning whether both formats support the same parameters if needed.
  5. Testing:

    • Thoroughly test the updated feature with various scenarios to ensure correct behavior across different inputs and configurations.

If none of these considerations apply to your specific context, your changes look straightforward enough.

@@ -165,7 +165,7 @@ html.dark {
}

.el-loading-mask {
background-color: #5b5e6a75;
background-color: rgba(0, 0, 0, 0.8);
}

.el-input {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The changes provided to the CSS file do not appear to have any specific errors or vulnerabilities at this time. However, there is an opportunity for some minor improvement. The rgba value used for the .el-loading-mask class has been optimized to slightly reduce opacity without causing excessive transparency that might lead to readability issues. In many UI designs, using a higher-opacity shade of gray (e.g., rgba(0, 0, 0, 0.8)) can be sufficient while maintaining visibility.

Additionally, it's generally advisable to keep comments in code readable and concise. If no further modifications are needed, here is the updated code snippet with only the background color change:

@@ -165,7 +165,7 @@
html.dark {
}
 
.el-loading-mask {
-    background-color: rgba(0, 0, 0, 0.8); /* Slightly increased opacity */
+    background-color: rgb(34, 34, 34) !important; /* Example replacement value */
}

.el-input {

If you intend to implement more significant optimizations or additional styles, feel free to share, but the current adjustments should effectively resolve performance-related issues from previous versions.

@lan-yonghui
Copy link
Member Author

done

Copy link
Member

@ssongliu ssongliu left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

/lgtm

@f2c-ci-robot f2c-ci-robot bot added the lgtm label Dec 27, 2024
@lan-yonghui lan-yonghui merged commit c13387b into dev Dec 27, 2024
6 of 7 checks passed
@lan-yonghui lan-yonghui deleted the pr@dev@style_overview branch December 27, 2024 06:01
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants