
.label[data-v-5c7bbdc2] {
  width: 120px;
  font-weight: 600;
}


.label[data-v-18ef45ee] {
  width: 125px;
  font-weight: 600;
}


.label[data-v-f03c7078] {
  width: 120px;
  font-weight: 600;
}


.row[data-v-5a1f8eab] {
  height: 10%;
}
h2[data-v-5a1f8eab] {
  display: inline-block;
  vertical-align: middle;
}
.card[data-v-5a1f8eab] {
  width: 80%;
  margin-bottom: 30px;
  padding: 25px 35px 35px;
}
.card_top[data-v-5a1f8eab] {
  display: block;
  margin-bottom: 10px;
}


.cursor-help {
  cursor: help;
}


table[data-v-120e5af6] {
  width: 100%;
  border: 2px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
  background-color: white;
  border-collapse:  collapse;
  font-size: 12px;
}
th[data-v-120e5af6] {
  color: black;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-top: 2px;
  border-radius: 3px;
}
td[data-v-120e5af6] {
  background-color: white;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
}
th[data-v-120e5af6], td[data-v-120e5af6] {
  padding: 2px 5px;
  width: 1%;
}



table[data-v-30c3e992] {
  width: 100%;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
  background-color: white;
  border-collapse:  collapse;
  font-size: 12px;
}
th[data-v-30c3e992] {
  color: black;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
}
th.client[data-v-30c3e992] {
  width: 20%;
}
th.tonnage[data-v-30c3e992],
th.hours[data-v-30c3e992] {
  width:4%;
}
td[data-v-30c3e992] {
  background-color: white;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
}
th[data-v-30c3e992], td[data-v-30c3e992] {
  padding: 2px 5px;
}
.headers[data-v-30c3e992] {
  text-align: left;
}
h6[data-v-30c3e992] {
  text-align: center
}
li[data-v-30c3e992] {
  font-size: 12px;
}
.obligations[data-v-30c3e992] {
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
  background-color: white;
}
#footerTable[data-v-30c3e992] {
  text-decoration: underline;
  text-align: left;
}



table[data-v-64e6a29c] {
  width: 100%;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
  background-color: white;
  border-collapse:  collapse;
  font-size: 12px;
}
th[data-v-64e6a29c] {
  color: black;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
}
td[data-v-64e6a29c] {
  background-color: white;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
  text-align: center;
}
.red[data-v-64e6a29c] {
  color: red;
}



table[data-v-82c615e6] {
  width: 100%;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
  background-color: white;
  border-collapse:  collapse;
  font-size: 12px;
}
th[data-v-82c615e6] {
  color: black;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
}
th.observations[data-v-82c615e6] {
  width:25%;
}
td[data-v-82c615e6] {
  background-color: white;
  border: 1px solid rgba(76, 156, 199, 0.98);
  border-radius: 3px;
}
th[data-v-82c615e6], td[data-v-82c615e6] {
  padding: 2px 5px;
}
h4[data-v-82c615e6] {
  text-align: center
}
.red[data-v-82c615e6] {
  color: red;
}

























































































































































































































/* Hide leaflet itinerary */
div.leaflet-top.leaflet-right {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
}


.label[data-v-3f0700b8] {
  width: 120px;
  font-weight: 600;
}


#card[data-v-7a0c5b68] {
  width: 31%;
  display: inline-block;
  margin: 0px 20px 20px 0px;
  text-align: center;
}
.v-image[data-v-7a0c5b68] {
  display: inline-block;
  width: 30%;
}
.infoCard[data-v-7a0c5b68] {
  display: inline-block;
  width: 50%;
  margin-top: 10px;
  vertical-align: top;
}
.infoCard span[data-v-7a0c5b68] {
  display: block;
  text-align: left;
  font-size: 18px;
}
.infoCard span[data-v-7a0c5b68]:nth-child(1) {
  color: #707070;
}
.infoCard span[data-v-7a0c5b68]:nth-child(3) {
  color: #707070;
  line-height: 40px;
  font-size: 11px;
}
.infoCard span[data-v-7a0c5b68]:nth-child(4) {
  color: #fd6e60;
  font-size: 28px;
  font-weight: bold;
}
.buttons[data-v-7a0c5b68] {
  display: flex;
  width: 100%;
}
.v-btn[data-v-7a0c5b68] {
  border-left: 1px solid #c2c2c2;
  border-top: 1px solid #c2c2c2;
  border-radius: 0;
  height: 60px;
  flex: 2 1 100px;
}
.v-btn[data-v-7a0c5b68]:nth-child(1) {
  border-left: 0;
}


.label[data-v-13de95c4] {
  width: 120px;
  font-weight: 600;
}


.centered-input[data-v-bbcb6ec2] input {
  text-align: center
}

#map[data-v-685ddbc0] {
  max-width: 100%;
  max-height: 100%;
}
#map path[data-v-685ddbc0] {
  fill: #395a6b;
  stroke: #ffffff;
  stroke-width: 0.6;
  transition: fill 0.2s, stroke 0.3s;
}
#map path[data-v-685ddbc0]:hover {
  fill: red;
  stroke: red;
}
#map .separator[data-v-685ddbc0] {
  stroke: #ccc;
  fill: none;
  stroke-width: 1.5;
}
#map .separator[data-v-685ddbc0]:hover {
  stroke: #ccc;
  fill: none;
}
#map .affecte[data-v-685ddbc0] {
  fill: #fd6e60;
  stroke: #ffffff;
  stroke-width: 1.5;
}
#tooltip[data-v-685ddbc0] {
  position: absolute;
  background-color: #ffffff;
  color: #395a6b;
  border-style: inset;
  padding: 4px;
  width: 200px;
  z-index: 1;
  display: none;
}

.wrapper {
  max-width: 400px;
  margin: 0 auto;
}


.label[data-v-96c7fff4] {
  width: 200px;
  font-weight: 600;
}








































































































































































/* Hide leaflet itinerary */
div.leaflet-top.leaflet-right {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
}


.costs:nth-of-type(even) {
  font-weight: bold;
}
.toursQty {
  font-weight: bold;
}
.v-data-table__wrapper table tbody tr td.text-start {
  padding: 0 8px!important;
}
// Pritable text size
@media print {
html, body, div, span, h1, h2, h3, h4, h5, h6, p, pre, a, ol, ul, li, table, tbody, tfoot, thead, tr, th, td, i {
    font-size: 6pt !important;
}
}


/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"back-script.css","mappings":";AAyDA;EACA;EACA;AACA;;;ACQA;EACA;EACA;AACA;;;ACCA;EACA;EACA;AACA;;;ACjDA;EACA;AACA;AACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;AACA;;;ACiEA;EACA;AACA;;;ACiFA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;AACA;;;;ACmFA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;EACA;AACA;AAEA;EACA;AACA;AAEA;;EAEA;AACA;AAEA;EACA;EACA;EACA;AACA;AAEA;EACA;AACA;AAEA;EACA;AACA;AAEA;EACA;AACA;AAEA;EACA;AACA;AAEA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;AACA;;;;AC7NA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;EACA;EACA;AACA;AAEA;EACA;AACA;;;;ACvEA;EACA;EACA;EACA;EACA;EACA;EACA;AACA;AAEA;EACA;EACA;EACA;AACA;AAEA;EACA;AACA;AAEA;EACA;EACA;EACA;AACA;AAEA;EACA;AACA;AAEA;EACA;AACA;AAEA;EACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACgGA;AACA;EACA;EACA;EACA;AACA;;;AC3LA;EACA;EACA;AACA;;;ACUA;EACA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;AACA;AACA;EACA;AACA;AACA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;AACA;AACA;EACA;EACA;AACA;AACA;EACA;EACA;EACA;EACA;EACA;AACA;AACA;EACA;AACA;;;ACjCA;EACA;EACA;AACA;;;ACoRA;EACA;AACA;;AC+IA;EACE;EACA;AAneF;AAqeE;EACE;EACA;EACA;EACA;AAneJ;AAqeE;EACE;EACA;AAneJ;AAqeE;EACE;EACA;EACA;AAneJ;AAqeE;EACE;EACA;AAneJ;AAqeE;EACE;EACA;EACA;AAneJ;AAueA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AApeF,C;;AC+HA;EACA;EACA;AACA;;;ACzFA;EACA;EACA;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACqFA;AACA;EACA;EACA;EACA;AACA;;;AC8hBA;EACA;AACA;AAEA;EACA;AACA;AAEA;EACA;AACA;AAEA;;AAEA;IACA;AACA;AACA","sources":["webpack:///./assets/src/app/module/back_office/account/AccountEditForm.vue","webpack:///./assets/src/app/module/back_office/account/AddressEditForm.vue","webpack:///./assets/src/app/module/back_office/account/CustomerAccountInfo.vue","webpack:///./assets/src/app/module/back_office/catalog/component/CatalogItemList.vue","webpack:///./assets/src/app/module/back_office/dashboard/PublicHolidays.vue","webpack:///./assets/src/app/module/back_office/delivery-schedule/component/DeliveryScheduleCharterPrint.vue","webpack:///./assets/src/app/module/back_office/delivery-schedule/component/DeliveryScheduleDriverPrint.vue","webpack:///./assets/src/app/module/back_office/delivery-schedule/component/DeliveryScheduleWarehouseCharterPrint.vue","webpack:///./assets/src/app/module/back_office/delivery-schedule/component/DeliveryScheduleWarehousePrint.vue","webpack:///./assets/src/app/module/back_office/itinerary/component/MakeItineraryMap.vue","webpack:///./assets/src/app/module/back_office/module/component/ModuleEditForm.vue","webpack:///./assets/src/app/module/back_office/product/ProductCard.vue","webpack:///./assets/src/app/module/back_office/replenishment/component/ReplenishmentEditForm.vue","webpack:///./assets/src/app/module/back_office/sales/component/OrderItemManualForm.vue","webpack:///./MapSvg.vue","webpack:///./assets/src/app/module/back_office/sectorization/SectorMapCreation.vue","webpack:///./assets/src/app/module/back_office/user/UserEditForm.vue","webpack:///./assets/src/app/shared/component/map/MarkersOnMap.vue","webpack:///./assets/src/app/shared/component/table/ApiDataTable.vue"],"sourcesContent":["<template>\n  <div>\n    <v-col v-if=\"isEdit\">\n      <slot></slot>\n    </v-col>\n    <v-col v-else>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">Nom</div>\n        <div class=\"py-1\">{{ user.name }}</div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">Email</div>\n        <div class=\"py-1\">{{ user.email }}</div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">Téléphone</div>\n        <div class=\"py-1\">{{ user.address ? user.address.phone : '-'}}</div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">Adresse</div>\n        <div class=\"py-1\" v-if=\"user.address\">\n          <span>{{ user.address.address_1 }}, {{ user.address.postcode }} {{ user.address.city }}</span>\n          <span>{{ user.address.country }}</span>\n        </div>\n        <div v-else>-</div>\n      </v-row>\n    </v-col>\n    <v-row no-gutters :justify=\"$vuetify.breakpoint.mdAndUp ? 'end' : 'center'\" v-if=\"!isEdit\">\n      <v-btn color=\"secondary\" v-on:click=\"isEdit = !isEdit\">\n        <v-icon left>mdi-pencil</v-icon>\n        Modifier les informations\n      </v-btn>\n    </v-row>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport Vue from \"vue\";\n\nexport default Vue.extend({\n  name: \"user-edit-form\",\n  props: [\"user\"],\n  mounted: function () {\n    this.$emitter.on(\"toggle-user-info\", () => {\n      this.isEdit = !this.isEdit;\n    });\n  },\n  data: function () {\n    return {\n      isEdit: false,\n    };\n  },\n});\n\n</script>\n\n<style scoped>\n.label {\n  width: 120px;\n  font-weight: 600;\n}\n</style>","<template>\n  <div>\n    <v-col v-if=\"isEdit\">\n      <slot></slot>\n    </v-col>\n    <v-col v-else class=\"pa-0 ma-0\">\n      <v-row no-gutters class=\"py-1\">\n        <v-chip class=\"ma-2 primary white--text\">\n          <p class=\"pa-0 ma-0\">Adresse de <span class=\"text-lowercase\">{{ address.type.name }}</span></p>\n        </v-chip>\n        <v-spacer></v-spacer>\n        <v-btn color=\"secondary\" v-on:click=\"isEdit = !isEdit\" icon>\n          <v-icon size=\"25\">mdi-pencil</v-icon>\n        </v-btn>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">\n          <v-icon color=\"primary\" class=\"mr-2\">mdi-account</v-icon>\n          Nom\n        </div>\n        <div class=\"py-1\">\n          <span class=\"text-capitalize\">{{ address.name }} </span>\n        </div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">\n          <v-icon color=\"primary\" class=\"mr-2\">mdi-map-marker</v-icon>\n          Adresse\n        </div>\n        <div class=\"py-1\">\n          <span>{{ address.address1 }}, {{ address.postcode }} {{ address.city }}</span>\n          <span>{{ address.country }}</span>\n        </div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">\n          <v-icon color=\"primary\" class=\"mr-2\">mdi-phone</v-icon>\n          Téléphone\n        </div>\n        <div class=\"py-1\">{{ address.phone }}</div>\n      </v-row>\n    </v-col>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport Vue from \"vue\";\n\nexport default Vue.extend({\n  name: \"address-edit-form\",\n  props: [\"address\", \"event_key\"],\n  mounted: function () {\n    this.$emitter.on(\"toggle-address-info\", (ref) => {\n      if (this.event_key == ref) {\n        this.isEdit = !this.isEdit;\n      }\n    });\n  },\n  data: function () {\n    return {\n      isEdit: false,\n    };\n  },\n});\n\n</script>\n\n<style scoped>\n.label {\n  width: 125px;\n  font-weight: 600;\n}\n</style>","<template>\n  <div>\n    <h4 class=\"py-4 pb-2 px-2\">Informations générales</h4>\n    <v-row no-gutters>\n      <slot name=\"main\"></slot>\n    </v-row>\n    <v-row no-gutters>\n      <slot name=\"type\"></slot>\n    </v-row>\n\n    <v-divider class=\"ma-2 mt-1\"></v-divider>\n    <v-row no-gutters> </v-row>\n    <v-row no-gutters v-if=\"type === 'Agent commercial'\">\n      {{ this.departements }}\n      <sectorization-map :departements=\"departements\"></sectorization-map>\n      <input\n        type=\"hidden\"\n        name=\"departments\"\n        :value=\"JSON.stringify({ departements })\"\n      />\n    </v-row>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport Vue from \"vue\";\n\nexport default Vue.extend({\n  name: \"customer-account-info\",\n  props: [\"module\"],\n  methods: {},\n  data: function () {\n    return {\n      type: \"\",\n      departements: [],\n    };\n  },\n  watch: {\n    type: function () {\n      if (this.type != \"Agent commercial\") {\n        this.departements = [];\n      }\n    },\n  },\n  mounted: function () {\n    //a chaque nouvelle action\n    this.$nextTick(() => {\n      //on récupére l'élément v-select du type de comtpe\n      const el: any = document.getElementsByClassName(\"v-select__selections\");\n      // on ecoute les click\n      el[0]?.addEventListener(\"click\", (e: any) => {\n        //on attend que la liste se charge\n        setTimeout(() => {\n          //on recupère l'element liste\n          const test: any = document.getElementsByClassName(\"v-menu__content\");\n          //on ecoute les click\n          test[0]?.addEventListener(\"click\", (eb: any) => {\n            // on récupère la valeur du type de compte\n            const text: any = document.getElementsByClassName(\n              \"v-select__selection\"\n            )[0].innerHTML;\n            //on l'affecte a la props type pour faire fonctionner le v-if du bouton affectation des départements\n            this.type = text;\n          });\n        }, 1);\n      });\n    });\n  },\n});\n</script>\n\n<style scoped>\n.label {\n  width: 120px;\n  font-weight: 600;\n}\n</style>\n","<template>\n  <div id=\"card\">\n    <v-spacer></v-spacer>\n    <v-card class=\"mx-auto card\" max-width=\"100%\" outlined>\n      <v-icon large color=\"secondary\">mdi-{{ catalog.icon }}</v-icon>\n      <h2 class=\"ml-2\">{{ catalog.name }}</h2>\n    </v-card>\n    <v-spacer></v-spacer>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport Vue from \"vue\";\n\nexport default Vue.extend({\n  name: \"catalog-item-list\",\n  props: [\"catalog\"],\n  data: function () {\n    return {\n      isActive: false,\n    };\n  },\n});\n</script>\n\n<style scoped>\n.row {\n  height: 10%;\n}\nh2 {\n  display: inline-block;\n  vertical-align: middle;\n}\n.card {\n  width: 80%;\n  margin-bottom: 30px;\n  padding: 25px 35px 35px;\n}\n.card_top {\n  display: block;\n  margin-bottom: 10px;\n}\n</style>\n","<template>\n  <div>\n    &nbsp;-&nbsp;\n    <small\n        class=\"font-italic\"\n        :class=\"nextDeliveryDate.isPublicHoliday ? 'orange--text cursor-help' : ''\"\n        :title=\"nextDeliveryDate.title\"\n    >\n      Prochaine livraison : {{ nextDeliveryDate.date | date }}\n\n      <v-tooltip bottom color=\"grey\">\n        <template v-slot:activator=\"{ on, attrs }\">\n          <v-icon\n              v-bind=\"attrs\"\n              v-on=\"on\"\n              size=\"small\"\n              :class=\"nextDeliveryDate.isPublicHoliday ? 'orange--text' : ''\"\n          >\n            mdi-help-circle-outline\n          </v-icon>\n        </template>\n        <div style=\"color: #000;\">\n          <span class=\"font-weight-bold\">Jours fériés dans les 2 prochains mois :</span>\n          <div v-for=\"holi in publicHolidays\">\n            {{ holi.startDate | date }} : {{ holi.name.find(n => n.language === 'FR').text }}\n          </div>\n        </div>\n      </v-tooltip>\n    </small>\n  </div>\n</template>\n\n<script>\nimport Vue from \"vue\";\nimport moment from \"moment\";\n\nexport default Vue.extend({\n  name: \"public-holidays\",\n  props: [],\n  data: () => ({\n    nextDeliveryDate: {\n      date: null,\n      isPublicHoliday: false,\n      title: ''\n    },\n    publicHolidays: []\n  }),\n  filters: {\n    date(date) {\n      return date ? moment(date).format('DD/MM/YYYY') : '';\n    }\n  },\n  beforeMount() {\n    this.nextDeliveryDate.date = this.$tomorrow;\n    this.fetchPublicHolidays();\n  },\n  methods: {\n    async fetchPublicHolidays() {\n      this.publicHolidays = null;\n      const storageHolidays = localStorage.getItem('public-holidays');\n\n      // Get public holidays from session storage\n      if (storageHolidays && storageHolidays.length > 0) {\n        const todayPH = JSON.parse(storageHolidays);\n        // If already fetch today, get them\n        if (moment(todayPH.date).isSame(moment(), 'day') && todayPH.publicHolidays) {\n          this.publicHolidays = todayPH.publicHolidays\n        }\n        // Else delete cause another day\n        else {\n          localStorage.removeItem('public-holidays');\n        }\n      }\n\n      // Use external api to get public holidays\n      if (null === this.publicHolidays) {\n        let dates = [\n            'validFrom=' + moment().format('YYYY-MM-DD'),\n            'validTo=' + moment().add(2, 'month').format('YYYY-MM-DD'),\n        ];\n        const response = await fetch('https://openholidaysapi.org/PublicHolidays?countryIsoCode=FR&languageIsoCode=FR&subdivisionCode=FR-FR&' + dates.join('&'))\n        this.publicHolidays = await response.json();\n        // Set public holidays to session storage\n        localStorage.setItem('public-holidays', JSON.stringify({\n          date: moment(),\n          publicHolidays: this.publicHolidays\n        }))\n      }\n\n      const tomorrowPH = this.publicHolidays.find(ph => moment(ph.startDate).isSame(this.$tomorrow, 'day'));\n      this.nextDeliveryDate.isPublicHoliday = tomorrowPH && tomorrowPH.id;\n      this.nextDeliveryDate.title = tomorrowPH ? tomorrowPH.name.find(n => n.language === 'FR')?.text : '';\n\n      // If tomorrow is PH, add one day (or more if weekend)\n      if (tomorrowPH && tomorrowPH.id) {\n        this.$tomorrow.add(1, 'days')\n        while ([6, 0].includes(this.$tomorrow.day())) {\n          this.$tomorrow = this.$tomorrow.add(1, 'days');\n        }\n      }\n    }\n  }\n})\n</script>\n\n<style>\n  .cursor-help {\n    cursor: help;\n  }\n</style>\n","<template>\n  <div class=\"mt-5\">\n    <diV>\n      <table class=\"mt-4\" >\n        <thead>\n          <tr>\n            <th>EXPEDITEUR</th>\n            <th>DESTINATAIRE</th>\n          </tr>\n        </thead>\n        <tbody>\n          <tr>\n            <td><strong>Société</strong> : CARRIERES</td>\n            <td><strong>Société</strong> : {{ deliverySchedule.transporter.name }}\n              <span v-if=\"deliverySchedule.transporter && deliverySchedule.transporter.address\">\n                ({{ deliverySchedule.transporter.address.postcode[0]}}{{ deliverySchedule.transporter.address.postcode[1]}})\n              </span>\n            </td>\n          </tr>\n          <tr>\n            <td><strong>Adresse</strong> : BP 2 - Route de Niort<br>79310 MAZIERES EN GATINE</td>\n            <td><strong>Adresse</strong> : <span v-if=\"deliverySchedule.transporter && deliverySchedule.transporter.address\">{{ deliverySchedule.transporter.address.address1 }}</span><br>\n              <span v-if=\"deliverySchedule.transporter && deliverySchedule.transporter.address\">\n                {{ deliverySchedule.transporter.address.postcode }} {{ deliverySchedule.transporter.address.city }}\n              </span>\n            </td>\n          </tr>\n          <tr>\n            <td><strong>Nom</strong> : {{ deliverySchedule.user.fullname }}</td>\n            <td><strong>Nom</strong> : {{ deliverySchedule.transporter.name }}</td>\n          </tr>\n          <tr>\n            <td><strong>Téléphone</strong> : {{ deliverySchedule.user.phone }}</td>\n            <td><strong>Téléphone</strong> : <span v-if=\"deliverySchedule.transporter && deliverySchedule.transporter.address\">{{ deliverySchedule.transporter.address.phone }}</span></td>\n          </tr>\n          <tr>\n            <td><strong>E-mail</strong> : {{ deliverySchedule.user.email }}</td>\n            <td><strong>E-mail</strong> : <span v-if=\"deliverySchedule.transporter && deliverySchedule.transporter.address\">{{ deliverySchedule.transporter.address.email }}</span></td>\n          </tr>\n        </tbody>\n        <tbody v-for=\"tour in tours\">\n          <template v-if=\"tour.is_message\">\n            <tr class=\"red--border\">\n              <th colspan=\"2\" style=\"color: orange;\">\n                <v-icon color=\"orange\" small class=\"mr-2\">mdi-comment-text-outline</v-icon>\n                {{ tour.message }}\n              </th>\n            </tr>\n          </template>\n          <template v-if=\"tour.delivery_order\">\n            <tr>\n                <th colspan=\"2\" style=\"border-top: 2px solid rgba(76, 156, 199, 0.98)\">DESCRIPTION MARCHANDISE A TRANSPORTER</th>\n            </tr>\n            <tr>\n              <td>\n                <strong>REF COMMANDE</strong> : {{ deliverySchedule.user.firstname }} {{ deliverySchedule.user.lastname }}<br>\n                <strong>REF PLANNING</strong> : {{ deliverySchedule.id }}<br>\n                <strong>NATURE PRODUIT</strong> : {{ tour.delivery_order.product ? tour.delivery_order.product.name : '' }}<br>\n                <strong>QUANTITE A LIVRER</strong> : {{ tour.delivery_quantity + '&nbspT'}}\n              </td>\n              <td>\n                <strong>CARACTERISTIQUES PARTICULIERES</strong> :<br>\n                <ul>\n                  <li>Bachâge obligatoire</li>\n                  <li>Bennes propres</li>\n                </ul>\n              </td>\n            </tr>\n            <tr>\n              <th>CHARGEMENT</th>\n              <th>DECHARGEMENT</th>\n            </tr>\n            <tr>\n              <td>\n                <strong>LIEU</strong> : {{ tour.delivery_order.warehouse.name }}<br>\n                <strong>COORDONNEES</strong> :<br>\n                <span class=\"pl-4\"><strong>Téléphone</strong> : {{ tour.delivery_order.warehouse.address.phone }}</span><br>\n                <span class=\"pl-4\"><strong>E-mail</strong> : {{ tour.delivery_order.warehouse.address.email }}</span><br>\n                <strong>ADRESSE</strong> : {{ tour.delivery_order.warehouse.address.address1 }} -\n                <span v-if=\"tour.delivery_order && tour.delivery_order.warehouse && tour.delivery_order.warehouse.address\">\n                  {{ tour.delivery_order.warehouse.address.postcode }} {{ tour.delivery_order.warehouse.address.city }}\n                </span><br>\n                <strong>(horaires d'ouvertures : {{ tour.delivery_order.warehouse.openHours }})</strong>\n              </td>\n              <td><strong>NOM CLIENT</strong> : {{ tour.delivery_order.customer.name }}<br>\n                <strong>LIEU</strong> : {{ tour.delivery_order.site.address.address1 !== '.' ? tour.delivery_order.site.address.address1 + ' - ' : '' }}\n                <span v-if=\"tour.delivery_order && tour.delivery_order.site && tour.delivery_order.site.address\">\n                  {{ tour.delivery_order.site.address.postcode }} {{ tour.delivery_order.site.address.city }}\n                </span><br>\n                <strong>HORAIRES</strong> :\n                  {{ tour.delivery_order.site.timeStart | hour }} - {{ tour.delivery_order.site.timeEnd | hour }} et\n                  {{ tour.delivery_order.site.timeHalfStart | hour }} - {{ tour.delivery_order.site.timeHalfEnd | hour }}<br>\n                <template v-if=\"tour.delivery_order.site.timeStartFriday && tour.delivery_order.site.timeEndFriday &&\n                                tour.delivery_order.site.timeHalfStartFriday && tour.delivery_order.site.timeHalfEndFriday\">\n                  <strong>HORAIRES DU VENDREDI</strong> :\n                    {{ tour.delivery_order.site.timeStartFriday | hour }} - {{ tour.delivery_order.site.timeEndFriday | hour }} et\n                    {{ tour.delivery_order.site.timeHalfStartFriday | hour }} - {{ tour.delivery_order.site.timeHalfEndFriday | hour }}<br>\n                </template>\n                <strong>NOM CHEF DE CHANTIER</strong> : {{ tour.delivery_order.site.chief }}<br>\n                <span v-if=\"tour.delivery_order.site.contactClient || tour.delivery_order.site.phoneClient\">\n                  <strong>CONTACT COMMANDE</strong> :\n                  {{ tour.delivery_order.site.contactClient ? tour.delivery_order.site.contactClient : '' }}\n                  {{ tour.delivery_order.site.phoneClient ? tour.delivery_order.site.phoneClient : '' }}\n                </span><br>\n                <strong>DATE</strong> : {{ deliverySchedule.date | date}}<br>\n                <strong>HEURE</strong> : {{ tour.deliveryHour | hour }}\n              </td>\n            </tr>\n            <tr>\n              <td>\n                <strong>Conditions Particulières</strong> :\n                <ul>\n                  <li>Pas de surcharge</li>\n                  <li>Respect protocole de chargement</li>\n                  <li>Respect du plan de circulation</li>\n                </ul>\n              </td>\n              <td>\n                <strong>Conditions Particulières</strong> :<br>\n                {{ tour.driver_comment}}\n              </td>\n            </tr>\n          </template>\n        </tbody>\n        <tbody>\n          <tr>\n            <th colspan=\"2\">PRIX PRESTATION DE TRANSPORT</th>\n          </tr>\n          <tr>\n            <td colspan=\"2\" style=\"text-align:center\">\n              PU AT : {{ totalPuat }} €<br>\n              \"Indexation carburant comprise\"<br>\n              \"Interdiction de sous-traiter cette prestation\"\n            </td>\n          </tr>\n        </tbody>\n        <tbody>\n          <tr>\n            <th colspan=\"2\">SIGNATURES</th>\n          </tr>\n          <tr>\n            <td colspan=\"2\" style=\"text-align: right\">\n              Sincères salutations,<br>\n              Signataire : {{ deliverySchedule.user.fullname }},<br>\n              Fonction : Logistique Mazières\n              <div style=\"height: 70px;\"></div>\n            </td>\n          </tr>\n        </tbody>\n      </table>\n    </div>\n  </div>\n</template>\n\n<script type=\"ts\">\nimport Vue from \"vue\";\nimport moment from \"moment\";\n\nexport default Vue.extend({\n  name: 'delivery-schedule-charter-print',\n  props: ['tours', 'deliverySchedule'],\n  data: () => ({\n    puAtArray: [],\n    totalPuat: null,\n  }),\n  filters: {\n    date(value) {\n      return (value && moment(value)) ? moment(value).format('DD/MM/YYYY') : value;\n    },\n    hour(value) {\n      return (value && moment(value)) ? moment(value).format('HH:mm') : value;\n    }\n  },\n  computed:{\n  },\n  mounted: function () {\n    this.tours.forEach((tour) => { this.puAtArray.push(tour.puAt)});\n    // Sum of puAt from each tour\n    this.totalPuat = this.puAtArray.reduce((previousValue, currentValue) => previousValue + currentValue, 0);\n    // Print schedule\n    window.print();\n    // Close window after print\n    window.onafterprint = () => { window.close(); };\n  },\n});\n</script>\n\n<style scoped>\n\ntable {\n  width: 100%;\n  border: 2px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n  background-color: white;\n  border-collapse:  collapse;\n  font-size: 12px;\n}\n\nth {\n  color: black;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-top: 2px;\n  border-radius: 3px;\n}\n\ntd {\n  background-color: white;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n}\n\nth, td {\n  padding: 2px 5px;\n  width: 1%;\n}\n\n</style>\n","<template>\n  <div class=\"mt-5\">\n    <div>\n      <v-row no-gutters class=\"mb-2\">\n        <v-col class=\"ml-10\">\n          <span class=\"font-weight-bold primary--text\">Date de livraison :</span> {{ deliverySchedule.date | date }}\n        </v-col>\n        <v-col class=\"ml-10\">\n          <span class=\"font-weight-bold primary--text\">Rédacteur :</span>\n          {{ deliverySchedule.user && deliverySchedule.user.firstname ? deliverySchedule.user.firstname : '' }}\n          {{ deliverySchedule.user && deliverySchedule.user.lastname ? deliverySchedule.user.lastname : '' }}\n          <span v-if=\"deliverySchedule.user && deliverySchedule.user.phone\">&nbsp;({{ deliverySchedule.user.phone }})</span>\n        </v-col>\n      </v-row>\n      <v-row no-gutters>\n        <v-col>\n          <span class=\"font-weight-bold primary--text\">Transporteur :</span>\n          {{ deliverySchedule.truck && deliverySchedule.truck.transporter.name ? deliverySchedule.truck.transporter.name : '' }}\n        </v-col>\n        <v-col class=\"ml-6\">\n          <span class=\"font-weight-bold primary--text\">Camion :</span>\n          {{ deliverySchedule.truck && deliverySchedule.truck.numberplate ? deliverySchedule.truck.numberplate : '' }}\n        </v-col>\n        <v-col>\n          <span class=\"font-weight-bold primary--text\">Chauffeur:</span>\n          {{ deliverySchedule.driver ? deliverySchedule.driver.firstname + ' ' + deliverySchedule.driver.lastname: '' }}\n        </v-col>\n      </v-row>\n    </div>\n    <!-- Orders -->\n    <div>\n      <table class=\"mt-4\" >\n        <thead>\n            <tr>\n              <th>Origine</th>\n              <th>Client</th>\n              <th>Destination</th>\n              <th>Commentaires</th>\n              <th>Prévisions / Observ.</th>\n              <th>Tel. Chef chantier</th>\n              <th>Produit</th>\n              <th>Qté</th>\n            </tr>\n        </thead>\n        <tbody>\n          <tr v-for=\"tour in tours\">\n            <template v-if=\"tour.is_message\">\n              <td colspan=\"8\" style=\"color: orange; text-align: center; font-weight: bold;\">\n                <v-icon color=\"orange\" small class=\"mr-2\">mdi-comment-text-outline</v-icon>\n                {{ tour.message }}\n              </td>\n            </template>\n            <template v-if=\"tour.delivery_order\">\n              <td>\n                {{ tour.delivery_order.warehouse.name }}\n              </td>\n              <td>\n                {{ tour.delivery_order.customer.name }}\n              </td>\n              <td>\n                {{ tour.delivery_order.site.address.city }} -\n                {{ tour.delivery_order.site.address.postcode.slice(0, 2) }}\n              </td>\n              <td>\n                {{ tour.delivery_order.site.name }} -\n                {{ tour.delivery_order.site.address.address1 }}<br>\n                <span v-if=\"tour.delivery_order.site.timeStart && tour.delivery_order.site.timeEnd\">\n                  Ouverture de {{ tour.delivery_order.site.timeStart | hour }} à {{ tour.delivery_order.site.timeEnd | hour }}\n                </span>\n                <span v-if=\"tour.delivery_order.site.timeHalfStart && tour.delivery_order.site.timeHalfEnd\">\n                  et de {{ tour.delivery_order.site.timeHalfStart | hour }} à {{ tour.delivery_order.site.timeHalfEnd | hour }}\n                </span>\n                <span v-if=\"tour.delivery_order.site.timeStartFriday && tour.delivery_order.site.timeEndFriday\">\n                  et le vendredi de {{ tour.delivery_order.site.timeStartFriday | hour }} à {{ tour.delivery_order.site.timeEndFriday | hour }}\n                </span>\n                <span v-if=\"tour.delivery_order.site.timeHalfStartFriday && tour.delivery_order.site.timeHalfEndFriday\">\n                  et de {{ tour.delivery_order.site.timeHalfStartFriday | hour }} à {{ tour.delivery_order.site.timeHalfEndFriday | hour }}\n                </span>\n                {{ tour.driver_comment }}\n              </td>\n              <td>\n                <span v-if=\"tour.momentDay ||tour.deliveryHour || tour.commentMoments\">Horaires :</span>\n                {{ tour.momentDay ? tour.momentDay.openingTime.name : '' }} - {{ tour.commentMoments ? tour.commentMoments : '' }}\n                <span v-if=\"tour.deliveryHour\"> à {{ tour.deliveryHour | filterDateToHour }}</span>\n                <div v-if=\"tour.highway\" class=\"ma-0 pa-0\">\n                  <v-badge color=\"primary\" :content=\"tour.highway\" bordered bottom inline overlap class=\"ma-0 pa-0\">\n                    <v-icon color=\"primary\">mdi-highway</v-icon>\n                  </v-badge>\n                </div>\n              </td>\n              <td>\n                {{ tour.delivery_order.site.chief }}\n                {{ tour.delivery_order.site.address.phone }}\n                <span v-if=\"tour.delivery_order.site.contactClient ||tour.delivery_order.site.phoneClient\">\n                  {{ tour.delivery_order.site.contactClient ? tour.delivery_order.site.contactClient : '' }}\n                  {{ tour.delivery_order.site.phoneClient ? tour.delivery_order.site.phoneClient : '' }}\n                </span>\n              </td>\n              <td>\n                {{ tour.delivery_order.product ? tour.delivery_order.product.name : '' }}\n              </td>\n              <td>\n                {{ tour.delivery_quantity + '&nbspT'}}\n              </td>\n            </template>\n          </tr>\n        </tbody>\n      </table>\n    </div>\n    <div class=\"obligations mt-1 mb-1 pt-2 pb-2\" >\n      <h6>OBLIGATIONS DU CHAUFFEUR</h6>\n      <ul class=\"ml-3\">\n        <li>Porter les EPI obligatoires (casque, baudrier, chaussures de sécurité)</li>\n        <li>Faire signer les BL</li>\n        <li>Respecter les protocoles de chargement/déchargement chez nos clients et sur nos sites</li>\n        <li>Bâchage obligatoire</li>\n      </ul>\n    </div>\n    <div class=\"obligations pt-2 pb-2\" >\n      <h6>A REMPLIR PAR LE CHAUFFEUR</h6>\n    </div>\n    <div>\n      <table>\n        <thead>\n          <tr class=\"headers\">\n            <th colspan=\"5\">Kilométrage Départ :</th>\n            <th colspan=\"5\">Kilométrage Arrivée :</th>\n            <th colspan=\"5\">Kilométrage total jour :</th>\n          </tr>\n        </thead>\n      </table>\n    </div>\n    <div>\n      <table>\n        <thead>\n          <tr>\n            <th colspan=\"3\" rowspan=\"2\">Lieu de chargement</th>\n            <th colspan=\"2\" class=\"hours\">Heures</th>\n            <th colspan=\"3\" rowspan=\"2\">Lieu de déchargement</th>\n            <th colspan=\"2\" class=\"hours\">Heures</th>\n            <th colspan=\"3\" rowspan=\"2\" class=\"client\">Client</th>\n            <th colspan=\"2\" rowspan=\"2\" class=\"tonnage\">Tonnage</th>\n          </tr>\n          <tr>\n            <th>Arrivée</th>\n            <th>Départ</th>\n            <th>Arrivée</th>\n            <th>Départ</th>\n          </tr>\n        </thead>\n        <tbody>\n          <tr>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"4\">&nbsp</td>\n            <td class=\"tonnage\">&nbsp</td>\n          </tr>\n          <tr>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"4\">&nbsp</td>\n            <td class=\"tonnage\">&nbsp</td>\n          </tr>\n          <tr>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"4\">&nbsp</td>\n            <td class=\"tonnage\">&nbsp</td>\n          </tr>\n          <tr>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"4\">&nbsp</td>\n            <td class=\"tonnage\">&nbsp</td>\n          </tr>\n          <tr>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"4\">&nbsp</td>\n            <td class=\"tonnage\">&nbsp</td>\n          </tr>\n          <tr>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"4\">&nbsp</td>\n            <td class=\"tonnage\">&nbsp</td>\n          </tr>\n          <tr>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"4\">&nbsp</td>\n            <td class=\"tonnage\">&nbsp</td>\n          </tr>\n          <tr>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"3\">&nbsp</td>\n            <td>&nbsp</td>\n            <td>&nbsp</td>\n            <td colspan=\"4\">&nbsp</td>\n            <td class=\"tonnage\">&nbsp</td>\n          </tr>\n        </tbody>\n      </table>\n    </div>\n    <div>\n      <table id=\"footerTable\">\n        <tbody>\n          <tr>\n            <th colspan=\"6\" rowspan=\"2\">Observations chauffeur :<br>\n              <br>\n              <br>\n              <br>\n              Signature du chauffeur : <br>\n              <br>\n              <br>\n              <br>\n            </th>\n            <th>Temps de conduite :<br>\n              <br>\n              <br>\n              <br>\n            </th>\n          </tr>\n          <tr>\n            <th>Temps de travail :<br>\n              <br>\n              <br>\n              <br>\n            </th>\n          </tr>\n        </tbody>\n      </table>\n    </div>\n    <div class=\"obligations mt-1 mb-1 pt-2 pb-2\" >\n      <h6>A transmettre chaque soir à la bascule avec les BL concernés (exemplaires vert)</h6>\n    </div>\n  </div>\n</template>\n\n<script type=\"ts\">\nimport Vue from \"vue\";\nimport moment from \"moment\";\n\nVue.filter('filterDateToHour', function(value) {\n  if (value) {\n    return moment(String(value)).format('HH:mm')\n  }\n});\n\nexport default Vue.extend({\n  name: 'delivery-schedule-driver-print',\n  props: ['tours', 'deliverySchedule'],\n  filters: {\n    date(value) { return (value && moment(value)) ? moment(value).format('DD/MM/YYYY') : value; },\n    hour(value) { return (value && moment(value)) ? moment(value).format('HH:mm') : value; },\n  },\n  mounted() {\n// Print schedule\n    window.print();\n// Close window after print\n    window.onafterprint = () => { window.close(); };\n  },\n});\n</script>\n\n<style scoped>\n\ntable {\n  width: 100%;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n  background-color: white;\n  border-collapse:  collapse;\n  font-size: 12px;\n}\n\nth {\n  color: black;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n}\n\nth.client {\n  width: 20%;\n}\n\nth.tonnage,\nth.hours {\n  width:4%;\n}\n\ntd {\n  background-color: white;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n}\n\nth, td {\n  padding: 2px 5px;\n}\n\n.headers {\n  text-align: left;\n}\n\nh6 {\n  text-align: center\n}\n\nli {\n  font-size: 12px;\n}\n\n.obligations {\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n  background-color: white;\n}\n\n#footerTable {\n  text-decoration: underline;\n  text-align: left;\n}\n\n</style>\n","<template>\n  <div class=\"mt-5\">\n    <div>\n      <v-row no-gutters class=\"mb-2\">\n        <v-col class=\"ml-10\">\n          <span class=\"font-weight-bold primary--text\">{{ warehouse.name }}</span>\n        </v-col>\n        <v-col class=\"ml-10\">A partir du : {{ datefromstring | filterDate }}</v-col>\n      </v-row>\n    </div>\n    <div>\n      <table class=\"mt-4\" >\n        <thead>\n            <tr>\n              <th>Code</th>\n              <th>Date</th>\n              <th>Réf. comm. client</th>\n              <th>Client</th>\n              <th>Lieu de livraison</th>\n              <th>Nom et tél. du chef de chantier</th>\n              <th>Désignation</th>\n              <th>Code SAP</th>\n              <th>Qté en T.</th>\n              <th>Site de départ</th>\n              <th>Transporteur</th>\n            </tr>\n        </thead>\n        <tbody>\n          <tr v-for=\"tour in tours\">\n            <td>{{ tour.id }}</td>\n            <td>{{ tour.dateWithoutHour | filterDate }}</td>\n            <td>{{ tour.user.firstname }} {{ tour.user.lasttname }}</td>\n            <td>{{ tour.deliveryScheduleOrders[0].delivery_order.customer.name }}</td>\n            <td>\n              <span v-for=\"scheduleOrder in tour.deliveryScheduleOrders\">\n                <span v-if=\"scheduleOrder.delivery_order &&  scheduleOrder.delivery_order.warehouse.name == warehouse.name\">\n                  <strong>{{ scheduleOrder.delivery_order.site.name }}</strong>\n                  {{ scheduleOrder.delivery_order.site.address.address1 }} {{ scheduleOrder.delivery_order.site.address.postcode }}\n                  {{ scheduleOrder.delivery_order.site.address.city }}\n                  <span v-if=\"scheduleOrder.momentDay || scheduleOrder.deliveryHour || scheduleOrder.commentMoments\"> -\n                    <span v-if=\"scheduleOrder.momentDay\"  class=\"red--text\">{{ scheduleOrder.momentDay.openingTime.name }}</span>\n                    <span class=\"red--text\"> - {{ scheduleOrder.commentMoments ? scheduleOrder.commentMoments : '' }}</span>\n                    <span v-if=\"scheduleOrder.deliveryHour\" class=\"red--text\">{{ scheduleOrder.deliveryHour | filterDateToHour }}</span>\n                  </span>\n                  <span v-if=\"scheduleOrder.schedule_comment\"> - {{ scheduleOrder.schedule_comment }}</span>\n                </span>\n              </span>\n            </td>\n            <td>\n              <span v-for=\"scheduleOrder in tour.deliveryScheduleOrders\">\n                <span v-if=\"scheduleOrder.delivery_order &&  scheduleOrder.delivery_order.warehouse.name == warehouse.name\">\n                  <strong>{{ scheduleOrder.delivery_order.site.chief }}</strong> : {{ scheduleOrder.delivery_order.site.address.phone }}\n                  <span v-if=\"scheduleOrder.delivery_order.site.contactClient || scheduleOrder.delivery_order.site.phoneClient\">\n                    <strong>{{ scheduleOrder.delivery_order.site.contactClient ? scheduleOrder.delivery_order.site.contactClient : '' }}</strong> :\n                    {{ scheduleOrder.delivery_order.site.phoneClient ? scheduleOrder.delivery_order.site.phoneClient : '' }}\n                  </span>\n                </span>\n              </span>\n            </td>\n            <td>\n              <span v-for=\"scheduleOrder in tour.deliveryScheduleOrders\">\n                <span v-if=\"scheduleOrder.delivery_order &&  scheduleOrder.delivery_order.warehouse.name == warehouse.name\">\n                  {{ scheduleOrder.delivery_order.product.name }}\n                </span>\n              </span>\n            </td>\n            <td>\n              <span v-for=\"scheduleOrder in tour.deliveryScheduleOrders\">\n                <span v-if=\"scheduleOrder.delivery_order &&  scheduleOrder.delivery_order.warehouse.name == warehouse.name\">\n                  {{ scheduleOrder.delivery_order.product.code }}\n                </span>\n              </span>\n            </td>\n            <td>\n              <span v-for=\"scheduleOrder in tour.deliveryScheduleOrders\">\n                <span v-if=\"scheduleOrder.delivery_order &&  scheduleOrder.delivery_order.warehouse.name == warehouse.name\">\n                  {{ scheduleOrder.delivery_quantity }}\n                </span>\n              </span>\n            </td>\n            <td>\n              <span v-for=\"scheduleOrder in tour.deliveryScheduleOrders\">\n                <span v-if=\"scheduleOrder.delivery_order &&  scheduleOrder.delivery_order.warehouse.name == warehouse.name\">\n                  {{ scheduleOrder.delivery_order.warehouse.name }}\n                </span>\n              </span>\n            </td>\n            <td>\n              {{ tour.transporter.name }}\n            </td>\n          </tr>\n        </tbody>\n      </table>\n    </div>\n  </div>\n</template>\n\n<script type=\"ts\">\nimport Vue from \"vue\";\nimport moment from \"moment\";\n\n// Keep only hour from datetime\nVue.filter('filterDateToHour', function(date) {\n  if (date) {\n    return moment(String(date)).format('HH:mm')\n  }\n});\n\n// Format datetime in french display\nVue.filter('filterDate', function(date) {\n  if (date) {\n    return moment(String(date)).format('DD/MM/YYYY')\n  }\n});\n\nexport default Vue.extend({\n  name: 'delivery-schedule-warehouse-charter-print',\n  props: ['warehouse', 'datefromstring', 'tours'],\n  data: () => ({\n  }),\n  mounted() {\n    // Print schedule\n    window.print();\n    // Close window after print\n    window.onafterprint = () => { window.close(); };\n  },\n});\n</script>\n\n<style scoped>\n\ntable {\n  width: 100%;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n  background-color: white;\n  border-collapse:  collapse;\n  font-size: 12px;\n}\n\nth {\n  color: black;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n}\n\ntd {\n  background-color: white;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n  text-align: center;\n}\n\n.red {\n  color: red;\n}\n\n</style>\n","<template>\n  <div class=\"mt-5\">\n       <!-- Orders -->\n    <div>\n      <table class=\"mt-4 mb-8\" >\n        <thead>\n            <tr>\n              <th style=\"width: 100px\">Date</th>\n              <th style=\"width: 100px\">N° immat.</th>\n              <th style=\"width: 200px\">Nom chauffeur</th>\n              <th>Travail à réaliser</th>\n              <th class=\"observations\">Observations</th>\n            </tr>\n        </thead>\n        <tbody>\n          <tr v-for=\"tour in tours\">\n            <td>{{ tour.dateWithoutHour | filterDate }}</td>\n            <td><strong>{{ tour.truck.numberplate }}</strong></td>\n            <td>\n              <strong>\n                {{ tour.driver.firstname }}<br>\n                {{ tour.driver.lastname }}<br>\n              </strong>\n              <span class=\"red--text\">\n                {{ tour.driver.phone}}\n              </span>\n            </td>\n            <td>\n              <ul v-for=\"scheduleOrder in tour.deliveryScheduleOrders\" style=\"list-style-type: none;\">\n                <li v-if=\"scheduleOrder.delivery_order &&  scheduleOrder.delivery_order.warehouse.name == warehouse.name\">\n                  -&nbsp;<strong>{{ scheduleOrder.delivery_order.warehouse.name }}</strong> :\n                  {{ scheduleOrder.delivery_order.product.name }} - {{ scheduleOrder.delivery_quantity }} T -\n                  {{ scheduleOrder.delivery_order.site.name }}\n                  <span v-if=\"scheduleOrder.momentDay || scheduleOrder.deliveryHour\"> -\n                    <span v-if=\"scheduleOrder.momentDay\"  class=\"red--text\">{{ scheduleOrder.momentDay.openingTime.name }} {{ scheduleOrder.comment_moments ? scheduleOrder.comment_moments : '' }}</span>\n                    <span v-if=\"scheduleOrder.deliveryHour\" class=\"red--text\">{{ scheduleOrder.deliveryHour | filterDateToHour }}</span>\n                  </span>\n                  <span v-if=\"scheduleOrder.schedule_comment\"> - {{ scheduleOrder.schedule_comment }}</span>\n                </li>\n              </ul>\n            </td>\n            <td>\n            </td>\n          </tr>\n        </tbody>\n      </table>\n    </div>\n  </div>\n</template>\n\n<script type=\"ts\">\nimport Vue from \"vue\";\nimport moment from \"moment\";\n\n// Keep only hour from datetime\nVue.filter('filterDateToHour', function(date) {\n  if (date) {\n    return moment(String(date)).format('HH:mm')\n  }\n});\n\n// Format datetime in french display\nVue.filter('filterDate', function(date) {\n  if (date) {\n    return moment(String(date)).format('DD/MM/YYYY')\n  }\n});\n\nexport default Vue.extend({\n  name: 'delivery-schedule-warehouse-print',\n  props: ['warehouse', 'datefromstring', 'tours'],\n  data: () => ({\n  }),\n  mounted() {\n    // Print schedule\n    window.print();\n    // Close window after print\n    window.onafterprint = () => { window.close(); };\n  },\n});\n</script>\n\n<style scoped>\n\ntable {\n  width: 100%;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n  background-color: white;\n  border-collapse:  collapse;\n  font-size: 12px;\n}\n\nth {\n  color: black;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n}\n\nth.observations {\n  width:25%;\n}\n\ntd {\n  background-color: white;\n  border: 1px solid rgba(76, 156, 199, 0.98);\n  border-radius: 3px;\n}\n\nth, td {\n  padding: 2px 5px;\n}\n\nh4 {\n  text-align: center\n}\n\n.red {\n  color: red;\n}\n\n</style>\n","<template>\n  <div style=\"height: 100%\">\n    <l-map\n      v-if=\"showMap\"\n      ref=\"map\"\n      :zoom=\"zoom\"\n      :center=\"center\"\n      :options=\"options\"\n      style=\"height: 100%\"\n      @update:center=\"centerUpdate\"\n      @update:zoom=\"zoomUpdate\"\n    >\n      <l-control-layers position=\"topright\"></l-control-layers>\n      <l-control-scale position=\"bottomleft\" :imperial=\"false\" :metric=\"true\"></l-control-scale>\n      <l-tile-layer\n        v-for=\"tileProvider in tileProviders\"\n        :key=\"tileProvider.name\"\n        :name=\"tileProvider.name\"\n        :visible=\"tileProvider.visible\"\n        :url=\"tileProvider.url\"\n        layer-type=\"base\"\n      >\n      </l-tile-layer>\n      <l-feature-group ref=\"features\"></l-feature-group>\n    </l-map>\n  </div>\n</template>\n\n<script type=\"ts\">\n  import Vue from \"vue\";\n  import L from \"leaflet\";\n  import LDraw from \"leaflet-draw\";\n  import LRouting from \"leaflet-routing-machine\";\n  import { LMap, LTileLayer, LControlLayers, LControlScale, LFeatureGroup, LIcon, LMarker } from \"vue2-leaflet\";\n  // import 'leaflet.markercluster';\n\n  export default Vue.extend({\n    name: \"make-itinerary-map\",\n    props: [\"markers\", \"center\", \"zoom\"],\n    components: { LMap, LTileLayer, LControlLayers, LControlScale, LFeatureGroup, LIcon, LMarker },\n    data: () => ({\n      currentZoom: 11.5,\n      currentCenter: null,\n      options: { zoomSnap: 0.5 },\n      map: null,\n      tileProviders: [\n        { name: \"Plan couleur\", visible: true, url: \"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\" },\n        { name: \"Plan noir et blanc\", visible: false, url: \"https://{s}.tiles.wmflabs.org/bw-mapnik/{z}/{x}/{y}.png\" },\n        { name: \"Satellite\", visible: false, url: \"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}\" },\n      ],\n      drawnItems: null,\n      routingControl: null,\n      markersList: [],\n      showMap: false\n    }),\n    watch: {\n      markers: function () {\n        this.markersList = this.markers ? [...this.markers] : [];\n        this.drawMarkersDirection();\n      },\n    },\n    mounted() {\n      this.markersList = this.markers ? [...this.markers] : [];\n\n      // Waiting map init\n      const _this = this;\n      setTimeout(function () {\n        _this.showMap = true;\n        _this.$nextTick(() => {\n          // Init leaflet map\n          _this.initMap();\n          // Draw markers and direction\n          _this.drawMarkersDirection();\n        });\n      }, 200);\n    },\n    methods: {\n      zoomUpdate(zoom) {\n        this.currentZoom = zoom;\n      },\n      centerUpdate(center) {\n        this.currentCenter = center;\n      },\n      initMap() {\n        // Map\n        this.map = this.$refs.map.mapObject;\n        // Items\n        this.drawnItems = L.featureGroup();\n        this.drawnItems.addTo(this.map);\n      },\n      waypointsChanged(e) {\n        this.markersList = this.routingControl.getWaypoints().map((w) => {\n          if (w.latLng) { // Only markers with coordinates\n            return {\n              latitude: w.latLng.lat,\n              longitude: w.latLng.lng,\n              description: w.options && w.options.description ? w.options.description : \"\",\n              title: w.options && w.options.title ? w.options.title : \"\",\n              position: w.options && w.options.position ? w.options.position : null,\n              color: w.options && w.options.color ? w.options.color : null,\n              type: w.options && w.options.type ? w.options.type : null,\n              additionnals: !(w.options && w.options.id),\n              uuid: w.options && w.options.uuid ? w.options.uuid : Math.random().toString(36).substr(2, 15),\n              id: w.options.id,\n              isNew: w.options && w.options.isNew\n            };\n          }\n        }).filter(w => w); // Not empty or null markers\n\n        this.$emit(\"updateMarkers\", this.markersList);\n      },\n      drawMarkersDirection() {\n        let markers = this.markersList.map(m => {\n          return {\n            latLng: L.latLng(m.latitude, m.longitude),\n            name: null,\n            options: {\n              title: m.name,\n              description: m.description,\n              id: m.id,\n              uuid: m.uuid,\n              color: m.color,\n              type: (m.type ?? null),\n              position: (m.position ?? ''),\n              isNew: false\n            },\n            used: false,\n            manual: true,\n            additionnals: m.additionnals\n          }\n        });\n\n        // Delete control to create new one\n        if (this.routingControl) { this.map.removeControl(this.routingControl); }\n        // Add routing with selected points\n        this.routingControl = L.Routing.control({\n          show: faplanninglse,\n          waypoints: markers,\n          lineOptions: {\n            styles : [{color: '#004487', opacity: 0.6, weight: 7}]\n          },\n          createMarker: (index, waypoint, nbWps) => {\n            if (index === 0) { markers.forEach((m) => m.used = false); }\n\n            let smallSize = false;\n            // Set position\n            if (!waypoint.options) { waypoint.options = {}; }\n            waypoint.options.isNew = !waypoint.manual ? !waypoint.options.isNew : false;\n            let markerName = waypoint.options.position;\n            // Blue color for detour\n            if (waypoint.options.isNew) { waypoint.options.color = '#ACF4FF'; }\n\n            // Marker already exist ?\n            let marks = markers.filter(d => d.latLng.lat === waypoint.latLng.lat && d.latLng.lng === waypoint.latLng.lng);\n            // Merge markers positions\n            if (marks.length > 0) {\n              // Stop create markers\n              if (marks.some(m => m.used)) { return null; }\n              // Create marker\n              marks.forEach(m => m.used = true);\n              // Set position with unique numbers\n              let posNumbers = [].concat(...marks.map(m => m.options.position.split(' - ')))\n              let uniqueNumbers = posNumbers.filter((v, i, s) => s.indexOf(v) === i);\n              waypoint.options.position = uniqueNumbers.join(' - ');\n              markerName = uniqueNumbers.length <= 2 ? waypoint.options.position : '***';\n              smallSize = (marks.length > 1 && uniqueNumbers.length <= 2);\n            }\n\n            // CREATE MARKER\n            let markerOptions = {\n              icon: this.getDefaultMarker(markerName, waypoint.options.color ? waypoint.options.color : '#004487', smallSize),\n              draggable: true\n            };\n            // Marker uuid\n            if (!waypoint.options.uuid) {\n              waypoint.options.uuid = Math.random().toString(36).substr(2, 15);\n            }\n            markerOptions.uuid = waypoint.options.uuid;\n            // Marker title\n            if (waypoint.options && waypoint.options.title) {\n              markerOptions.title = waypoint.options.title;\n            }\n            // Create marker\n            let marker = L.marker(\n              [waypoint.latLng.lat, waypoint.latLng.lng],\n              markerOptions\n            );\n            // Merker popup desc\n            if (waypoint.options && waypoint.options.description) {\n              // Content of popup: here the step number and description\n              marker.bindPopup('[' + waypoint.options.position + '] - ' + waypoint.options.description);\n              // Display/hide popup on mouse over/out\n              marker.on('mouseover', function () { this.openPopup() });\n              marker.on('mouseout', function () { this.closePopup() });\n            }\n            return marker;\n          },\n        }).on('waypointschanged', this.waypointsChanged);\n        // Add to map\n        if (this.routingControl && this.map) { this.routingControl.addTo(this.map); }\n      },\n      getDefaultMarker(text = '', color = '#004487', smallSize) {\n        return L.divIcon({\n          iconSize: null,\n          html:'<div class=\"marker\">' +\n                  '<span class=\"' + (smallSize ? 'pos-custom-small' : 'pos-custom') + '\">' + text.replaceAll(' - ', '<br>') + '</span>' +\n                  '<span class=\"marker-custom\" style=\"background-color: ' + color + '\"></span>' +\n              '</div>'\n        });\n      }\n    },\n  });\n</script>\n\n<style>\n  /* Hide leaflet itinerary */\n  div.leaflet-top.leaflet-right {\n    display: none !important;\n    width: 0 !important;\n    height: 0 !important;\n  }\n</style>\n","<template>\n  <div>\n    <v-row no-gutters>\n      <slot name=\"main\"></slot>\n    </v-row>\n    <v-row no-gutters class=\"px-1\">\n      <v-checkbox v-model=\"isParent\" label=\"Ce module est-il un enfant ?\"></v-checkbox>\n    </v-row>\n    <v-row no-gutters>\n      <slot v-if=\"isParent\" name=\"parent\"></slot>\n    </v-row>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport Vue from \"vue\";\n\nexport default Vue.extend({\n  name: \"module-edit-form\",\n  props: [\"module\"],\n  beforeMount() {\n    this.isParent = this.module.parent != null;\n  },\n  data: function () {\n    return {\n      isParent: false,\n    };\n  },\n});\n\n</script>\n\n<style scoped>\n.label {\n  width: 120px;\n  font-weight: 600;\n}\n</style>","<template>\n  <div id=\"card\">\n    <v-spacer></v-spacer>\n    <v-card class=\"mx-auto card\" max-width=\"100%\" outlined>\n      <v-img src=\"/build/images/blanc.jpg\" height=\"150\" contain></v-img>\n      <div class=\"infoCard\">\n        <span color=\"#f3f3f3\">{{ product.category }}</span>\n        <span>{{ product.name }}</span>\n        <span>Prix par {{ this.price }} :</span>\n        <span v-if=\"pricing === 'price6'\">{{ product.price6 }}</span>\n        <span v-else-if=\"pricing === 'price36'\">{{ product.price36 }}</span>\n        <span v-else-if=\"pricing === 'price72'\">{{ product.price72 }}</span>\n        <span v-else-if=\"pricing === 'price120'\">{{ product.price120 }}</span>\n        <span v-else-if=\"pricing === 'price180'\">{{ product.price180 }}</span>\n        <span v-else-if=\"pricing === 'price240'\">{{ product.price240 }}</span>\n        <span v-else-if=\"pricing === 'price300'\">{{ product.price300 }}</span>\n        <span v-else-if=\"pricing === 'price600'\">{{ product.price600 }}</span>\n      </div>\n      <div class=\"buttons\">\n        <v-btn text>Détails</v-btn>\n        <v-btn text><v-icon>mdi-heart-outline</v-icon></v-btn>\n        <v-btn color=\"secondary\" text\n          ><v-icon>mdi-basket-plus-outline</v-icon></v-btn\n        >\n      </div>\n    </v-card>\n    <v-spacer></v-spacer>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport Vue from \"vue\";\n\nexport default Vue.extend({\n  name: \"product-card\",\n  props: [\"product\", \"price\"],\n  data: function () {\n    return {\n      isActive: false,\n      pricing: \"price\" + this.price,\n    };\n  },\n});\n</script>\n   \n<style scoped>\n#card {\n  width: 31%;\n  display: inline-block;\n  margin: 0px 20px 20px 0px;\n  text-align: center;\n}\n.v-image {\n  display: inline-block;\n  width: 30%;\n}\n.infoCard {\n  display: inline-block;\n  width: 50%;\n  margin-top: 10px;\n  vertical-align: top;\n}\n.infoCard span {\n  display: block;\n  text-align: left;\n  font-size: 18px;\n}\n.infoCard span:nth-child(1) {\n  color: #707070;\n}\n.infoCard span:nth-child(3) {\n  color: #707070;\n  line-height: 40px;\n  font-size: 11px;\n}\n.infoCard span:nth-child(4) {\n  color: #fd6e60;\n  font-size: 28px;\n  font-weight: bold;\n}\n.buttons {\n  display: flex;\n  width: 100%;\n}\n.v-btn {\n  border-left: 1px solid #c2c2c2;\n  border-top: 1px solid #c2c2c2;\n  border-radius: 0;\n  height: 60px;\n  flex: 2 1 100px;\n}\n.v-btn:nth-child(1) {\n  border-left: 0;\n}\n</style>\n","<template>\n  <div>\n    <v-col v-if=\"isEdit\">\n      <slot></slot>\n    </v-col>\n    <v-col v-else>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">Nom</div>\n        <div class=\"py-1\">\n          <span class=\"text-capitalize\">{{ user.firstname }} </span>\n          <span class=\"text-uppercase\">{{ user.lastname }}</span>\n        </div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">Email</div>\n        <div class=\"py-1\">{{ user.email }}</div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">Téléphone</div>\n        <div class=\"py-1\">{{ user.address ? user.address.phone : '-'}}</div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">Adresse</div>\n        <div class=\"py-1\" v-if=\"user.address\">\n          <span>{{ user.address.address1 }}, {{ user.address.postcode }} {{ user.address.city }}</span>\n          <span>{{ user.address.country }}</span>\n        </div>\n        <div v-else>-</div>\n      </v-row>\n    </v-col>\n    <v-row no-gutters :justify=\"$vuetify.breakpoint.mdAndUp ? 'end' : 'center'\" v-if=\"!isEdit\">\n      <v-btn color=\"secondary\" v-on:click=\"isEdit = !isEdit\">\n        <v-icon left>mdi-pencil</v-icon>\n        Modifier les informations\n      </v-btn>\n    </v-row>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport Vue from \"vue\";\n\nexport default Vue.extend({\n  name: \"user-edit-form\",\n  props: [\"user\"],\n  mounted: function () {\n    this.$emitter.on(\"toggle-user-info\", () => {\n      this.isEdit = !this.isEdit;\n    });\n  },\n  data: function () {\n    return {\n      isEdit: false,\n    };\n  },\n});\n\n</script>\n\n<style scoped>\n.label {\n  width: 120px;\n  font-weight: 600;\n}\n</style>\n","<template>\n  <div>\n    <v-card>\n      <v-row no-gutters>\n        <v-col md=\"2\">\n          <v-checkbox class=\"ml-3 mt-3\" v-model=\"form.isCharted\" :value=\"form.isCharted\" label=\"Affrètement\" hide-details name=\"is_charted\"></v-checkbox>\n        </v-col>\n        <v-col md=\"2\">\n          <v-checkbox class=\"ml-3 mt-3\" v-model=\"form.isInert\" :value=\"form.isInert\" label=\"Inerte\" hide-details name=\"is_inert\"></v-checkbox>\n        </v-col>\n      </v-row>\n      <v-row no-gutters>\n        <v-col>\n          <api-select-autocomplete\n              select-class=\"pa-2 required\"\n              formName=\"customer\"\n              label=\"codeName\"\n              value=\"uuid\"\n              placeholder=\"Client\"\n              :filters=\"form\"\n              filter-name=\"customeruuid\"\n              resource=\"accounts\"\n              :params=\"{order: {code: 'asc'}, type: 1, isArchived: '0'}\"\n              :required=\"true\"\n              @change=\"siteKey++\"\n              :disabled=\"origin === 'quote'\"\n              :key=\"customerKey\"\n              :groups=\"['api:account']\"\n          >\n          </api-select-autocomplete>\n        </v-col>\n        <v-col>\n          <api-select-autocomplete\n              select-class=\"pa-2 required\"\n              :key=\"siteKey\"\n              label=\"name\"\n              value=\"id\"\n              formName=\"site\"\n              placeholder=\"Chantier\"\n              :filters=\"form\"\n              filter-name=\"site\"\n              resource=\"sites\"\n              :params=\"{'order': { name: 'asc' }, 'client.uuid': form.customeruuid ? form.customeruuid : null}\"\n              :disabled=\"origin === 'quote'\"\n              :required=\"true\"\n              name=\"site\"\n              @change=\"updateSite\"\n              :groups=\"['api:account']\"\n              :lists.sync=\"sites\"\n          ></api-select-autocomplete>\n        </v-col>\n        <v-col>\n          <!-- On click, create event \"openModalSite\" and pass it state and customer -->\n          <v-btn v-if=\"(origin === 'manual' || origin === 'split')\" class=\"mt-2 ml-5\" color=\"primary\" :disabled=\"!form.customeruuid\"\n                 @click=\"$emitter.emit('openModalSiteCreate', { stateModal: true, customeruuid: form.customeruuid, customername: form.customername})\">\n            <v-icon left>mdi-plus</v-icon>\n            Ajouter un chantier\n          </v-btn>\n        </v-col>\n      </v-row>\n      <v-row no-gutters>\n        <v-col cols=\"3\">\n          <v-autocomplete v-model=\"form.warehouseType\" name=\"warehouseType\" :items=\"warehouseTypes\" label=\"Type de carrière\" outlined item-text=\"name\" required\n                          item-value=\"code\" class=\"pa-2 required\" dense hide-details=\"auto\" clearable @change=\"changeWarehouseType\">\n          </v-autocomplete>\n        </v-col>\n        <v-col cols=\"3\">\n          <api-select-autocomplete\n              select-class=\"pa-2 required\"\n              formName=\"warehouse\"\n              label=\"name\"\n              value=\"uuid\"\n              placeholder=\"Carrière\"\n              :filters=\"form\"\n              filter-name=\"warehouseuuid\"\n              resource=\"warehouses\"\n              :params=\"warehouseParams\"\n              @change=\"changeWarehouse\"\n              :required=\"true\"\n              :reload=\"warehouseKey\"\n              :groups=\"['form.read']\"\n          >\n          </api-select-autocomplete>\n        </v-col>\n        <v-col cols=\"3\">\n          <v-autocomplete v-model=\"form.product\" name=\"product\" :items=\"form.products\" label=\"Produit\" outlined item-text=\"name\" required\n                          item-value=\"id\" class=\"pa-2 required\" dense hide-details=\"auto\" clearable\n          />\n        </v-col>\n        <v-col cols=\"3\">\n          <v-text-field v-model=\"form.quantity\" label=\"Quantité\" name=\"quantity\" type=\"number\" pattern=\"[0-9]*\" class=\"pa-2 required\"\n                        dense hide-details=\"auto\" outlined clearable required\n          />\n        </v-col>\n      </v-row>\n      <v-row no-gutters>\n        <v-col cols=\"7\">\n          <v-row no-gutters>\n            <v-col class=\"pa-2\">\n              <v-textarea rows=\"2\" v-model=\"form.commentplanning\" name=\"commentplanning\" label=\"Commentaire planning\"\n                          outlined hide-details class=\"pb-2\" prepend-inner-icon=\"mdi-comment-search-outline\" clearable\n                          @click:prepend-inner=\"showCommentsModal('schedule', 'commentPlanning')\" ref=\"commentPlanning\"\n              ></v-textarea>\n              <v-textarea rows=\"2\" v-model=\"form.commentsOrder\" name=\"commentsOrder\" label=\"Commentaire commande\"\n                          outlined hide-details class=\"pt-2\" prepend-inner-icon=\"mdi-comment-search-outline\" clearable\n                          @click:prepend-inner=\"showCommentsModal('order', 'commentOrder')\" ref=\"commentOrder\"\n              ></v-textarea>\n            </v-col>\n            <v-col>\n              <v-textarea rows=\"5\" v-model=\"form.commentdriver\" name=\"commentdriver\" label=\"Commentaire chauffeur\"\n                          outlined hide-details class=\"pa-2\" prepend-inner-icon=\"mdi-comment-search-outline\" clearable\n                          @click:prepend-inner=\"showCommentsModal('driver', 'commentDriver')\" ref=\"commentDriver\"\n              ></v-textarea>\n            </v-col>\n          </v-row>\n        </v-col>\n        <v-col cols=\"5\">\n          <v-row no-gutters>\n            <v-col>\n              <v-text-field v-model=\"deliveryDate\" label=\"Date de livraison\" name=\"deliveryDate\" type=\"date\" class=\"pr-4 mr-0 mt-4 required\"\n                            dense hide-details=\"auto\" outlined clearable required></v-text-field>\n            </v-col>\n            <v-col>\n              <v-text-field v-model=\"form.externalCode\" label=\"Ref. cde. client\" name=\"externalCode\" type=\"text\" class=\"pr-4 mr-0 mt-4\"\n                            dense hide-details=\"auto\" outlined clearable></v-text-field>\n            </v-col>\n          </v-row>\n          <p class=\"mb-0 text-center mt-2 mb-2 font-weight-bold\">{{ form.isInert ? 'Réceptions' : 'Livraisons' }}</p>\n          <v-row no-gutters>\n            <v-col cols=\"7\" class=\"mb-4\">\n              <template v-for=\"(mo, idx) in momentsDays\">\n                <v-row no-gutters>\n                  <v-col cols=\"10\">\n                    <v-select v-model=\"mo.code\" label=\"Moments de la journée\" :items=\"form.openingTime\" dense :disabled=\"mo.used\"\n                              :title=\"mo.used ? 'Affecté à un tour' : ''\" item-value=\"code\" item-text=\"name\"\n                              hide-details=\"auto\" class=\"mr-1 mt-2\" outlined clearable>\n                    </v-select>\n                  </v-col>\n                  <v-col cols=\"2\">\n                    <v-btn :disabled=\"mo.used\" outlined color=\"error\" class=\"btn mb-0\" x-small type=\"button\"\n                           :title=\"mo.used ? 'Affecté à un tour' : 'Supprimer le moment'\" @click=\"removeMomentDay(idx)\">-</v-btn>\n                    <v-btn title=\"Ajouter un moment\" v-if=\"(idx + 1) === momentsDays.length\" outlined x-small\n                           color=\"primary\" class=\"btn mt-0\" type=\"button\" @click=\"addMomentDay()\">+</v-btn>\n                  </v-col>\n                </v-row>\n              </template>\n              <input type=\"hidden\" name=\"momentsDays\" :value=\"JSON.stringify(momentsDays)\" />\n            </v-col>\n            <v-col cols=\"5\" class=\"mb-4\">\n              <template v-for=\"(timeItem, idx) in times\">\n                <v-row no-gutters>\n                  <v-col cols=\"8\">\n                    <v-text-field :disabled=\"timeItem.used\" hide-details text-align=\"center\" class=\"centered-input p-0 m-0\" v-model=\"timeItem.time\" type=\"time\"></v-text-field>\n                  </v-col>\n                  <v-col cols=\"4\">\n                    <v-btn :disabled=\"timeItem.used\" title=\"Supprimer l'horaire\" outlined color=\"error\" class=\"btn mb-0\" x-small type=\"button\" @click=\"removeTime(idx)\">-</v-btn>\n                    <v-btn title=\"Ajouter un horaire\" v-if=\"(idx + 1) === times.length\" outlined x-small color=\"primary\" class=\"btn mt-0\" type=\"button\" @click=\"addTime()\">+</v-btn>\n                  </v-col>\n                </v-row>\n              </template>\n              <input type=\"hidden\" name=\"times\" :value=\"JSON.stringify(times)\" />\n            </v-col>\n          </v-row>\n        </v-col>\n      </v-row>\n    </v-card>\n    <CommentsListModal\n        :is-open-modal=\"isOpenCommentModal\" :types=\"commentModalType\"\n        @close=\"isOpenCommentModal = false\" @update:comment=\"updateCommentValue($event)\"\n    />\n  </div>\n</template>\n\n<script type=\"ts\">\nimport Vue from \"vue\";\nimport moment from \"moment\";\nimport CommentsListModal from \"../../comment/component/CommentsListModal.vue\";\n\nexport default Vue.extend({\n  name: \"order-item-manual-form\",\n  components: {CommentsListModal},\n  props: ['dialog', 'customeruuid', 'orderItem', 'origin', 'site', 'quantity', 'datetomorrow', 'socName'],\n  data: (_this) => ({\n    times: [], // Times array\n    momentsDays: [],\n    defaultTime: { time: null, used: false },\n    defaultMomentDay: { code: null, used: false },\n    form: {\n      customeruuid: '',\n      customername: '',\n      site: null,\n      sites: [],\n      warehouseuuid: null,\n      product: null,\n      products: [],\n      quantity: 30,\n      openingTime: [{name: 'Journée', code: 'day'}, {name: 'Matin', code: 'morning'}, {name: 'Après-Midi', code: 'afternoon'}],\n      commentplanning: '',\n      commentdriver: '',\n      isCharted: false,\n      externalCode: null,\n      warehouseType: 'KM',\n      isInert: false\n    },\n    deliveryDate: null,\n    warehouses: [],\n    customers: [],\n    customerKey: 0,\n    warehouseKey: 0,\n    warehouseTypes: [\n      { code: 'KM', name: (_this.socName ?? '-'), params: {order: {name: 'asc'}, isTransport: '0', isTrading: '0'}},\n      { code: 'TRADING', name: 'Négoce', params: {order: {name: 'asc'}, isTransport: '0', isTrading: '1'}},\n      { code: 'TRANSPORT', name: 'Transport', params: {order: {name: 'asc'}, isTransport: '1', isTrading: '0'}},\n      { code: 'BOTH', name: 'Négoce et transport', params: {order: {name: 'asc'}, isTransport: '1', isTrading: '1'}},\n    ],\n    warehouseParams: null,\n    siteKey: 0,\n    sites: [],\n    isOpenCommentModal: false,\n    commentModalType: [],\n    updatableCommentRef: null\n  }),\n  beforeMount() {\n    this.deliveryDate = !this.datetomorrow ? this.$tomorrow.format('YYYY-MM-DD') : moment(this.datetomorrow).format('YYYY-MM-DD');\n\n    // Order form\n    if (this.orderItem) {\n      this.form = {\n        customeruuid: this.orderItem.customer && this.orderItem.customer.uuid ? this.orderItem.customer.uuid : '',\n        customername: this.orderItem.customer && this.orderItem.customer.name ? this.orderItem.customer.name : '',\n        openingTime: [{name: 'Journée', code: 'day'}, {name: 'Matin', code: 'morning'}, {name: 'Après-Midi', code: 'afternoon'}],\n        commentplanning: this.orderItem.commentsPlanning ? this.orderItem.commentsPlanning : '',\n        commentdriver: this.orderItem.commentsDriver ? this.orderItem.commentsDriver : '',\n        commentsOrder: this.orderItem.commentsOrder ? this.orderItem.commentsOrder : '',\n        isCharted: !!this.orderItem.is_charted,\n        products: [],\n        sites: [],\n        site: this.orderItem.site?.id ?? null,\n        externalCode: this.orderItem.externalCode ? this.orderItem.externalCode : '',\n        warehouseType: this.orderItem.warehouseType ?? (this.$appTheme === 'luche' ? 'Luché' : 'KM'),\n        isInert: this.orderItem.isInert\n      };\n\n      this.changeWarehouseType();\n\n      switch (this.origin) {\n        case 'manual':\n          this.form.warehouseuuid = this.orderItem.warehouse && this.orderItem.warehouse.uuid ? this.orderItem.warehouse.uuid : null; // Warehouse\n          this.form.site = this.orderItem.site && this.orderItem.site.id ? this.orderItem.site.id : null; // Site\n          this.form.quantity = this.orderItem.quantityOrdered ? this.orderItem.quantityOrdered : (this.quantity ? this.quantity : null); // Qty\n          break;\n        case 'quote':\n        case 'split':\n          this.form.warehouseuuid = this.orderItem.warehouse && this.orderItem.warehouse.uuid ? this.orderItem.warehouse.uuid : null; // Warehouse\n          this.form.site = this.site && this.site.id ? this.site.id : null; // Site\n          this.form.quantity = this.quantity ? this.quantity : null; // Qty\n          break;\n      }\n\n      this.form.product = this.orderItem.product && this.orderItem.product.id ? this.orderItem.product.id : null;\n      this.times = this.orderItem.deliveryTimes ? this.orderItem.deliveryTimes : [];\n\n      if (this.times.length === 0) { this.addTime(); }\n\n      this.momentsDays = this.orderItem.momentsDays ? this.orderItem.momentsDays.map(m => { let mo = m.openingTime; mo.id = m.id; mo.used = m.used; return mo; }) : [];\n      if (this.momentsDays.length === 0) { this.addMomentDay(); }\n    } else {\n      // If no time saved\n      this.addTime(); // Add a default time\n      this.addMomentDay();\n      // Else retrieve them with this.times = ...\n      if (this.customeruuid) {\n        this.form.customeruuid = this.customeruuid;\n        if (this.site && this.site.id) { this.form.site = this.site.id; }\n      }\n    }\n\n    // Add create site to list and select it\n    this.$emitter.on('order-manual-add-site', (site) => {\n      this.siteKey++;\n      this.form.site = site.id;\n    });\n  },\n  methods: {\n    changeWarehouse(e) {\n      if (e && e.list && e.list.length > 0) {\n        this.warehouses = e.list;\n        let warehouse = this.warehouses.find(w => w.uuid == this.form.warehouseuuid);\n        // Retrieve products list from warehouse\n        if (warehouse && warehouse.uuid) {\n          this.form.products = [...warehouse.products];\n        } else {\n          this.form.products = [];\n        }\n\n        if (!this.form.products.map(s => s.id).includes(this.form.product)) {\n          this.form.product = null;\n        }\n      }\n    },\n    addTime() {\n      this.times.push({...this.defaultTime});\n    },\n    addMomentDay() {\n      this.momentsDays.push({...this.defaultMomentDay});\n    },\n    removeTime(idx) {\n      if (this.times.length > 1) {\n        this.times.splice(idx, 1)\n      }\n    },\n    removeMomentDay(idx) {\n      if (this.momentsDays.length > 1) {\n        this.momentsDays.splice(idx, 1)\n      }\n    },\n    changeWarehouseType() {\n      let wt = this.warehouseTypes.find(w => w.code === this.form.warehouseType);\n      this.warehouseParams = wt ? wt.params : null;\n      this.warehouseKey++;\n    },\n    updateSite(param) {\n      let site = param.list ? param.list.find(s => s.id === this.form.site) : null;\n      this.$emitter.emit('orderItem-update-site', (site && site.id ? site : null));\n    },\n    showCommentsModal(type, ref) {\n      this.isOpenCommentModal = true;\n      this.commentModalType = [type];\n      this.updatableCommentRef = ref;\n    },\n    updateCommentValue(comment) {\n      this.$refs[this.updatableCommentRef].internalValue += comment;\n      this.isOpenCommentModal = false\n    }\n  }\n});\n</script>\n\n<style scoped>\n  .centered-input >>> input {\n    text-align: center\n  }\n</style>\n","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n#map {\n  max-width: 100%;\n  max-height: 100%;\n\n  path {\n    fill: #395a6b;\n    stroke: #ffffff;\n    stroke-width: 0.6;\n    transition: fill 0.2s, stroke 0.3s;\n  }\n  path:hover {\n    fill: red;\n    stroke: red;\n  }\n  .separator {\n    stroke: #ccc;\n    fill: none;\n    stroke-width: 1.5;\n  }\n  .separator:hover {\n    stroke: #ccc;\n    fill: none;\n  }\n  .affecte {\n    fill: #fd6e60;\n    stroke: #ffffff;\n    stroke-width: 1.5;\n  }\n}\n\n#tooltip {\n  position: absolute;\n  background-color: #ffffff;\n  color: #395a6b;\n  border-style: inset;\n  padding: 4px;\n  width: 200px;\n  z-index: 1;\n  display: none;\n}\n","<template>\n  <l-map\n    v-on:click=\"addMarker\"\n    ref=\"map\"\n    :zoom=\"zoom\"\n    :center=\"center\"\n    :options=\"options\"\n    style=\"height: 350px\"\n    @update:center=\"centerUpdate\"\n    @update:zoom=\"zoomUpdate\"\n  >\n    <l-control-layers position=\"topright\"></l-control-layers>\n    <l-control-scale\n      position=\"bottomleft\"\n      :imperial=\"false\"\n      :metric=\"true\"\n    ></l-control-scale>\n    <l-tile-layer\n      v-for=\"tileProvider in tileProviders\"\n      :key=\"tileProvider.name\"\n      :name=\"tileProvider.name\"\n      :visible=\"tileProvider.visible\"\n      :url=\"tileProvider.url\"\n      layer-type=\"base\"\n    >\n    </l-tile-layer>\n    <l-feature-group ref=\"features\"></l-feature-group>\n  </l-map>\n</template>\n\n<script>\nimport Vue from \"vue\";\nimport L from \"leaflet\";\nimport {\n  LMap,\n  LTileLayer,\n  LControlLayers,\n  LControlScale,\n  LFeatureGroup,\n  LIcon,\n  LMarker,\n} from \"vue2-leaflet\";\n\nexport default Vue.extend({\n  name: \"sector-map-creation\",\n  components: {\n    LMap,\n    LTileLayer,\n    LControlLayers,\n    LControlScale,\n    LFeatureGroup,\n    LIcon,\n    LMarker,\n  },\n\n  props: [\"markers\", \"center\", \"zoom\"],\n  data: () => ({\n    currentZoom: 11.5,\n    currentCenter: null,\n    options: { zoomSnap: 0.5 },\n    map: null,\n    tileProviders: [\n      {\n        name: \"Plan couleur\",\n        visible: true,\n        url: \"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\",\n      },\n      {\n        name: \"Plan noir et blanc\",\n        visible: false,\n        url: \"https://{s}.tiles.wmflabs.org/bw-mapnik/{z}/{x}/{y}.png\",\n      },\n      {\n        name: \"Satellite\",\n        visible: false,\n        url: \"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}\",\n      },\n    ],\n    markersList: [],\n    layers: [],\n  }),\n  watch: {\n    markers: function () {\n      this.markersList = this.markers ? [...this.markers] : [];\n      this.clearMap();\n      this.updateMap();\n    },\n  },\n  mounted() {\n    this.markersList = this.markers ? [...this.markers] : [];\n\n    this.$nextTick(() => {\n      // Init leaflet map\n      this.initMap();\n      this.$emit(\"childToParent\", this.markersList);\n      this.updateMap();\n    });\n  },\n  methods: {\n    zoomUpdate(zoom) {\n      this.currentZoom = zoom;\n    },\n    centerUpdate(center) {\n      this.currentCenter = center;\n    },\n    initMap() {\n      // Map\n      this.map = this.$refs.map.mapObject;\n    },\n    addMarker(event) {\n      let markerOptions = { icon: this.getDefaultMarker() };\n\n      this.markersList.push(event.latlng);\n      if (this.markersList && this.markersList.length > 0) {\n        this.markersList.forEach((item, index) => {\n          let layer = L.marker(item, markerOptions);\n          layer.bindPopup(\"point n°\" + (index + 1).toString()).openPopup();\n          this.layers.push(layer);\n          layer.addTo(this.map);\n        });\n\n        L.polygon(this.markersList).addTo(this.map);\n      }\n      this.$emit(\"childToParent\", this.markersList);\n    },\n    clearMap() {\n      if (this.map) {\n        //on clear les markers\n        this.layers.forEach((item) => { this.map.removeLayer(item); });\n        //on clear le polygon\n        const m = this.map;\n        for (let i in m._layers) {\n          if (m._layers[i]._path !== undefined) {\n            try {\n              m.removeLayer(m._layers[i]);\n            } catch (e) {\n              console.log(\"problem with \" + e + m._layers[i]);\n            }\n          }\n        }\n      }\n    },\n    updateMap() {\n      let markerOptions = { icon: this.getDefaultMarker() };\n      if (this.markersList && this.markersList.length > 0) {\n        this.markersList.forEach((item, index) => {\n          let layer = L.marker(item, markerOptions);\n          layer.bindPopup(\"point n°\" + (index + 1).toString()).openPopup();\n          this.layers.push(layer);\n          layer.addTo(this.map);\n        });\n\n        L.polygon(this.markersList).addTo(this.map);\n      }\n    },\n    getDefaultMarker() {\n      return new L.Icon({\n        iconUrl: \"/img/default-marker.png\",\n        iconAnchor: new L.Point(16, 16),\n      });\n    },\n  },\n});\n</script>\n<style>\n.wrapper {\n  max-width: 400px;\n  margin: 0 auto;\n}\n</style>\n","<template>\n  <div>\n    <v-col v-if=\"isEdit\">\n      <slot></slot>\n    </v-col>\n    <v-col v-else>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">\n          <v-icon color=\"primary\" class=\"mr-2\">mdi-account</v-icon>\n          Nom\n        </div>\n        <div class=\"py-1\">\n          <span class=\"text-capitalize\">{{ user.firstname }} </span>\n          <span class=\"text-uppercase\">{{ user.lastname }}</span>\n        </div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">\n          <v-icon color=\"primary\" class=\"mr-2\">mdi-mail</v-icon>\n          Email\n        </div>\n        <div class=\"py-1\">{{ user.email }}</div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">\n          <v-icon color=\"primary\" class=\"mr-2\">mdi-phone</v-icon>\n          Téléphone\n        </div>\n        <div class=\"py-1\">{{ user.address ? user.address.phone : '-'}}</div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">\n          <v-icon color=\"primary\" class=\"mr-2\">mdi-map-marker</v-icon>\n          Adresse\n        </div>\n        <div class=\"py-1\" v-if=\"user.address\">\n          <span>{{ user.address.address1 }}, {{ user.address.postcode }} {{ user.address.city }}</span>\n          <span>{{ user.address.country }}</span>\n        </div>\n        <div v-else>-</div>\n      </v-row>\n      <v-row no-gutters>\n        <div class=\"py-1 label\">\n          <v-icon color=\"primary\" class=\"mr-2\">mdi-shield</v-icon>\n          Profil utilisateur\n        </div>\n        <div class=\"py-1\">{{ user.profile.name}}</div>\n      </v-row>\n    </v-col>\n    <v-row no-gutters :justify=\"$vuetify.breakpoint.mdAndUp ? 'end' : 'center'\" v-if=\"!isEdit\">\n      <v-btn color=\"secondary\" v-on:click=\"isEdit = !isEdit\">\n        <v-icon left>mdi-pencil</v-icon>\n        Modifier les informations\n      </v-btn>\n    </v-row>\n  </div>\n</template>\n\n<script lang=\"ts\">\nimport Vue from \"vue\";\n\nexport default Vue.extend({\n  name: \"user-edit-form\",\n  props: [\"user\"],\n  mounted: function () {\n    this.$emitter.on(\"toggle-user-info\", () => {\n      this.isEdit = !this.isEdit;\n    });\n  },\n  data: function () {\n    return {\n      isEdit: false,\n    };\n  },\n});\n\n</script>\n\n<style scoped>\n.label {\n  width: 200px;\n  font-weight: 600;\n}\n</style>\n","<template>\n  <div>\n    <l-map\n      v-if=\"showMap\"\n      ref=\"map\"\n      :zoom=\"zoom\"\n      :center=\"center\"\n      :options=\"options\"\n      style=\"height: 350px\"\n      @update:center=\"centerUpdate\"\n      @update:zoom=\"zoomUpdate\"\n    >\n      <l-tile-layer\n        v-for=\"tileProvider in tileProviders\"\n        :key=\"tileProvider.name\"\n        :name=\"tileProvider.name\"\n        :visible=\"tileProvider.visible\"\n        :url=\"tileProvider.url\"\n        layer-type=\"base\"\n      >\n      </l-tile-layer>\n      <l-feature-group ref=\"features\"></l-feature-group>\n    </l-map>\n  </div>\n</template>\n\n<script type=\"ts\">\n  import Vue from \"vue\";\n  import L from \"leaflet\";\n  import LDraw from \"leaflet-draw\";\n  import { LMap, LTileLayer, LControlLayers, LControlScale, LFeatureGroup, LIcon, LMarker } from \"vue2-leaflet\";\n\n  export default Vue.extend({\n    name: \"markers-on-map\",\n    props: [\"markers\", \"center\", \"zoom\", \"draggable\"],\n    components: { LMap, LTileLayer, LControlLayers, LControlScale, LFeatureGroup, LIcon, LMarker },\n    data: () => ({\n      currentZoom: 11.5,\n      currentCenter: null,\n      options: { zoomSnap: 0.5 },\n      map: null,\n      tileProviders: [\n        { name: \"Plan couleur\", visible: true, url: \"https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png\" },\n        { name: \"Plan noir et blanc\", visible: false, url: \"https://{s}.tiles.wmflabs.org/bw-mapnik/{z}/{x}/{y}.png\" },\n        { name: \"Satellite\", visible: false, url: \"https://server.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}\" },\n      ],\n      drawnItems: null,\n      layerGroupMarkers: null,\n      markersList: [],\n      showMap: false\n    }),\n    watch: {\n      markers: function () {\n        this.markersList = this.markers ? [...this.markers] : [];\n        this.drawMarkers();\n      },\n    },\n    beforeMount() {\n      this.markersList = this.markers ? [...this.markers] : [];\n\n      // Waiting map init\n      const _this = this;\n      setTimeout(function () {\n        _this.showMap = true;\n        _this.$nextTick(() => {\n          // Init leaflet map\n          _this.initMap();\n          // Draw markers and direction\n          _this.drawMarkers();\n        });\n      }, 200);\n    },\n    methods: {\n      zoomUpdate(zoom) {\n        this.currentZoom = zoom;\n      },\n      centerUpdate(center) {\n        this.currentCenter = center;\n      },\n      initMap() {\n        // Map\n        this.map = this.$refs.map.mapObject;\n        // Items\n        this.drawnItems = L.featureGroup();\n        this.drawnItems.addTo(this.map);\n      },\n      drawMarkers() {\n        let markersBounds = [];\n        // Delete layer to create new one\n        if (this.layerGroupMarkers) { this.map.removeControl(this.layerGroupMarkers); }\n        // Add layer with selected points\n        this.layerGroupMarkers = new L.LayerGroup();\n        // Add markers\n        this.markersList.map((m) => {\n          return {\n            latLng: L.latLng(m.latitude, m.longitude),\n            name: null,\n            options: { title: m.name, description: m.description, id: m.id, uuid: m.uuid, color: m.color ? m.color : '#000000' },\n          };\n        }).forEach((m, idx) => {\n          let marker = this.createMarker(idx, m)\n          marker.addTo(this.layerGroupMarkers);\n          markersBounds.push(marker);\n        });\n\n        // Add to map\n        if (this.layerGroupMarkers && this.map) { this.layerGroupMarkers.addTo(this.map); }\n\n        this.map.fitBounds((new L.featureGroup(markersBounds)).getBounds());\n      },\n      getDefaultMarker(pos = '', color = '#004487') {\n        return L.divIcon({\n          iconSize: null,\n          html:'<div class=\"marker\"><span class=\"marker-custom\" style=\"background-color: ' + color + '\"></span></div>'\n        });\n      },\n      createMarker(index, waypoint) {\n        let markerOptions = {\n          icon: this.getDefaultMarker('', waypoint.options && waypoint.options.color ? waypoint.options.color : null),\n          draggable: this.draggable,\n        };\n        // Set position\n        if (!waypoint.options) { waypoint.options = {}; }\n        waypoint.options.position = index + 1;\n        // Marker title\n        if (waypoint.options && waypoint.options.title) {\n          markerOptions.title = waypoint.options.title;\n        }\n        // Marker uuid\n        if (waypoint.options && waypoint.options.uuid) {\n          markerOptions.uuid = waypoint.options.uuid;\n        }\n        // Create marker\n        let marker = L.marker(\n            [waypoint.latLng.lat, waypoint.latLng.lng],\n            markerOptions\n        );\n        // Merker popup desc\n        if (waypoint.options && waypoint.options.description) {\n          // Content of popup: here the step number and description\n          marker.bindPopup(waypoint.options.position + ' - ' + waypoint.options.description);\n          // Display/hide popup on mouse over/out\n          marker.on('mouseover', () => { this.openPopup(); });\n          marker.on('mouseout', () => { this.closePopup(); });\n        }\n        // Update marker location\n        marker.on('dragend', (e) => { this.updateMarkers(e); });\n\n        return marker;\n      },\n      updateMarkers(e) {\n        if (e.target) {\n          let marker = this.markersList.find(m => e.target.options && e.target.options.uuid ? (m.uuid === e.target.options.uuid) : false);\n\n          if (marker && e.target._latlng) {\n            marker.latitude = e.target._latlng.lat;\n            marker.longitude = e.target._latlng.lng;\n          }\n\n          this.$emit('updateMarkers', this.markersList);\n        }\n      }\n    },\n  });\n</script>\n\n<style>\n  /* Hide leaflet itinerary */\n  div.leaflet-top.leaflet-right {\n    display: none !important;\n    width: 0 !important;\n    height: 0 !important;\n  }\n</style>\n","<template>\n  <div>\n    <v-card elevation=\"2\" tile>\n      <v-row no-gutters class=\"pa-2\" v-if=\"!hideFilters\">\n        <slot name=\"filters\" :filters.sync=\"filters\" :trigger=\"filterChange\"></slot>\n      </v-row>\n      <v-data-table\n          v-model=\"checked\"\n          :headers=\"headers\"\n          :items=\"data\"\n          :options.sync=\"options\"\n          :server-items-length=\"itemCount\"\n          :loading=\"loading\"\n          loading-text=\"Chargement...\"\n          class=\"elevation-1\"\n          :items-per-page=\"nbItemsPerPage\"\n          :footer-props=\"{ 'items-per-page-text':'Lignes par page', 'items-per-page-options': [10, 20, 30, 50, -1] }\"\n          :item-class=\"itemRowBackground\"\n          :show-select=\"checkable\"\n      >\n        <template #item.thumb=\"{ item }\">\n          <slot name=\"thumb\">\n            <v-img :src=\"item.thumb\" height=\"50px\" width=\"50px\"></v-img>\n          </slot>\n        </template>\n\n        <template #item.actions=\"{ item }\">\n          <v-icon v-if=\"((action.name === 'reset' && !item.isActive) ||\n                         (action.name === 'archive' && !item.isArchived) ||\n                         (action.name !== 'reset' && action.name !== 'archive')) &&\n                         (!action.rights || checkRights(action.rights))\"\n                  @click=\"route(item, action.name, (action.target ? action.target : null), action.url, action.param, action.confirm, action.isNotifyDeliverySchedule)\"\n                  v-for=\"action in actions\"\n                  :key=\"action.name\"\n                  :color=\"getColor(action, item)\"\n                  :title=\"getTitle(action, item)\"\n          >\n            <template v-if=\"action.icon\">\n              {{ action.icon }}\n            </template>\n            <template v-else-if=\"action.icons && action.icons.type === 'showMapMarker' && item.address && item.address.latitude && item.address.longitude\">\n                {{ action.icons.with }}\n            </template>\n            <template v-else-if=\"action.icons && action.icons.type === 'showMapMarker'\">\n                {{ action.icons.without }}\n            </template>\n          </v-icon>\n        </template>\n\n        <!-- templates to format date -->\n        <template #item.date=\"{ item }\">\n          {{ item.date | date }}\n        </template>\n        <template #item.startValidity=\"{ item }\">\n          {{ item.startValidity | date }}\n        </template>\n        <template #item.endValidity=\"{ item }\">\n          {{ item.endValidity | date }}\n        </template>\n        <template #item.deliveryDate=\"{ item }\">\n          {{ item.deliveryDate | date }}\n        </template>\n        <template #item.dateWithoutHour=\"{ item }\">\n          {{ item.dateWithoutHour | date }}\n        </template>\n\n        <!-- template to display all details orders in schedule list -->\n        <template #item.details=\"{ item }\">\n          <ol style=\"padding-left: 10px!important;\" class=\"pt-2\">\n            <draggable :list=\"item.details\" :group=\"'deliveryScheduleOrder-' + item.id\" @change=\"changeOrderPosition(item)\" :disabled=\"!canDraggable(item.details)\">\n              <li v-for=\"detail in item.details\" :key=\"detail.deliveryScheduleId\">\n                <v-row v-if=\"detail.isComment\" class=\"primary--text\" style=\"font-style: italic;\">\n                  <v-col>\n                    <v-icon color=\"primary\" small class=\"mr-2\">mdi-comment-text-outline</v-icon>{{ detail.text }}\n                  </v-col>\n                </v-row>\n                <v-row v-else no-gutters>\n                  <v-col>\n                    <v-row no-gutters>\n                      <div :style=\"{'background-color': detail.warehouseColor ? detail.warehouseColor : '', 'width': '5px', 'margin-right': '5px'}\"></div>\n                      <span class=\"font-weight-bold\">{{ detail.warehouse }}</span> -\n                      {{ detail.customer }} -\n                      <span class=\"font-weight-bold\">{{ detail.site }}</span> -\n                      {{ detail.product }} -\n                      <span class=\"font-weight-bold\">{{ detail.quantity }}</span> -\n                      <span v-if=\"detail.hours\"> {{ detail.hours }} - </span>\n                      <a :href=\"'/app/order-items/show/' + detail.orderUuid \" target=\"_blank\">Cde. {{ detail.orderNumber }} </a>\n                      <span v-if=\"detail.nb_schedules && detail.nb_schedules > 1\" class=\"font-italic\" :title=\"detail.nb_schedules + ' tournées'\">&nbsp;(* {{ detail.nb_schedules }})</span>\n                    </v-row>\n                  </v-col>\n                  <v-col sm=\"1\" class=\"pa-0 text-center mt-1\">\n                    <v-row no-gutters class=\"ma-0 pa-0\">\n                      <v-col class=\"ma-0 pa-0\">\n                        <v-checkbox :disabled=\"detail.disabled || !checkRights(detail.rights + ',planified:delivery-schedule')\" class=\"pa-0 ma-0\" hide-details small title=\"Réalisé\"\n                                    @change=\"changeRealisedOrder(detail, item)\" v-model=\"detail.is_realised\">\n                        </v-checkbox>\n                      </v-col>\n                      <v-col>\n                        <span v-if=\"checkRights(detail.rights)\" @click=\"$emitter.emit('open-modal-transfer-dso', { detail: detail, deliverySchedule: item })\"\n                              title=\"Réaffecter le tour\" style=\"cursor: pointer\">\n                          <v-icon :color=\"!checkRights(detail.rights) ? '' : 'primary'\">mdi-folder-arrow-up-down-outline</v-icon>\n                        </span>\n                      </v-col>\n                    </v-row>\n                  </v-col>\n                </v-row>\n                <v-divider></v-divider>\n              </li>\n            </draggable>\n          </ol>\n        </template>\n\n        <!-- Parsing charted to string -->\n        <template #item.is_charted=\"{ item }\">\n          {{ item.is_charted ? 'Oui' : 'Non' }}\n        </template>\n\n        <!-- template to display truck details for planning J+1 resume view-->\n        <template #item.truckDetails=\"{ item }\">\n            <span v-for=\"truckDetail in item.truckDetails\" :key=\"truckDetail.deliveryScheduleId\" v-if=\"truckDetail && truckDetail !== ''\">\n              {{ truckDetail }}<br>\n            </span>\n            <span v-if=\"item.driver && item.driver.phone\">\n              {{ item.driver.phone }}\n            </span>\n        </template>\n\n        <!-- template to display costs for planning J+1 resume view-->\n        <template #item.costs=\"{ item }\">\n          <div class=\"text-right\" v-if=\"item.costs && item.costs.kilometers\">{{ item.costs.kilometers }} Km</div>\n          <div\n              v-if=\"item.costs && item.costs.price\"\n              class=\"font-weight-bold text-right\"\n              :class=\"`${item.costs.puAtColor}--text`\"\n          >\n            {{ item.costs.price }} €\n          </div>\n        </template>\n\n        <!-- template to display tours for planning J+1 resume view-->\n        <template #item.tours=\"{ item }\">\n          <span class=\"toursQty\">{{ item.tours.length / 2 }} Tours</span><br>\n          <span v-for=\"(tour, index) in item.tours\" :key=\"tour.deliveryScheduleId\">\n              <span :style=\"{color: colorWarehouse(tour)}\">{{ tour }}</span><span v-if=\"index < item.tours.length - 1\"> -> </span>\n          </span>\n        </template>\n\n        <!-- template to display J+1-->\n        <template #item.toursCustoms=\"{ item }\">\n          <span v-for=\"(data, index) in item.toursCustoms\" :key=\"index\">\n            <span v-if=\"data.isComment && filters.with_comments\" class=\"primary--text\" style=\"font-style: italic;\" :title=\"data.text\">\n             <v-icon color=\"primary\" small class=\"mr-2\">mdi-comment-text-outline</v-icon>{{ data.text | limitString(40) }}\n            </span>\n            <span  v-if=\"!data.isComment\">\n              <span v-if=\"data.num\">{{ data.num }}. </span>\n              <span v-if=\"data.color\" :style=\"{'background-color': data.color, 'width': '5px', 'margin-right': '5px'}\">&nbsp;</span>\n              <span>{{ data.text }}</span>\n              <span v-if=\"index % 2 === 0\"><v-icon small class=\"pb-1 primary--class\">mdi-arrow-right</v-icon></span>\n              <span v-else>\n                <span v-if=\"data.quantity\"> ({{ data.quantity }} T)</span>\n                <span v-if=\"!data.realised\" class=\"red--text font-italic\" title=\"Tour non réalisé\"> (NR)</span>\n                <span v-if=\"data.nbSchedules && data.nbSchedules > 1\" class=\"font-italic\" :title=\"data.nbSchedules + ' tournées'\"> (* {{ data.nbSchedules }})</span>\n                <br>\n              </span>\n            </span>\n          </span>\n        </template>\n        <template #item.customerList=\"{ item }\">\n          <ol class=\"pl-0\">\n            <template v-for=\"customer in item.customerList\" >\n              <span v-if=\"customer && !customer.isMessage\" :style=\"'color:' + (customer.name === '-' ? 'transparent' : '')\" :title=\"customer.name\">\n                {{ customer.num }}. {{ customer.name | limitString }}\n                <br>\n              </span>\n              <br v-else>\n            </template>\n          </ol>\n        </template>\n        <template #item.productsList=\"{ item }\">\n          <ol class=\"pl-0\">\n            <template v-for=\"product in item.productsList\">\n              <span v-if=\"product && !product.isMessage\" :style=\"'color:' + (product.name === '-' ? 'transparent' : '')\" :title=\"product.name\">\n                {{ product.num }}. {{ product.name | limitString }}\n                <br>\n              </span>\n              <br v-else>\n            </template>\n          </ol>\n        </template>\n        <template #item.hoursList=\"{ item }\">\n          <ol class=\"pl-0\">\n            <template v-for=\"hour in item.hoursList\">\n              <span v-if=\"hour && !hour.isMessage\" :style=\"'color:' + (hour.name === '-' ? 'transparent' : '')\" :title=\"hour.num + '. ' + hour.name\">\n                {{ hour.num }}. {{ hour.name | limitString(12) }}\n                <br>\n              </span>\n              <br v-else>\n            </template>\n          </ol>\n        </template>\n        <template #item.deliveryTimesAndMoments=\"{ item }\">\n          {{ getDeliveryTimesAndMoments(item) }}\n        </template>\n\n        <!-- colors -->\n        <template #item.color=\"{ item }\">\n          <v-icon :color=\"item.color\">mdi-palette</v-icon>\n        </template>\n\n        <!-- Site name address -->\n        <template #item.site.nameAddress=\"{ item }\">\n          <span class=\"font-weight-bold\">{{ item.site ? item.site.name : '' }}</span><br>\n          {{ item.site && item.site.address ? item.site.address.address1 + ', ' + item.site.address.postcode + ' ' + item.site.address.city : '' }}\n        </template>\n\n        <!-- active -->\n        <template #item.isActive=\"{ item }\">\n          <v-icon :color=\"item.isActive ? 'primary' : 'error'\">{{ item.isActive ? \"mdi-check\" : \"mdi-close\" }}</v-icon>\n        </template>\n        <template #item.isWriter=\"{ item }\">\n          <v-icon :color=\"item.isWriter ? 'primary' : 'error'\">{{ item.isWriter ? \"mdi-check\" : \"mdi-close\" }}</v-icon>\n        </template>\n        <template #item.is_active=\"{ item }\">\n          <v-icon :color=\"item.is_active ? 'primary' : 'error'\">{{ item.is_active ? \"mdi-check\" : \"mdi-close\" }}</v-icon>\n        </template>\n\n        <!-- Warehouse color name -->\n        <template #item.quarry.colorName=\"{ item }\">\n          <div v-if=\"item.quarry && item.quarry.colorName\">\n            <v-row>\n              <div :style=\"{'background-color': item.quarry.colorName.color, 'width': '5px', 'margin-right': '5px'}\"></div>\n              {{ item.quarry.short_name }}\n            </v-row>\n          </div>\n        </template>\n        <template #item.warehouse.colorName=\"{ item }\">\n          <div v-if=\"item.warehouse && item.warehouse.colorName\">\n            <v-row>\n              <div :style=\"{'background-color': item.warehouse.colorName.color, 'width': '5px', 'margin-right': '5px'}\"></div>\n              {{ item.warehouse.short_name }}\n            </v-row>\n          </div>\n        </template>\n        <template #item.deliveryScheduleOrders=\"{ item }\">\n          <div v-if=\"item.deliveryScheduleOrders && item.deliveryScheduleOrders.length > 0\">\n            <div style=\"cursor: pointer;\" @click=\"openDetail(item)\" :class=\"getClassQtyColor(item)\">\n              {{ item.deliveryScheduleOrders.reduce((sum, value) => sum += (value.is_realised ? value.delivery_quantity : 0), 0) }}/{{ item.quantityOrdered }}&nbsp;T\n              <v-icon v-if=\"!$rights.hasProfile('bascule')\" class=\"ml-1\" :id=\"'arrow_' + item.uuid\">mdi-chevron-down</v-icon>\n              <v-icon v-else class=\"ml-1\" :id=\"'arrow_' + item.uuid\">mdi-chevron-up</v-icon>\n            </div>\n            <div :id=\"'detail_' + item.uuid\" :class=\"$rights.hasProfile('bascule') ? '' : 'd-none'\">\n              <ol>\n                <template v-for=\"deliveryscheduleorder in item.deliveryScheduleOrders\">\n                  <li class=\"text-no-wrap\" v-if=\"!deliveryscheduleorder.delivery_schedule.isCharted && deliveryscheduleorder.delivery_schedule.truck\">\n                    <span v-if=\"!deliveryscheduleorder.is_realised\" class=\"red--text font-italic\" title=\"Tour non réalisé\">(NR) - </span>\n                    {{ deliveryscheduleorder.delivery_schedule.truck.numberplate }}\n                    ({{ deliveryscheduleorder.delivery_quantity }}T)<br />{{ deliveryscheduleorder.delivery_schedule.truck.transporter.name }}\n                  </li>\n                  <li v-else-if=\"deliveryscheduleorder.delivery_schedule.isCharted && deliveryscheduleorder.delivery_schedule.transporter\">\n                    <span v-if=\"!deliveryscheduleorder.is_realised\" class=\"red--text font-italic\" title=\"Tour non réalisé\">(NR) - </span>\n                    {{ deliveryscheduleorder.delivery_schedule.transporter.name }}\n                    ({{ deliveryscheduleorder.delivery_quantity }}T)\n                  </li>\n                  <li v-else>\n                    <span v-if=\"!deliveryscheduleorder.is_realised\" class=\"red--text font-italic\" title=\"Tour non réalisé\">(NR) - </span>\n                    ({{ deliveryscheduleorder.delivery_quantity }}T)\n                  </li>\n                </template>\n              </ol>\n            </div>\n          </div>\n          <div v-else>\n            <div class=\"red--text\">0/{{ item.quantityOrdered }}&nbsp;T</div>\n          </div>\n        </template>\n        <template #item.deliveryScheduleOrdersTimes=\"{ item }\">\n          <div v-if=\"getTimesTitle(item) !== ''\">\n            <v-tooltip left color=\"black\">\n              <template v-slot:activator=\"{ on, attrs }\">\n                <v-icon v-bind=\"attrs\" v-on=\"on\" style=\"cursor: help;\">mdi-clock-outline</v-icon>\n              </template>\n              <pre>{{ getTimesTitle(item) }}</pre>\n            </v-tooltip>\n          </div>\n        </template>\n\n        <!-- User info array -->\n        <template #item.driver.userInfosArray=\"{ item }\">\n          <template v-if=\"item.driver && item.driver.userInfosArray\">\n            <div>{{ item.driver.userInfosArray.firstname }}&nbsp;{{ item.driver.userInfosArray.lastname }}</div>\n            <div>{{ item.driver.userInfosArray.phone }}</div>\n          </template>\n        </template>\n\n        <!-- Customer code name for Bascule -->\n        <template #item.customer.nameCode=\"{ item }\">\n          <template v-if=\"item.customer\">\n            <div>{{ item.customer.name }}</div>\n            <div v-if=\"$rights.hasProfile('bascule')\" class=\"font-weight-bold\"> - {{ item.customer.code }}</div>\n          </template>\n        </template>\n\n        <!-- Creator initials -->\n        <template #item.creator.fullname=\"{ item }\">\n          <span v-if=\"item.creator && item.creator.initials\" :title=\"item.creator.fullname\">{{ item.creator.initials }}</span>\n        </template>\n\n        <!-- Inert -->\n        <template #item.isInert=\"{ item }\">\n          <v-icon v-if=\"item.isInert\" color=\"primary\">mdi-check</v-icon>\n        </template>\n\n        <template #item.site.hoursStr=\"{ item }\">\n          <v-tooltip left color=\"black\" v-if=\"item.site.hoursStr !== ''\">\n            <template v-slot:activator=\"{ on, attrs }\">\n              <v-icon v-bind=\"attrs\" v-on=\"on\" style=\"cursor: help;\">mdi-clock-outline</v-icon>\n            </template>\n            <pre>{{ item.site.hoursStr }}</pre>\n          </v-tooltip>\n        </template>\n      </v-data-table>\n    </v-card>\n    <modal v-model:value=\"deleteModalIsOpen\" confirm=\"Confirmer\" cancel=\"Annuler\" title=\"Confimer la suppression\"\n           @confirm=\"deleteObject(currentItem)\" @cancel=\"deleteModalIsOpen = false\" width=\"40%\">\n      <div v-if=\"currentItem\">\n        <h3 class=\"text-center pa-6 ma-0 font-weight-regular\">Êtes-vous sûr de vouloir supprimer : {{ currentItem.name }} ?</h3>\n      </div>\n      <v-row v-else no-gutters justify=\"center\">\n        <v-progress-circular indeterminate color=\"primary\" class=\"pa-3 ma-6\"></v-progress-circular>\n      </v-row>\n    </modal>\n    <!-- Confirm modal -->\n    <modal :value=\"confirm.open\" confirm=\"Confirmer\" cancel=\"Annuler\" :title=\"confirm.title\"\n           @confirm=\"submitConfirm(confirm)\" @cancel=\"confirm.open = false\" width=\"30%\">\n      <div v-if=\"!confirm.load\">\n        <h3 class=\"text-center pa-6 ma-0 font-weight-regular\">{{ confirm.message }}</h3>\n      </div>\n      <v-row v-else no-gutters justify=\"center\">\n        <v-progress-circular indeterminate color=\"primary\" class=\"pa-3 ma-6\"></v-progress-circular>\n      </v-row>\n    </modal>\n    <!-- Notify modal -->\n    <send-driver-modal :is-open.sync=\"notifyModal.open\" :item.sync=\"notifyModal.item\" :route=\"notifyModal.route\"></send-driver-modal>\n\n    <alert v-if=\"alert.message\" :message=\"alert.message\" :type=\"alert.type\" :key=\"alert.key\"></alert>\n  </div>\n</template>\n\n<script type=\"ts\">\nimport Vue from \"vue\";\nimport moment from \"moment\";\nimport draggable from \"vuedraggable\";\n\nexport default Vue.extend({\n  name: \"api-data-table\",\n  props: [\"resource\", \"headers\", \"actions\", \"hideFilters\", \"values\", \"defaultFilters\", \"reload\", \"tableFilters\", \"checkable\", \"nbItems\"],\n  components: {draggable},\n  data: function (_this) {\n    return {\n      data: [],\n      nbItemsPerPage: _this.nbItems ?? 30,\n      loading: true,\n      options: {},\n      itemCount: 0,\n      filters: [],\n      deleteModalIsOpen: false,\n      currentItem: null, // Current selected item.\n      warehouseColors: {\n        'D67A': '#66ff00',\n        'D68A': '#8899dd',\n        'D64A': '#ffcccc',\n        'TRAKM': '#ffffff',\n        'D72A': '#f0ebe4',\n        'D66A': '#ff9900',\n        'D73A': '#00ffff',\n        'D63A': '#ff0000',\n        'D65A': '#66cc33',\n        'NEGDI': '#ffffff',\n        'D70D': '#ff3399',\n        'D69A': '#ffff00',\n        'D70C': '#ff66ff',\n        'D70A': '#ff9933',\n      },\n      applyDefaultFilters: true,\n      dragging: false,\n      alert: {\n        message: null,\n        type: '',\n        key: 0\n      },\n      confirm: { open: false, message: null, title: null, color: null, icon: null, target: null, route: null, load: false },\n      notifyModal: { open: false, item: null, route: null },\n      checked: []\n    };\n  },\n  filters: {\n    date: (value) => {\n      return value ? moment(value).format('DD/MM/YY') : value;\n    },\n    limitString(str, n = 30) {\n      return (str && str.length > n) ? str.slice(0, n-1) + '...' : str;\n    }\n  },\n  watch: {\n    reload() {\n      this.fetchData();\n    },\n    checked: {\n      handler() {\n        this.$emit('update:checked', this.checked);\n      },\n      deep: true,\n    },\n    options: {\n      handler() {\n        // Apply default filters\n        if (this.defaultFilters && this.applyDefaultFilters) {\n          for (const key in this.defaultFilters) {\n            if (key === 'order') {\n              for (let prop in this.defaultFilters[key]) {\n                this.options.sortBy.push(prop);\n                this.options.sortDesc.push(this.defaultFilters[key][prop] === 'desc');\n              }\n            } else if (this.defaultFilters.hasOwnProperty(key)) {\n              this.filters[key] = this.defaultFilters[key];\n            }\n          }\n          // Set null default filters when already used\n          this.applyDefaultFilters = false;\n        }\n        this.fetchData();\n      },\n      deep: true,\n    },\n    'notifyModal.item.isNotify'(sended) {\n      if (!this.notifyModal.openModal && sended) {\n        this.fetchData();\n      }\n    }\n  },\n  methods: {\n    filterChange() {\n      // Init page to 1, to get results\n      this.options.page = 1;\n      this.fetchData();\n    },\n    async fetchData() {\n      this.$emit('update:values', null);\n      const params = { order: {} };\n      const { sortBy, sortDesc, page, itemsPerPage } = this.options;\n\n      // Sort\n      for (let i = 0; i < sortBy.length; i++) {\n        let key = sortBy[i];\n        // Custom rows\n        if (sortBy[i] === 'quarry.colorName') { key = 'quarry.name'; }\n        if (sortBy[i] === 'warehouse.colorName') { key = 'warehouse.name'; }\n        if (sortBy[i] === 'site.nameAddress') { key = 'site.name'; }\n        if (sortBy[i] === 'customer.nameCode') { key = 'customer.name'; }\n        // Sort\n        params.order[key] = !sortDesc[i] ? \"asc\" : \"desc\";\n      }\n      // Filters\n      for (const key in this.filters) {\n        if (this.filters[key]) {\n          if (Array.isArray(this.filters[key])) {\n            params[key] = this.filters[key];\n          } else {\n            params[key] = [this.filters[key]];\n          }\n        }\n      }\n      // Return filters to ApiDataTable component\n      this.$emit('update:tableFilters', {\n        filters: {...this.filters},\n        params: {...params}, // Without pagination\n        pagination: { page: page, itemsPerPage: itemsPerPage }\n      });\n      // Pagination\n      params.page = page;\n      if (itemsPerPage > 0) {\n        params.itemsPerPage = itemsPerPage;\n      }\n\n      this.loading = true;\n      try {\n        const result = await this.$http.get(this.resource, { params: params });\n\n        this.itemCount = result.total;\n        this.data = result.data;\n      } catch (e) {\n        this.itemCount = 0;\n        this.data = [];\n\n        console.log('erreur lors de la récup des données...', e);\n      } finally {\n        this.$emit('update:values', this.data);\n        this.loading = false;\n      }\n    },\n    /**\n     * Switch lié aux actions de la grille.\n     */\n    route: async function (item, action, openTarget = '_blank', url = null, param = null, confirm = null, isNotifyDeliverySchedule = false) {\n      let resource = this.resource.replace(/\\?.*/, ''); // Delete parameters\n\n      switch (action) {\n        case 'delete':\n          if (!item.name && item.num) { item.name = item.num; } // Case order\n          else if (!item.name && item.id) { item.name = '#' + item.id; } // Case delivery schedules\n\n          this.currentItem = item;\n          this.deleteModalIsOpen = true;\n          break;\n        case '_other':\n          if (url) {\n            url += param && item[param] ? item[param] : '';\n            window.open(url, openTarget);\n          }\n          break;\n        case '#':\n          this.$emitter.emit('open-modal_' + param, item);\n          break;\n        default:\n          if (confirm) {\n            this.confirm.message = confirm.message;\n            this.confirm.title = confirm.title;\n            this.confirm.color = confirm.color;\n            this.confirm.icon = confirm.icon;\n            this.confirm.route = '/app/' + resource + '/' + action + '/' + item.uuid;\n            this.confirm.target = openTarget;\n            this.confirm.open = true;\n          } else if (isNotifyDeliverySchedule) {\n            this.notifyModal.route = '/' + resource + '/' + action + '/' + item.uuid;\n            this.notifyModal.item = item;\n            this.notifyModal.open = true;\n          } else {\n            window.open('/app/' + resource + '/' + action + '/' + item.uuid, openTarget);\n          }\n          break;\n      }\n    },\n    submitConfirm(confirm) {\n      confirm.load = true;\n      window.open(confirm.route, confirm.target);\n    },\n    /**\n     * Delete an object.\n     */\n    async deleteObject(item) {\n      this.alert.message = null;\n\n      const id = item['@id'];\n      this.currentItem = null; // To start the delete loader.\n      try {\n        let res = await this.$http.delete(id);\n        // Update list\n        await this.fetchData();\n        // Success message\n        if (res.data && res.data.success) {\n          this.alert.message = res.data.success;\n          this.alert.type = 'success';\n          this.alert.key++;\n        }\n      } catch (e) {\n        if (e.data && e.data.error) {\n          this.alert.message = e.data.error;\n          this.alert.type = 'danger';\n          this.alert.key++;\n        }\n      }\n      this.deleteModalIsOpen = false;\n    },\n    async changeRealisedOrder(detail, deliverySchedule) {\n      // Disable change checkbox\n      detail.disabled = true;\n      // Save realisation or not\n      let result = await this.$http.post('/delivery-schedule-order/realised/' + detail.deliveryScheduleId, detail);\n      // Change detail detail\n      if (result && result.data && result.data.detail && result.data.detail.deliveryScheduleId) {\n        detail.detail = result.data.detail.detail;\n      }\n      // Change delivery schedule status\n      if (result && result.data && result.data.deliveryScheduleStatus) {\n        deliverySchedule.status = result.data.deliveryScheduleStatus;\n      }\n      // Enable change checkbox\n      detail.disabled = false;\n    },\n    colorWarehouse(tour) {\n      if (this.warehouseColors[tour]) {\n        return this.warehouseColors[tour];\n      }\n    },\n    checkRights(rights) {\n      if (rights) {\n        // If one of rights are true, can access\n        return rights.split(',').some(right => {\n          let [action, resource] = right.split(':');\n          return this.$rights.can(resource, action);\n        });\n      }\n\n      return true;\n    },\n    async changeOrderPosition(deliverySchedule) {\n      await this.$http.post('delivery-schedules/' + deliverySchedule.id + '/orders-positions', {details: deliverySchedule.details});\n    },\n    getTitle(action, item) {\n      // Change email title\n      if (action.isNotifyDeliverySchedule) {\n        if (item.isNotify) {\n          return 'Notification envoyée';\n        } else if (item.notificationRecipient && item.notificationRecipient !== '') {\n          return 'Notification non envoyée';\n        } else {\n          return 'Aucun destinataire';\n        }\n      }\n\n      return action.title ? action.title : '';\n    },\n    getColor(action, item) {\n      // Change email color\n      if (action.isNotifyDeliverySchedule) {\n        if (item.isNotify) {\n          return 'light-green';\n        } else if (item.notificationRecipient && item.notificationRecipient !== '') {\n          return 'amber';\n        } else {\n          return 'red';\n        }\n      }\n      // Locations\n      if (action.icons && action.icons.type === 'showMapMarker' && (!item.address || (!item.address.latitude || !item.address.longitude))) {\n        return 'red';\n      }\n\n      return action.color ? action.color : '';\n    },\n    canDraggable(details) {\n      return details.some(detail => !detail.disabled && this.checkRights(detail.rights));\n    },\n    openDetail(item) {\n      let toggle = document.getElementById('detail_' + item.uuid);\n      if (toggle) {\n        // Toggle detail\n        toggle.classList.toggle('d-none');\n        // Change arrow class\n        let arrow = document.getElementById('arrow_' + item.uuid);\n        if (arrow) {\n          if (toggle.classList.contains('d-none')) {\n            arrow.classList.remove('mdi-chevron-up');\n            arrow.classList.add('mdi-chevron-down');\n          } else {\n            arrow.classList.remove('mdi-chevron-down');\n            arrow.classList.add('mdi-chevron-up');\n          }\n        }\n      }\n    },\n    getTimesTitle(item) {\n      if (item.deliveryScheduleOrders) {\n        let times = item.deliveryScheduleOrders.map((s, idx) => {\n          let time = null;\n          if (s.momentDay) {\n            time = (idx + 1) + ' - ' + s.momentDay.openingTime.name\n          } else if (s.delivery_hour) {\n            time = (idx + 1) + ' - ' + s.delivery_hour;\n          } else if (s.deliveryHour) {\n            time = (idx + 1) + ' - ' + moment(s.deliveryHour).format('HH:mm');\n          }\n          if (s.commentMoments) {\n            if (!time) { time = (idx + 1); }\n            time += ' - ' + s.commentMoments;\n          }\n\n          return time;\n        }).filter(s => s);\n\n        return times ? times.join(\"\\n\") : '';\n      }\n\n      return '';\n    },\n    getDeliveryTimesAndMoments(item) {\n      let times = [];\n      // Moments days\n      if (item.momentsDays && item.momentsDays.length > 0) {\n        let moments = item.momentsDays.reduce((acc, m) => acc.set(m.openingTime.short, (acc.get(m.openingTime.short) || 0) + 1), new Map());\n        times.push(...([...moments.entries()].map(m => m[0] + ' (' + m[1] + ')')));\n      }\n      // Delivery times\n      if (item.deliveryTimes && item.deliveryTimes.length > 0) {\n        times.push(...item.deliveryTimes.map(t => t.time));\n      }\n      return times.join(', ');\n    },\n    getClassQtyColor(item) {\n      let scheQty = item.deliveryScheduleOrders.reduce((sum, value) => sum += (value.is_realised ? value.delivery_quantity : 0), 0);\n      let orderQty = item.quantityOrdered ?? 0;\n      // Colors\n      if (scheQty <= 0 || scheQty > orderQty) { return 'red--text'; }\n      if (scheQty === orderQty) { return 'green--text'; }\n      return 'orange--text';\n    },\n    itemRowBackground(item) {\n      return item && item.isArchived ? 'red lighten-4' : '';\n    }\n  }\n});\n</script>\n\n<style>\n  .costs:nth-of-type(even) {\n    font-weight: bold;\n  }\n\n  .toursQty {\n    font-weight: bold;\n  }\n\n  .v-data-table__wrapper table tbody tr td.text-start {\n    padding: 0 8px!important;\n  }\n\n  // Pritable text size\n  @media print {\n    html, body, div, span, h1, h2, h3, h4, h5, h6, p, pre, a, ol, ul, li, table, tbody, tfoot, thead, tr, th, td, i {\n      font-size: 6pt !important;\n    }\n  }\n</style>\n"],"names":[],"sourceRoot":""}*/