\r\n \r\n \r\n \r\n {{ $vuetify.icons.values.tiempoTrabajado }}\r\n \r\n Con tiempo trabajado\r\n \r\n
\r\n\r\n\r\n\r\n","import mod from \"-!../../../../../../node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ExtraSubtitle.vue?vue&type=script&lang=js&\"; export default mod; export * from \"-!../../../../../../node_modules/cache-loader/dist/cjs.js??ref--13-0!../../../../../../node_modules/thread-loader/dist/cjs.js!../../../../../../node_modules/babel-loader/lib/index.js!../../../../../../node_modules/cache-loader/dist/cjs.js??ref--1-0!../../../../../../node_modules/vue-loader/lib/index.js??vue-loader-options!./ExtraSubtitle.vue?vue&type=script&lang=js&\"","import { render, staticRenderFns } from \"./ExtraSubtitle.vue?vue&type=template&id=4bc17aae&\"\nimport script from \"./ExtraSubtitle.vue?vue&type=script&lang=js&\"\nexport * from \"./ExtraSubtitle.vue?vue&type=script&lang=js&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../../../../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports\n\n/* vuetify-loader */\nimport installComponents from \"!../../../../../../node_modules/vuetify-loader/lib/runtime/installComponents.js\"\nimport { VChip } from 'vuetify/lib/components/VChip';\nimport { VIcon } from 'vuetify/lib/components/VIcon';\ninstallComponents(component, {VChip,VIcon})\n","import { basePageMixin } from '@/mixins/basePageMixin'\r\nimport { beforeRouteLeaveCommon } from './common'\r\nimport { ItemNotFoundError } from '@/utils/consts'\r\nimport _ from '@/utils/lodash'\r\n\r\nexport const viewPageMixin = {\r\n mixins: [basePageMixin],\r\n data () {\r\n return {\r\n // moreInfoRows puede ser:\r\n // 1º un array strings con nombres de campos\r\n // ['idcliente', 'nombre']\r\n // 2º un array de objetos (campos)\r\n // [{ name: 'idcliente' }, { name: 'nombre' }]\r\n // 3º un objeto con grupos y cada grupo con un título y un array de strings u objetos (campos)\r\n // {\r\n // cliente: { title: 'Cliente', rows: ['idcliente', 'nombre'] },\r\n // sistema: { title: 'Sistema', rows: [ { name: 'idsistema' }, 'descripcion'] },\r\n // },\r\n item: {\r\n dataset: [],\r\n metadata: {},\r\n },\r\n moreInfoRows: [],\r\n details: [],\r\n }\r\n },\r\n methods: {\r\n async initStore () {\r\n await this.copyRouteParamsToPageStore()\r\n },\r\n async beforeRouteLeaveBase (to, from, next) {\r\n if (!beforeRouteLeaveCommon(this, to, from, next)) {\r\n if (this.pageStorePath) {\r\n await this.dispatchStore('resetStore')\r\n }\r\n next()\r\n }\r\n },\r\n buildMoreInfo (metadata) {\r\n const getRowLabelFromMetadata = (rowName, metadata) => {\r\n let label = ''\r\n if (metadata && typeof metadata.getColumn === 'function') {\r\n const metadataRow = metadata.getColumn(rowName)\r\n if (metadataRow) {\r\n label = metadataRow.label\r\n }\r\n }\r\n return label || this.$options.filters.capitalize(rowName)\r\n }\r\n const defaultProperties = {\r\n visible: true,\r\n clickable: false,\r\n password: false,\r\n icon: this.$vuetify.icons.values.next\r\n }\r\n if (Array.isArray(this.moreInfoRows)) {\r\n const moreInfoArray = []\r\n for (const row of this.moreInfoRows) {\r\n let formattedRow = {}\r\n if (typeof(row) === 'string') {\r\n formattedRow = { name: row, label: getRowLabelFromMetadata(row, metadata) }\r\n } else {\r\n formattedRow = row\r\n if (!formattedRow.label) {\r\n formattedRow.label = getRowLabelFromMetadata(formattedRow.name, metadata)\r\n }\r\n }\r\n moreInfoArray.push({ ...defaultProperties, ...formattedRow })\r\n }\r\n return moreInfoArray\r\n } else {\r\n const moreInfoObj = {}\r\n for (const group in this.moreInfoRows) {\r\n moreInfoObj[group] = {}\r\n moreInfoObj[group].title = this.moreInfoRows[group].title\r\n moreInfoObj[group].rows = []\r\n for (const row of this.moreInfoRows[group].rows) {\r\n let formattedRow = {}\r\n if (typeof(row) === 'string') {\r\n formattedRow = { name: row, label: getRowLabelFromMetadata(row, metadata) }\r\n } else {\r\n formattedRow = row\r\n if (!formattedRow.label) {\r\n formattedRow.label = getRowLabelFromMetadata(formattedRow.name, metadata)\r\n }\r\n }\r\n moreInfoObj[group].rows.push({ ...defaultProperties, ...formattedRow })\r\n }\r\n }\r\n return moreInfoObj\r\n }\r\n },\r\n initDetails () {\r\n this.details = []\r\n },\r\n addDetail (name, title, subtitle, icon, disabled = false, data = {}) {\r\n const index = this.details.push({\r\n type: 'detail',\r\n name,\r\n title,\r\n subtitle,\r\n icon,\r\n order: this.details.length + 1,\r\n badge: '',\r\n badgeColor: '',\r\n totals: '',\r\n data,\r\n disabled,\r\n })\r\n return this.details[index - 1]\r\n },\r\n addDetailHeader (title) {\r\n const index = this.details.push({\r\n type: 'header',\r\n title,\r\n order: this.details.length + 1,\r\n })\r\n return this.details[index - 1]\r\n },\r\n setMoreInfoRowValue (name, prop, value, group = '') {\r\n // ¿esta agrupado?\r\n if (group) {\r\n _.find(this.moreInfoRows[group].rows, { name })[prop] = value\r\n } else {\r\n _.find(this.moreInfoRows, { name })[prop] = value\r\n }\r\n },\r\n itemNotFound (message) {\r\n throw new ItemNotFoundError(message)\r\n },\r\n }\r\n}\r\n","import { decodeBase64 } from '@/utils/router'\r\nimport { get } from 'vuex-pathify'\r\nimport _ from '@/utils/lodash'\r\nimport { beforeRouteLeaveCommon } from './common'\r\nimport { hasViewPerm, hasInsertPerm, hasEditPerm, hasDeletePerm, hasPerm, permissions } from '@/utils/permissions'\r\nimport { initSchema, connect } from '@/offline/database'\r\n\r\nexport const basePageMixin = {\r\n data () {\r\n return {\r\n title: '',\r\n routeParams: null,\r\n routeQuery: null,\r\n loadingData: false,\r\n rememberState: false,\r\n rememberScroll: false,\r\n showingDialogs: {},\r\n pageLoaded: false,\r\n bottomNavBarButtons: [],\r\n dbReady: false,\r\n }\r\n },\r\n created () {\r\n this.routeParams = _.cloneDeep(this.$route.params)\r\n this.routeQuery = _.cloneDeep(this.$route.query)\r\n if (this.routeQuery.extra) {\r\n this.routeQuery.extra = decodeBase64(this.routeQuery.extra)\r\n }\r\n },\r\n computed: {\r\n routeFromBrowserHistory () {\r\n // no mostrar alerts en el \"back\" del navegador\r\n return this.$route.meta.fromBrowserHistory\r\n },\r\n userPermissions: get('usuario/permisos'),\r\n permissions () {\r\n return permissions\r\n },\r\n },\r\n methods: {\r\n async initDB () {\r\n if (!this.$offline.db) {\r\n this.$loading.showManual('Inicializando base de datos...')\r\n try {\r\n await this.$offline.init(await connect(initSchema()))\r\n } finally {\r\n this.dbReady = true\r\n this.$loading.hide()\r\n }\r\n } else {\r\n this.dbReady = true\r\n }\r\n },\r\n async closeDB () {\r\n if (this.$offline.db) {\r\n await this.$offline.db.close()\r\n this.$offline.db = null\r\n this.dbReady = false\r\n }\r\n },\r\n async copyRouteParamsToPageStore () {\r\n if (this.pageStoreName) {\r\n for (const routeParam in this.routeParams) {\r\n if (this.storeHasProperty(routeParam)) {\r\n await this.setStoreProperty(routeParam, this.routeParams[routeParam])\r\n }\r\n }\r\n }\r\n },\r\n async initStore () {\r\n // routeParams -> ¿existe en el store de la página? -> copiar valor\r\n // usado para: nextRoute, readonly\r\n await this.copyRouteParamsToPageStore()\r\n },\r\n storeHasProperty (property) {\r\n return property in this.$store.get(`${this.pageStoreName}`)\r\n },\r\n async setStoreProperty (property, value) {\r\n await this.$store.set(`${this.pageStoreName}/${property}`, value)\r\n },\r\n async getStoreProperty (property) {\r\n return await this.$store.get(`${this.pageStoreName}/${property}`)\r\n },\r\n async dispatchStore (actionName, payload) {\r\n return await this.$store.dispatch(`${this.pageStoreName}/${actionName}`, payload)\r\n },\r\n hasViewPerm (perm) {\r\n return hasViewPerm(this.userPermissions, perm)\r\n },\r\n hasInsertPerm (perm) {\r\n return hasInsertPerm(this.userPermissions, perm)\r\n },\r\n hasEditPerm (perm) {\r\n return hasEditPerm(this.userPermissions, perm)\r\n },\r\n hasDeletePerm (perm) {\r\n return hasDeletePerm(this.userPermissions, perm)\r\n },\r\n hasPerm (perm) {\r\n return hasPerm(this.userPermissions, perm)\r\n },\r\n beforeRouteLeaveBase (to, from, next) {\r\n if (!beforeRouteLeaveCommon(this, to, from, next)) {\r\n next()\r\n }\r\n },\r\n initNavigationBottom () {\r\n this.bottomNavBarButtons = []\r\n },\r\n addNavigationBottomButton (title, name, icon, visible = true, badge = null, badgeColor = 'green') {\r\n const index = this.bottomNavBarButtons.push({\r\n title,\r\n name,\r\n icon,\r\n order: this.bottomNavBarButtons.length + 1,\r\n visible,\r\n badge,\r\n badgeColor,\r\n })\r\n return this.bottomNavBarButtons[index - 1]\r\n },\r\n }\r\n}\r\n","export const beforeRouteLeaveCommon = (that, to, from, next) => {\r\n if (that.loadingData) {\r\n next(false)\r\n return true\r\n } else {\r\n let showingDialog = false\r\n for (const dialog in that.showingDialogs) {\r\n if (that.showingDialogs[dialog]) {\r\n that.$set(that.showingDialogs, dialog, false)\r\n showingDialog = true\r\n next(false)\r\n break\r\n }\r\n }\r\n return showingDialog\r\n }\r\n}\r\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('b10-base',[_c('b10-toolbar',{attrs:{\"title\":_vm.title,\"options\":_vm.toolbarOptions},on:{\"click-option\":_vm.clickToolbarOption}}),_c('b10-page-content',[_c('b10-view-summary',{attrs:{\"item\":_vm.formattedItem,\"showing\":_vm.showingDialogs.moreInfo},on:{\"update:showing\":function($event){return _vm.$set(_vm.showingDialogs, \"moreInfo\", $event)}}},[_c('template',{slot:\"extraSubtitle\"},[_c('extra-subtitle',{attrs:{\"con-tiempo-trabajado\":_vm.formattedItem.tiene_tiempo_trabajado}})],1)],2)],1)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","import { APIFilter } from '@/utils/api'\r\n\r\n\r\nexport default {\r\n async selectParteTrabajoTecnico (Vue, idparteTrabajoTecnico) {\r\n const apiFilter = new APIFilter()\r\n apiFilter.addExact('idparte_trabajo_tecnico', idparteTrabajoTecnico)\r\n const resp = await Vue.$api.call('parteTrabajoTecnico.select', { filter: apiFilter })\r\n return [resp.data.result.dataset[0], resp.data.result.metadata]\r\n },\r\n async selectDetails (Vue, idparteTrabajo) {\r\n let apiCalls = []\r\n apiCalls.push({ name: 'parteTrabajoDescargado', method: 'parteTrabajo.descargado', params: { idparte_trabajo: idparteTrabajo } })\r\n return await Vue.$api.batchCall(apiCalls)\r\n },\r\n async setTecnicoPrincipal (Vue, idparteTrabajoTecnico, idparteTrabajo) {\r\n await Vue.$api.call(\r\n 'parteTrabajoTecnico.setTecnicoPrincipal',\r\n {\r\n idparte_trabajo_tecnico: idparteTrabajoTecnico,\r\n idparte_trabajo: idparteTrabajo\r\n }\r\n )\r\n }\r\n}\r\n","