From 4e8f524f49cc234e128af6c93af9297112c9310d Mon Sep 17 00:00:00 2001 From: pablone Date: Thu, 9 May 2024 22:47:13 +0200 Subject: [PATCH 01/31] feat: add new list form with popup --- src/pages/Worker/Card/WorkerPda.vue | 264 ++++++++++++++++------------ 1 file changed, 155 insertions(+), 109 deletions(-) diff --git a/src/pages/Worker/Card/WorkerPda.vue b/src/pages/Worker/Card/WorkerPda.vue index 5e7c89326..c903cd6cc 100644 --- a/src/pages/Worker/Card/WorkerPda.vue +++ b/src/pages/Worker/Card/WorkerPda.vue @@ -1,140 +1,186 @@ - + es: PDA deallocated: PDA desasignada + Current SIM: SIM actual From 071e6a7296eb704a1825d84cc794321ce891e2eb Mon Sep 17 00:00:00 2001 From: Jon Date: Fri, 10 May 2024 12:00:16 +0200 Subject: [PATCH 02/31] refactor: refs #7361 ticket/summary like salix --- src/pages/Ticket/Card/TicketSummary.vue | 55 ++++++++++++++++++++----- 1 file changed, 45 insertions(+), 10 deletions(-) diff --git a/src/pages/Ticket/Card/TicketSummary.vue b/src/pages/Ticket/Card/TicketSummary.vue index af501240b..ab20a2b94 100644 --- a/src/pages/Ticket/Card/TicketSummary.vue +++ b/src/pages/Ticket/Card/TicketSummary.vue @@ -13,6 +13,7 @@ import VnLinkPhone from 'src/components/ui/VnLinkPhone.vue'; import { getUrl } from 'src/composables/getUrl'; import VnUserLink from 'src/components/ui/VnUserLink.vue'; import VnTitle from 'src/components/common/VnTitle.vue'; +import ItemDescriptorProxy from 'src/pages/Item/Card/ItemDescriptorProxy.vue'; const route = useRoute(); const router = useRouter(); @@ -262,15 +263,19 @@ async function changeState(value) { :url="ticketUrl + 'sale'" :text="t('ticket.summary.saleLines')" /> - + + + + + + + + + + + From ce444c7e5c3f76a0497e15899d86696a34b68702 Mon Sep 17 00:00:00 2001 From: Javier Segarra Date: Fri, 17 May 2024 14:19:29 +0200 Subject: [PATCH 11/31] first approach --- quasar.config.js | 11 +++- src/boot/customQInput.js | 77 +++++++++++++++++++++++++++ src/boot/customQTh.js | 34 ++++++++++++ src/boot/defaults/qTable.js | 46 ++++++++++++++++ src/components/common/VnInput.vue | 1 - src/pages/Claim/Card/ClaimSummary.vue | 27 +--------- src/pages/Customer/CustomerFilter.vue | 2 +- src/pages/Ticket/TicketFilter.vue | 2 - 8 files changed, 169 insertions(+), 31 deletions(-) create mode 100644 src/boot/customQInput.js create mode 100644 src/boot/customQTh.js diff --git a/quasar.config.js b/quasar.config.js index b59c62eeb..ddfe41c82 100644 --- a/quasar.config.js +++ b/quasar.config.js @@ -29,7 +29,16 @@ module.exports = configure(function (/* ctx */) { // app boot file (/src/boot) // --> boot files are part of "main.js" // https://v2.quasar.dev/quasar-cli/boot-files - boot: ['i18n', 'axios', 'vnDate', 'validations', 'quasar', 'quasar.defaults'], + boot: [ + 'i18n', + 'axios', + 'vnDate', + 'validations', + 'quasar', + 'quasar.defaults', + 'customQTh', + 'customQInput', + ], // https://v2.quasar.dev/quasar-cli-vite/quasar-config-js#css css: ['app.scss'], diff --git a/src/boot/customQInput.js b/src/boot/customQInput.js new file mode 100644 index 000000000..51dcd9179 --- /dev/null +++ b/src/boot/customQInput.js @@ -0,0 +1,77 @@ +// src/boot/customQTh.js + +import { boot } from 'quasar/wrappers'; +import { QInput } from 'quasar'; +import i18n from 'src/i18n'; +const TR_HEADER = 'tr-header'; + +export default boot((b) => { + const { app } = b; + app.use(i18n); + app.mixin({ + // mounted() { + // this.applyMixinLogic(); + // }, + mounted() { + this.applyMixinLogic(); + // if (this.$options.name === QInput.name) { + // console.table([this.$options.name]); + // if (this.label) this.label = this.$t(this.label); + // // this.addClassToQTh(this); + // } + }, + methods: { + applyMixinLogic() { + if (this.$options.name === 'QInput') { + // Traducción de la etiqueta + if (this.label) { + const el = this.$el; + // Recorrer los elementos hijos + const children = el.children || []; + for (let i = 0; i < children.length; i++) { + const child = children[i]; + if ( + child.tagName === 'DIV' && + child.classList.contains('q-field__inner') + ) { + const input = child.querySelector('input'); + const filterAvailableText = (element) => + element.__vueParentComponent.type.name === 'QInput' && + element.__vueParentComponent?.attrs?.class !== + 'vn-input-date'; + + if ( + input && + input.__vueParentComponent.type.name === 'QInput' + ) { + // Añadir clase CSS + input.classList.add('input-default'); + + // Traducción de la etiqueta + const labelElement = + child.querySelector('.q-field__label'); + if (labelElement) { + const labelKey = labelElement.textContent.trim(); + labelElement.textContent = this.$t(labelKey); + } + } + } + } + // Traducción de la etiqueta + // const label = this.$el.getAttribute('label'); + // if (label) { + // this.$el = this.$el.setAttribute('label', 'sasd'); + // } + // this.$props.label = this.$t(`*${this.$props.label}`); + // this.label = this.$t(`*${this.$props.label}`); + // this.getNativeElement().ariaLabel = '++++'; + } + // // Añadir clase CSS + // if (!this.$el.classList.contains('input-default')) { + // this.$el.classList.add('input-default'); + // } + } + }, + }, + }); +}); diff --git a/src/boot/customQTh.js b/src/boot/customQTh.js new file mode 100644 index 000000000..ae3aa1011 --- /dev/null +++ b/src/boot/customQTh.js @@ -0,0 +1,34 @@ +// src/boot/customQTh.js + +import { QTable } from 'quasar'; +import { boot } from 'quasar/wrappers'; + +import i18n from 'src/i18n'; +const TR_HEADER = 'tr-header'; + +export default boot((b) => { + const { app } = b; + app.use(i18n); + app.mixin({ + mounted() { + if (this.$options.name === QTable.name) { + console.table([this.$options.name]); + this.addClassToQTh(this.columns ?? []); + } + }, + methods: { + addClassToQTh(columns) { + for (const column of columns) { + let { headerClasses, label, sortable } = column ?? []; + if (!headerClasses) headerClasses = TR_HEADER; + if (!Array.isArray(headerClasses)) headerClasses = [headerClasses]; + else headerClasses.push(TR_HEADER); + column.headerClasses = headerClasses; + if (sortable === undefined) column.sortable = true; + column.label = this.$t(label); + console.table([headerClasses, column.headerClasses]); + } + }, + }, + }); +}); diff --git a/src/boot/defaults/qTable.js b/src/boot/defaults/qTable.js index 8902d4266..23bc7d922 100644 --- a/src/boot/defaults/qTable.js +++ b/src/boot/defaults/qTable.js @@ -1,5 +1,51 @@ import { QTable } from 'quasar'; +import { QInput } from 'quasar'; import setDefault from './setDefault'; +import { QSelect } from 'quasar'; setDefault(QTable, 'pagination', { rowsPerPage: 0 }); setDefault(QTable, 'hidePagination', true); +QInput.props.outlined = { + type: QInput.props.outlined, + default: false, +}; +QInput.props.dense = { + type: QInput.props.dense, + default: false, +}; +QInput.props.stackLabel = { + type: QInput.props.stackLabel, + default: true, +}; +QSelect.props.optionLabel = { + type: QSelect.props.optionLabel, + default: 'name', +}; +QSelect.props.optionValue = { + type: QSelect.props.optionValue, + default: 'id', +}; +QInput.props.hideBottomSpace = { + type: QInput.props.hideBottomSpace, + default: true, +}; +QTable.props.columns = { + type: QTable.props.columns, + align: 'right', + format: (value) => `${value}*`, +}; +QTable.props.noDataLabel = { + default: 'asd', +}; + +setDefault(QInput, 'outlined', false); +// setDefault(QTable, "noDataLabel", t('globalfs.noResults')); +setDefault(QTable, 'gridHeader', true); +setDefault(QTable, 'color', 'red-8'); +setDefault(QTable, 'pagination', { rowsPerPage: 25 }); +setDefault(QTable, 'rowKey', 'id'); +// setDefault(QTable, 'columns', (data) => { +// console.log(this); +// }); +// setDefault(QSelect, 'optionValue', 'id'); +// setDefault(QSelect, 'optionLabel', 'name'); diff --git a/src/components/common/VnInput.vue b/src/components/common/VnInput.vue index 8358cd6e6..67a4fd958 100644 --- a/src/components/common/VnInput.vue +++ b/src/components/common/VnInput.vue @@ -69,7 +69,6 @@ const inputRules = [ :clearable="false" :rules="inputRules" :lazy-rules="true" - hide-bottom-space >