refactor: br id
This commit is contained in:
parent
db10c7619c
commit
55f26b3758
2 changed files with 41 additions and 10 deletions
|
|
@ -1,7 +1,7 @@
|
|||
<script setup lang="ts">
|
||||
import useUserStore from 'stores/user';
|
||||
import { selectFilterOptionRefMod } from 'stores/utils';
|
||||
import { onMounted, ref } from 'vue';
|
||||
import { onMounted, ref, watch } from 'vue';
|
||||
import { useI18n } from 'vue-i18n';
|
||||
import { isRoleInclude } from 'src/stores/utils';
|
||||
|
||||
|
|
@ -15,7 +15,7 @@ const userRole = defineModel<string>('userRole');
|
|||
const username = defineModel<string | null | undefined>('username');
|
||||
const userCode = defineModel<string>('userCode');
|
||||
|
||||
defineProps<{
|
||||
const props = defineProps<{
|
||||
title?: string;
|
||||
dense?: boolean;
|
||||
outlined?: boolean;
|
||||
|
|
@ -73,9 +73,33 @@ const roleFilter = selectFilterOptionRefMod(
|
|||
);
|
||||
|
||||
onMounted(async () => {
|
||||
if (userStore.userOption.hqOpts[0].value)
|
||||
if (userStore.userOption.hqOpts[0].value && !props.readonly) {
|
||||
await userStore.fetchBrOption(userStore.userOption.hqOpts[0].value);
|
||||
if (userStore.userOption.brOpts.length === 1) {
|
||||
brId.value = userStore.userOption.brOpts[0].value;
|
||||
}
|
||||
brFilter = selectFilterOptionRefMod(
|
||||
ref(userStore.userOption.brOpts),
|
||||
brOptions,
|
||||
'label',
|
||||
);
|
||||
}
|
||||
});
|
||||
|
||||
watch(
|
||||
() => hqId.value,
|
||||
async (v) => {
|
||||
if (v) {
|
||||
userStore.userOption.brOpts = [];
|
||||
await userStore.fetchBrOption(v);
|
||||
brFilter = selectFilterOptionRefMod(
|
||||
ref(userStore.userOption.brOpts),
|
||||
brOptions,
|
||||
'label',
|
||||
);
|
||||
}
|
||||
},
|
||||
);
|
||||
</script>
|
||||
<template>
|
||||
<div class="row col-12">
|
||||
|
|
@ -261,7 +285,7 @@ onMounted(async () => {
|
|||
</q-item>
|
||||
</template>
|
||||
</q-select>
|
||||
<!-- <q-input
|
||||
<!-- <q-input
|
||||
id="input-user-code"
|
||||
:dense="dense"
|
||||
:outlined="readonly ? false : outlined"
|
||||
|
|
|
|||
|
|
@ -59,12 +59,19 @@ const useUserStore = defineStore('api-user', () => {
|
|||
const res = await branchStore.fetchById(id, {
|
||||
includeSubBranch: true,
|
||||
});
|
||||
if (res && res?.branch) {
|
||||
res.branch.map((item) => {
|
||||
userOption.value.brOpts.push({
|
||||
label: item.code,
|
||||
value: item.id,
|
||||
});
|
||||
|
||||
if (res && res.branch) {
|
||||
res.branch.forEach((item) => {
|
||||
const exists = userOption.value.brOpts.some(
|
||||
(opt) => opt.value === item.id,
|
||||
);
|
||||
|
||||
if (!exists) {
|
||||
userOption.value.brOpts.push({
|
||||
label: item.code,
|
||||
value: item.id,
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue