@ozdao/martyrs 0.2.540 → 0.2.542

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (290) hide show
  1. package/dist/_virtual/index.cjs +4 -4
  2. package/dist/_virtual/index.js +4 -4
  3. package/dist/_virtual/index2.cjs +3 -6
  4. package/dist/_virtual/index2.cjs.map +1 -1
  5. package/dist/_virtual/index2.js +2 -5
  6. package/dist/_virtual/index2.js.map +1 -1
  7. package/dist/{globals.verifier-CJ1lr-NW.cjs → globals.verifier-Bi-XLEi9.cjs} +24 -23
  8. package/dist/{globals.verifier-BhqUrneb.js → globals.verifier-gPPX_jhf.js} +24 -23
  9. package/dist/inventory.server.cjs +1 -1
  10. package/dist/inventory.server.js +1 -1
  11. package/dist/{main-gOfhekZG.js → main-ByKkD9qa.js} +2857 -3276
  12. package/dist/main-Czyu-VcC.cjs +11 -0
  13. package/dist/martyrs/src/components/Button/{Button.vue2.cjs → Button.vue.cjs} +2 -2
  14. package/dist/martyrs/src/components/Button/{Button.vue2.js.map → Button.vue.cjs.map} +1 -1
  15. package/dist/martyrs/src/components/Button/{Button.vue2.js → Button.vue.js} +2 -2
  16. package/dist/martyrs/src/components/Button/Button.vue.js.map +1 -0
  17. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.cjs +1 -1
  18. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js +1 -1
  19. package/dist/martyrs/src/components/FieldTags/BlockTags.vue.cjs +30 -21
  20. package/dist/martyrs/src/components/FieldTags/BlockTags.vue.cjs.map +1 -1
  21. package/dist/martyrs/src/components/FieldTags/BlockTags.vue.js +32 -23
  22. package/dist/martyrs/src/components/FieldTags/BlockTags.vue.js.map +1 -1
  23. package/dist/martyrs/src/components/FieldTags/FieldTags.vue2.cjs +235 -0
  24. package/dist/martyrs/src/components/FieldTags/FieldTags.vue2.cjs.map +1 -0
  25. package/dist/martyrs/src/components/FieldTags/FieldTags.vue2.js +235 -0
  26. package/dist/martyrs/src/components/FieldTags/FieldTags.vue2.js.map +1 -0
  27. package/dist/martyrs/src/components/Marquee/Marquee.vue.cjs +17 -8
  28. package/dist/martyrs/src/components/Marquee/Marquee.vue.cjs.map +1 -1
  29. package/dist/martyrs/src/components/Marquee/Marquee.vue.js +17 -8
  30. package/dist/martyrs/src/components/Marquee/Marquee.vue.js.map +1 -1
  31. package/dist/martyrs/src/components/UploadImage/UploadImage.vue.cjs +161 -42
  32. package/dist/martyrs/src/components/UploadImage/UploadImage.vue.cjs.map +1 -1
  33. package/dist/martyrs/src/components/UploadImage/UploadImage.vue.js +162 -43
  34. package/dist/martyrs/src/components/UploadImage/UploadImage.vue.js.map +1 -1
  35. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.cjs +1 -1
  36. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.js +1 -1
  37. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.cjs +1 -1
  38. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +1 -1
  39. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs +1 -1
  40. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +1 -1
  41. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.cjs +1 -1
  42. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.js +1 -1
  43. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.cjs +1 -1
  44. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js +4 -4
  45. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.cjs +1 -1
  46. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.js +1 -1
  47. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.cjs +1 -1
  48. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.js +1 -1
  49. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.cjs +1 -1
  50. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.js +1 -1
  51. package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.cjs +1 -1
  52. package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.js +1 -1
  53. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.cjs +1 -1
  54. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js +1 -1
  55. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs +1 -4
  56. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs.map +1 -1
  57. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +1 -4
  58. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js.map +1 -1
  59. package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.js +2 -2
  60. package/dist/martyrs/src/modules/events/components/elements/ButtonCheck.vue.cjs +1 -1
  61. package/dist/martyrs/src/modules/events/components/elements/ButtonCheck.vue.js +1 -1
  62. package/dist/martyrs/src/modules/events/components/elements/ButtonJoin.vue.cjs +1 -1
  63. package/dist/martyrs/src/modules/events/components/elements/ButtonJoin.vue.js +1 -1
  64. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.cjs +1 -1
  65. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +21 -21
  66. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.cjs +1 -1
  67. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +1 -1
  68. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +1 -1
  69. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +1 -1
  70. package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.cjs +1 -1
  71. package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.js +1 -1
  72. package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.cjs +1 -1
  73. package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.js +1 -1
  74. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.cjs +1 -1
  75. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.js +1 -1
  76. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.cjs +1 -1
  77. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.js +1 -1
  78. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.cjs +1 -1
  79. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.js +1 -1
  80. package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.cjs +1 -1
  81. package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.js +1 -1
  82. package/dist/martyrs/src/modules/globals/views/components/partials/NavigationBar.vue.cjs +1 -1
  83. package/dist/martyrs/src/modules/globals/views/components/partials/NavigationBar.vue.js +1 -1
  84. package/dist/martyrs/src/modules/globals/views/store/globals.cjs +2 -2
  85. package/dist/martyrs/src/modules/globals/views/store/globals.cjs.map +1 -1
  86. package/dist/martyrs/src/modules/globals/views/store/globals.js +2 -2
  87. package/dist/martyrs/src/modules/globals/views/store/globals.js.map +1 -1
  88. package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.cjs +1 -1
  89. package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.js +1 -1
  90. package/dist/martyrs/src/modules/inventory/components/forms/ColumnSettingsMenu.vue.cjs +1 -1
  91. package/dist/martyrs/src/modules/inventory/components/forms/ColumnSettingsMenu.vue.js +1 -1
  92. package/dist/martyrs/src/modules/inventory/components/forms/HistoryView.vue.cjs +1 -1
  93. package/dist/martyrs/src/modules/inventory/components/forms/HistoryView.vue.js +1 -1
  94. package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.cjs +1 -1
  95. package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.js +1 -1
  96. package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.cjs +1 -1
  97. package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.js +1 -1
  98. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs +1 -1
  99. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js +1 -1
  100. package/dist/martyrs/src/modules/music/components/cards/ArtistCardSmall.vue.cjs +1 -1
  101. package/dist/martyrs/src/modules/music/components/cards/ArtistCardSmall.vue.js +1 -1
  102. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs +1 -1
  103. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js +1 -1
  104. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.cjs +1 -1
  105. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js +1 -1
  106. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.cjs +1 -1
  107. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js +11 -11
  108. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.cjs +1 -1
  109. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js +12 -12
  110. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs +1 -1
  111. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js +16 -16
  112. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs +1 -1
  113. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js +1 -1
  114. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs +1 -1
  115. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js +16 -16
  116. package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs +1 -1
  117. package/dist/martyrs/src/modules/music/components/pages/Album.vue.js +1 -1
  118. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs +1 -1
  119. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js +1 -1
  120. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs +1 -1
  121. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js +1 -1
  122. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs +1 -1
  123. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js +1 -1
  124. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs +1 -1
  125. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js +1 -1
  126. package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs +1 -1
  127. package/dist/martyrs/src/modules/music/components/pages/Track.vue.js +1 -1
  128. package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.cjs +1 -1
  129. package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.js +1 -1
  130. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs +1 -1
  131. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js +1 -1
  132. package/dist/martyrs/src/modules/orders/components/forms/FormApplicationDetails.vue.cjs +1 -1
  133. package/dist/martyrs/src/modules/orders/components/forms/FormApplicationDetails.vue.js +1 -1
  134. package/dist/martyrs/src/modules/orders/components/forms/FormCustomerDetails.vue.cjs +1 -1
  135. package/dist/martyrs/src/modules/orders/components/forms/FormCustomerDetails.vue.js +1 -1
  136. package/dist/martyrs/src/modules/orders/components/forms/FormSelectCustomer.vue.cjs +1 -1
  137. package/dist/martyrs/src/modules/orders/components/forms/FormSelectCustomer.vue.js +1 -1
  138. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.cjs +1 -1
  139. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +1 -1
  140. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.cjs +1 -1
  141. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.js +1 -1
  142. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs +1 -1
  143. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +1 -1
  144. package/dist/martyrs/src/modules/orders/components/sections/ApplicationDetails.vue.cjs +1 -1
  145. package/dist/martyrs/src/modules/orders/components/sections/ApplicationDetails.vue.js +1 -1
  146. package/dist/martyrs/src/modules/orders/components/sections/CustomerDetails.vue.cjs +1 -1
  147. package/dist/martyrs/src/modules/orders/components/sections/CustomerDetails.vue.js +1 -1
  148. package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.cjs +3 -4
  149. package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.cjs.map +1 -1
  150. package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.js +3 -4
  151. package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.js.map +1 -1
  152. package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.cjs +1 -1
  153. package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.js +1 -1
  154. package/dist/martyrs/src/modules/organizations/components/forms/AddExistingMembersForm.vue.cjs +1 -1
  155. package/dist/martyrs/src/modules/organizations/components/forms/AddExistingMembersForm.vue.js +1 -1
  156. package/dist/martyrs/src/modules/organizations/components/forms/DepartmentForm.vue.cjs +1 -1
  157. package/dist/martyrs/src/modules/organizations/components/forms/DepartmentForm.vue.js +20 -20
  158. package/dist/martyrs/src/modules/organizations/components/forms/InviteForm.vue.cjs +1 -1
  159. package/dist/martyrs/src/modules/organizations/components/forms/InviteForm.vue.js +1 -1
  160. package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.cjs +3 -4
  161. package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.cjs.map +1 -1
  162. package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.js +3 -4
  163. package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.js.map +1 -1
  164. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs +4 -5
  165. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs.map +1 -1
  166. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js +4 -5
  167. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js.map +1 -1
  168. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs +2 -3
  169. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs.map +1 -1
  170. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js +2 -3
  171. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js.map +1 -1
  172. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +1 -1
  173. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +6 -6
  174. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.cjs +1 -1
  175. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +1 -1
  176. package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.cjs +1 -1
  177. package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.js +1 -1
  178. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs +1 -1
  179. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js +1 -1
  180. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.cjs +1 -1
  181. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js +1 -1
  182. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.cjs +1 -1
  183. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js +1 -1
  184. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.cjs +1 -1
  185. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.js +1 -1
  186. package/dist/martyrs/src/modules/products/components/blocks/CardProduct.vue.cjs +1 -1
  187. package/dist/martyrs/src/modules/products/components/blocks/CardProduct.vue.js +1 -1
  188. package/dist/martyrs/src/modules/products/components/elements/{THC.vue2.cjs → THC.vue.cjs} +2 -2
  189. package/dist/martyrs/src/modules/products/components/elements/THC.vue.cjs.map +1 -0
  190. package/dist/martyrs/src/modules/products/components/elements/{THC.vue2.js → THC.vue.js} +2 -2
  191. package/dist/martyrs/src/modules/products/components/elements/THC.vue.js.map +1 -0
  192. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.cjs +1 -1
  193. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.js +1 -1
  194. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs +63 -39
  195. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs.map +1 -1
  196. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +69 -45
  197. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js.map +1 -1
  198. package/dist/martyrs/src/modules/products/components/pages/Product.vue.cjs +1 -1
  199. package/dist/martyrs/src/modules/products/components/pages/Product.vue.js +1 -1
  200. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.cjs +1 -1
  201. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +1 -1
  202. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.cjs +1 -1
  203. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +1 -1
  204. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.cjs +1 -1
  205. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +1 -1
  206. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.cjs +1 -1
  207. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +1 -1
  208. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.cjs +1 -1
  209. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.js +1 -1
  210. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.cjs +1 -1
  211. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.js +1 -1
  212. package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.cjs +2 -2
  213. package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.js +2 -2
  214. package/dist/martyrs/src/modules/products/store/categories.cjs +4 -0
  215. package/dist/martyrs/src/modules/products/store/categories.cjs.map +1 -1
  216. package/dist/martyrs/src/modules/products/store/categories.js +4 -0
  217. package/dist/martyrs/src/modules/products/store/categories.js.map +1 -1
  218. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.cjs +1 -1
  219. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.js +1 -1
  220. package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.cjs +1 -1
  221. package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.js +1 -1
  222. package/dist/martyrs/src/modules/spots/components/pages/Map.vue.cjs +1 -1
  223. package/dist/martyrs/src/modules/spots/components/pages/Map.vue.js +1 -1
  224. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.cjs +1 -1
  225. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +11 -11
  226. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.cjs +1 -1
  227. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +1 -1
  228. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.cjs +1 -1
  229. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js +1 -1
  230. package/dist/martyrs.cjs.js +1 -1
  231. package/dist/martyrs.css +1 -1
  232. package/dist/martyrs.es.js +1 -1
  233. package/dist/music.server.cjs +1 -1
  234. package/dist/music.server.js +1 -1
  235. package/dist/node_modules/.pnpm/lodash.merge@4.6.2/node_modules/lodash.merge/index.cjs +1 -1
  236. package/dist/node_modules/.pnpm/lodash.merge@4.6.2/node_modules/lodash.merge/index.js +1 -1
  237. package/dist/orders.server.cjs +1 -1
  238. package/dist/orders.server.js +1 -1
  239. package/dist/organizations.server.cjs +1 -1
  240. package/dist/organizations.server.js +1 -1
  241. package/dist/products.server.cjs +10 -2
  242. package/dist/products.server.js +10 -2
  243. package/dist/rents.server.cjs +1 -1
  244. package/dist/rents.server.js +1 -1
  245. package/dist/style.css +129 -129
  246. package/dist/{web-DxxU2bwy.js → web-BklgIiYr.js} +1 -1
  247. package/dist/{web-bMa0DMyG.cjs → web-CQBm7C6L.cjs} +1 -1
  248. package/package.json +1 -1
  249. package/src/components/FieldTags/BlockTags.vue +28 -16
  250. package/src/components/FieldTags/FieldTags.vue +327 -508
  251. package/src/components/Marquee/Marquee.vue +25 -14
  252. package/src/components/UploadImage/UploadImage.vue +192 -18
  253. package/src/modules/community/components/pages/CreateBlogPost.vue +0 -1
  254. package/src/modules/globals/controllers/classes/globals.validator.js +24 -23
  255. package/src/modules/globals/views/store/globals.js +2 -2
  256. package/src/modules/products/components/pages/CategoryEdit.vue +73 -39
  257. package/src/modules/products/middlewares/categories.verifier.js +9 -1
  258. package/src/modules/products/store/categories.js +5 -0
  259. package/dist/_virtual/index3.cjs +0 -5
  260. package/dist/_virtual/index3.cjs.map +0 -1
  261. package/dist/_virtual/index3.js +0 -5
  262. package/dist/_virtual/index3.js.map +0 -1
  263. package/dist/main-Zhs0EqRp.cjs +0 -11
  264. package/dist/martyrs/src/components/Button/Button.vue2.cjs.map +0 -1
  265. package/dist/martyrs/src/components/FieldTags/FieldTags.vue.cjs +0 -480
  266. package/dist/martyrs/src/components/FieldTags/FieldTags.vue.cjs.map +0 -1
  267. package/dist/martyrs/src/components/FieldTags/FieldTags.vue.js +0 -480
  268. package/dist/martyrs/src/components/FieldTags/FieldTags.vue.js.map +0 -1
  269. package/dist/martyrs/src/components/FieldTags/create-tags.cjs +0 -43
  270. package/dist/martyrs/src/components/FieldTags/create-tags.cjs.map +0 -1
  271. package/dist/martyrs/src/components/FieldTags/create-tags.js +0 -43
  272. package/dist/martyrs/src/components/FieldTags/create-tags.js.map +0 -1
  273. package/dist/martyrs/src/components/FieldTags/tag-input.vue2.cjs +0 -32
  274. package/dist/martyrs/src/components/FieldTags/tag-input.vue2.cjs.map +0 -1
  275. package/dist/martyrs/src/components/FieldTags/tag-input.vue2.js +0 -32
  276. package/dist/martyrs/src/components/FieldTags/tag-input.vue2.js.map +0 -1
  277. package/dist/martyrs/src/components/FieldTags/vue-tags-input.props.cjs +0 -329
  278. package/dist/martyrs/src/components/FieldTags/vue-tags-input.props.cjs.map +0 -1
  279. package/dist/martyrs/src/components/FieldTags/vue-tags-input.props.js +0 -329
  280. package/dist/martyrs/src/components/FieldTags/vue-tags-input.props.js.map +0 -1
  281. package/dist/martyrs/src/modules/products/components/elements/THC.vue2.cjs.map +0 -1
  282. package/dist/martyrs/src/modules/products/components/elements/THC.vue2.js.map +0 -1
  283. package/dist/node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/index.cjs +0 -39
  284. package/dist/node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/index.cjs.map +0 -1
  285. package/dist/node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/index.js +0 -39
  286. package/dist/node_modules/.pnpm/fast-deep-equal@3.1.3/node_modules/fast-deep-equal/index.js.map +0 -1
  287. package/src/components/FieldTags/create-tags.js +0 -84
  288. package/src/components/FieldTags/tag-input.vue +0 -55
  289. package/src/components/FieldTags/vue-tags-input.props.js +0 -342
  290. package/src/components/FieldTags/vue-tags-input.scss +0 -149
@@ -1 +0,0 @@
1
- {"version":3,"file":"Button.vue2.cjs","sources":["../../../../../src/components/Button/Button.vue"],"sourcesContent":["<script setup>\nimport { ref } from 'vue'\n\nimport Loader from '@martyrs/src/components/Loader/Loader.vue'\n\nimport IconCheckmark from '@martyrs/src/modules/icons/navigation/IconCheckmark.vue';\nimport IconCross from '@martyrs/src/modules/icons/navigation/IconCross.vue';\n\nconst props = defineProps({\n submit: {\n type: Function,\n default: async () => { console.log('Button click.') }\n },\n text: {\n type: Object,\n default: () => ({\n success: null,\n error: null\n })\n },\n counter: {\n type: Object\n },\n callback: {\n type: Function,\n default: async () => { console.log('Button callback.') }\n },\n callbackDelay: {\n type: Number,\n default: 750\n },\n showSucces: {\n type: Boolean,\n default: true\n },\n showLoader: {\n type: Boolean,\n default: true\n },\n validation: {\n type: Boolean,\n default: false\n },\n})\n\nconst emits = defineEmits(['error'])\n\nconst button = ref(null)\nconst error = ref(null)\nconst loading = ref(false)\nconst finished = ref(false)\n\nasync function Submit() {\n console.log('click')\n \n button.value.style['pointer-events'] = 'none'\n error.value = null\n loading.value = true\n\n // Функция для сброса состояния кнопки\n const resetButton = () => {\n if (button.value) {\n button.value.style.pointerEvents = 'auto'\n loading.value = false\n finished.value = false\n error.value = null\n }\n }\n\n try {\n await props.submit()\n\n button.value.classList.replace('bg-main', 'bg-second')\n loading.value = false\n\n // Используем функцию сброса состояния кнопки здесь\n if (props.showSucces) { \n finished.value = true\n setTimeout(() => {\n resetButton()\n button.value.classList.replace('bg-second', 'bg-main')\n }, 500)\n } else {\n resetButton()\n button.value.classList.replace('bg-second', 'bg-main')\n }\n\n // Если есть callback, мы также установим таймер для его вызова\n if (props.callback) setTimeout(() => props.callback(), props.callbackDelay)\n\n } catch (err) {\n emits('error', err)\n // Если возникла ошибка, мы изменяем стили и устанавливаем сообщение об ошибке\n button.value.classList.replace('bg-main', 'bg-fourth-nano')\n loading.value = false\n error.value = true\n \n // После задержки снова сбрасываем состояние кнопки\n setTimeout(() => {\n resetButton()\n // Так как класс кнопки был изменен, вернем его в исходное состояние\n button.value.classList.replace('bg-fourth-nano', 'bg-main')\n }, 1330)\n }\n}\n</script>\n\n<template>\n <button \n @click.stop=\"Submit\"\n :disabled=\"validation\"\n ref=\"button\"\n\t\tclass=\"button\"\n :class=\"{ 'button--disabled': loading || validation }\"\n >\n <Transition name=\"content\" mode=\"out-in\">\n <!-- Default slot content -->\n <span v-if=\"!loading && !error && !finished || !showLoader\" class=\"button-content\">\n <slot></slot>\n </span>\n <!-- Loading state -->\n <Loader v-else-if=\"loading && !error && showLoader\" class=\"icon button-content pos-relative pos-t-0 pos-l-0 loading\"/>\n <!-- Success state -->\n <span v-else-if=\"finished && showSucces\" class=\"button-content t-semi t-center w-100 loading t-black\">\n <template v-if=\"text.success\">\n {{ text.success }}\n </template>\n <IconCheckmark v-else class=\"icon\" />\n </span>\n <!-- Error state -->\n <span v-else-if=\"error\" class=\"button-content t-center w-100 error\">\n <template v-if=\"text.error\">\n {{ text.error }}\n </template>\n <IconCross v-else class=\"icon\" />\n </span>\n </Transition>\n \n <!-- Counter -->\n <div v-if=\"counter\" class=\"button-counter flex flex-center\">\n <span>{{ counter }}</span>\n </div>\n </button>\n</template>\n\n<style lang=\"scss\">\nbutton[disabled] {\n opacity: 0.75 !important;\n pointer-events: none !important;\n cursor: default !important;\n color: rgba(var(--dark), 0.33) !important;\n background: rgba(var(--light), 1) !important;\n}\n\na.button {\n text-box: trim-both cap alphabetic;\n}\n\n.button {\n display: flex;\n padding: var(--small);\n border-radius: var(--small);\n text-box: trim-both cap alphabetic;\n transform: scale(1);\n opacity: 1;\n align-items: center;\n justify-content: center;\n color: black;\n text-align: center;\n text-transform: uppercase;\n font-size: 1rem;\n letter-spacing: 5%;\n transition: all 0.33s ease;\n\n &:hover {\n cursor: pointer;\n opacity: 0.9;\n }\n\n &:active {\n transform: scale(0.95);\n }\n\n &-small {\n padding: 0.75rem;\n border-radius: 0.5rem;\n height: fit-content;\n }\n\n .button-counter {\n position: absolute;\n right: -8px;\n bottom: -8px;\n background: yellow;\n height: 16px;\n border-radius: 16px;\n width: 16px;\n font-weight: 500;\n text-align: center;\n line-height: 16px;\n font-size: 10px;\n }\n}\n\n.button-content {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 8px;\n}\n\n.icon {\n width: 1rem;\n height: 1rem;\n}\n\n/* Vue Transitions */\n.content-enter-active,\n.content-leave-active {\n transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n}\n\n.content-enter-from {\n opacity: 0;\n transform: translateY(8px) scale(0.95);\n}\n\n.content-leave-to {\n opacity: 0;\n transform: translateY(-8px) scale(0.95);\n}\n\n.content-enter-to,\n.content-leave-from {\n opacity: 1;\n transform: translateY(0) scale(1);\n}\n</style>"],"names":["ref"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQA,UAAM,QAAQ;AAqCd,UAAM,QAAQ;AAEd,UAAM,SAASA,IAAAA,IAAI,IAAI;AACvB,UAAM,QAAQA,IAAAA,IAAI,IAAI;AACtB,UAAM,UAAUA,IAAAA,IAAI,KAAK;AACzB,UAAM,WAAWA,IAAAA,IAAI,KAAK;AAE1B,mBAAe,SAAS;AACtB,cAAQ,IAAI,OAAO;AAEnB,aAAO,MAAM,MAAM,gBAAgB,IAAI;AACvC,YAAM,QAAQ;AACd,cAAQ,QAAQ;AAGhB,YAAM,cAAc,MAAM;AACxB,YAAI,OAAO,OAAO;AAChB,iBAAO,MAAM,MAAM,gBAAgB;AACnC,kBAAQ,QAAQ;AAChB,mBAAS,QAAQ;AACjB,gBAAM,QAAQ;AAAA,QAChB;AAAA,MACF;AAEA,UAAI;AACF,cAAM,MAAM,OAAM;AAElB,eAAO,MAAM,UAAU,QAAQ,WAAW,WAAW;AACrD,gBAAQ,QAAQ;AAGhB,YAAI,MAAM,YAAY;AACpB,mBAAS,QAAQ;AACjB,qBAAW,MAAM;AACf,wBAAW;AACX,mBAAO,MAAM,UAAU,QAAQ,aAAa,SAAS;AAAA,UACvD,GAAG,GAAG;AAAA,QACR,OAAO;AACL,sBAAW;AACX,iBAAO,MAAM,UAAU,QAAQ,aAAa,SAAS;AAAA,QACvD;AAGA,YAAI,MAAM,SAAU,YAAW,MAAM,MAAM,SAAQ,GAAI,MAAM,aAAa;AAAA,MAE5E,SAAS,KAAK;AACZ,cAAM,SAAS,GAAG;AAElB,eAAO,MAAM,UAAU,QAAQ,WAAW,gBAAgB;AAC1D,gBAAQ,QAAQ;AAChB,cAAM,QAAQ;AAGd,mBAAW,MAAM;AACf,sBAAW;AAEX,iBAAO,MAAM,UAAU,QAAQ,kBAAkB,SAAS;AAAA,QAC5D,GAAG,IAAI;AAAA,MACT;AAAA,IACF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,480 +0,0 @@
1
- "use strict";
2
- Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
- const vue = require("vue");
4
- const index = require("../../../../_virtual/index.cjs");
5
- const createTags = require("./create-tags.cjs");
6
- const tagInput = require("./tag-input.vue2.cjs");
7
- const vueTagsInput_props = require("./vue-tags-input.props.cjs");
8
- ;/* empty css */
9
- const _hoisted_1 = { class: "ti-input" };
10
- const _hoisted_2 = {
11
- key: 0,
12
- class: "ti-tags"
13
- };
14
- const _hoisted_3 = ["onClick"];
15
- const _hoisted_4 = { class: "ti-content" };
16
- const _hoisted_5 = {
17
- key: 0,
18
- class: "ti-tag-left"
19
- };
20
- const _hoisted_6 = ["onClick"];
21
- const _hoisted_7 = {
22
- key: 1,
23
- class: "ti-tag-right"
24
- };
25
- const _hoisted_8 = { class: "ti-actions" };
26
- const _hoisted_9 = ["onClick"];
27
- const _hoisted_10 = ["onClick"];
28
- const _hoisted_11 = { class: "ti-new-tag-input-wrapper" };
29
- const _hoisted_12 = ["placeholder", "value", "maxlength", "disabled"];
30
- const _hoisted_13 = ["onMouseenter"];
31
- const _hoisted_14 = ["onClick"];
32
- const _sfc_main = {
33
- __name: "FieldTags",
34
- props: vueTagsInput_props.default,
35
- emits: [
36
- "adding-duplicate",
37
- "before-adding-tag",
38
- "before-deleting-tag",
39
- "before-editing-tag",
40
- "before-saving-tag",
41
- "max-tags-reached",
42
- "saving-duplicate",
43
- "tags-changed",
44
- "tag-clicked",
45
- "update:modelValue",
46
- "update:tags"
47
- ],
48
- setup(__props, { expose: __expose, emit: __emit }) {
49
- const propsObj = __props;
50
- const emit = __emit;
51
- const tagCenterRefs = vue.ref(/* @__PURE__ */ new Map());
52
- const newTag = vue.ref(propsObj.modelValue || "");
53
- const tagsCopy = vue.shallowRef([]);
54
- const tagsEditStatus = vue.ref([]);
55
- const deletionMark = vue.ref(null);
56
- const deletionMarkTimer = vue.ref(null);
57
- const selectedItem = vue.ref(null);
58
- const focused = vue.ref(false);
59
- const newTagInputRef = vue.ref(null);
60
- const autocompleteOpen = vue.computed(() => {
61
- if (propsObj.autocompleteAlwaysOpen) return true;
62
- return newTag.value !== null && newTag.value.length >= propsObj.autocompleteMinLength && filteredAutocompleteItems.value.length > 0 && focused.value;
63
- });
64
- const filteredAutocompleteItems = vue.computed(() => {
65
- const items = propsObj.autocompleteItems.map(
66
- (i) => createTags.createTag(i, propsObj.tags, propsObj.validation, propsObj.isDuplicate)
67
- );
68
- if (!propsObj.autocompleteFilterDuplicates) return items;
69
- return items.filter(duplicateFilter);
70
- });
71
- const getSelectedIndex = (method) => {
72
- const items = filteredAutocompleteItems.value;
73
- const current = selectedItem.value;
74
- const lastItem = items.length - 1;
75
- if (items.length === 0) return;
76
- if (current === null) return 0;
77
- if (method === "before" && current === 0) return lastItem;
78
- if (method === "after" && current === lastItem) return 0;
79
- return method === "after" ? current + 1 : current - 1;
80
- };
81
- const selectDefaultItem = () => {
82
- selectedItem.value = propsObj.addOnlyFromAutocomplete && filteredAutocompleteItems.value.length > 0 ? 0 : null;
83
- };
84
- const selectItem = (method) => {
85
- selectedItem.value = getSelectedIndex(method);
86
- };
87
- const isSelected = (index2) => selectedItem.value === index2;
88
- const isMarked = (index2) => deletionMark.value === index2;
89
- const setTagCenter = (el, index2) => {
90
- if (el) {
91
- tagCenterRefs.value.set(index2, el);
92
- } else {
93
- tagCenterRefs.value.delete(index2);
94
- }
95
- };
96
- const invokeDelete = () => {
97
- if (!propsObj.deleteOnBackspace || newTag.value.length > 0) return;
98
- const lastIndex = tagsCopy.value.length - 1;
99
- if (deletionMark.value === null) {
100
- clearTimeout(deletionMarkTimer.value);
101
- deletionMarkTimer.value = setTimeout(() => deletionMark.value = null, 1e3);
102
- deletionMark.value = lastIndex;
103
- } else {
104
- performDeleteTag(lastIndex);
105
- }
106
- };
107
- const addTagsFromPaste = () => {
108
- if (!propsObj.addFromPaste) return;
109
- setTimeout(() => performAddTags(newTag.value), 10);
110
- };
111
- const performEditTag = (index2) => {
112
- if (!propsObj.allowEditTags) return;
113
- if (!propsObj.onBeforeEditingTag) {
114
- editTag(index2);
115
- } else {
116
- emit("before-editing-tag", {
117
- index: index2,
118
- tag: tagsCopy.value[index2],
119
- editTag: () => editTag(index2)
120
- });
121
- }
122
- };
123
- const editTag = (index2) => {
124
- if (!propsObj.allowEditTags) return;
125
- toggleEditMode(index2);
126
- focus(index2);
127
- };
128
- const toggleEditMode = (index2) => {
129
- if (!propsObj.allowEditTags || propsObj.disabled) return;
130
- tagsEditStatus.value[index2] = !tagsEditStatus.value[index2];
131
- };
132
- const createChangedTag = (index2, event) => {
133
- const tag = tagsCopy.value[index2];
134
- tag.text = event ? event.target.value : tagsCopy.value[index2].text;
135
- const newTags = [...tagsCopy.value];
136
- newTags[index2] = createTags.createTag(tag, tagsCopy.value, propsObj.validation, propsObj.isDuplicate);
137
- tagsCopy.value = newTags;
138
- };
139
- const focus = (index2) => {
140
- vue.nextTick(() => {
141
- const el = tagCenterRefs.value.get(index2)?.querySelector("input.ti-tag-input");
142
- if (el) el.focus();
143
- });
144
- };
145
- const quote = (regex) => regex.replace(/([()[{*+.$^\\|?])/g, "\\$1");
146
- const cancelEdit = (index2) => {
147
- if (!propsObj.tags[index2]) return;
148
- const newTags = [...tagsCopy.value];
149
- newTags[index2] = createTags.clone(createTags.createTag(propsObj.tags[index2], propsObj.tags, propsObj.validation, propsObj.isDuplicate));
150
- tagsCopy.value = newTags;
151
- tagsEditStatus.value[index2] = false;
152
- };
153
- const hasForbiddingAddRule = (tiClasses) => {
154
- return tiClasses.some((type) => {
155
- const rule = propsObj.validation.find((rule2) => type === rule2.classes);
156
- return rule ? rule.disableAdd : false;
157
- });
158
- };
159
- const createTagTexts = (string) => {
160
- const regex = new RegExp(propsObj.separators.map((s) => quote(s)).join("|"));
161
- return string.split(regex).map((text) => ({ text }));
162
- };
163
- const performDeleteTag = (index2) => {
164
- if (!propsObj.onBeforeDeletingTag) {
165
- deleteTag(index2);
166
- } else {
167
- emit("before-deleting-tag", {
168
- index: index2,
169
- tag: tagsCopy.value[index2],
170
- deleteTag: () => deleteTag(index2)
171
- });
172
- }
173
- };
174
- const deleteTag = (index2) => {
175
- if (propsObj.disabled) return;
176
- deletionMark.value = null;
177
- clearTimeout(deletionMarkTimer.value);
178
- const newTags = [...tagsCopy.value];
179
- newTags.splice(index2, 1);
180
- tagsCopy.value = newTags;
181
- tagsEditStatus.value.splice(index2, 1);
182
- emit("update:tags", tagsCopy.value);
183
- emit("tags-changed", tagsCopy.value);
184
- };
185
- const noTriggerKey = (event, category) => {
186
- const triggerKey = propsObj[category].indexOf(event.keyCode) !== -1 || propsObj[category].indexOf(event.key) !== -1;
187
- if (triggerKey) event.preventDefault();
188
- return !triggerKey;
189
- };
190
- const performAddTags = (tag, event, source) => {
191
- if (propsObj.disabled || event && noTriggerKey(event, "addOnKey")) return;
192
- let tags = [];
193
- if (typeof tag === "object") tags = [tag];
194
- if (typeof tag === "string") tags = createTagTexts(tag);
195
- tags = tags.filter((tag2) => tag2.text.trim().length > 0);
196
- tags.forEach((tag2) => {
197
- tag2 = createTags.createTag(tag2, propsObj.tags, propsObj.validation, propsObj.isDuplicate);
198
- if (!propsObj.onBeforeAddingTag) {
199
- addTag(tag2, source);
200
- } else {
201
- emit("before-adding-tag", {
202
- tag: tag2,
203
- addTag: () => addTag(tag2, source)
204
- });
205
- }
206
- });
207
- };
208
- const duplicateFilter = (tag) => {
209
- return propsObj.isDuplicate ? !propsObj.isDuplicate(tagsCopy.value, tag) : !tagsCopy.value.find((t) => t.text === tag.text);
210
- };
211
- const addTag = (tag, source = "new-tag-input") => {
212
- const options = filteredAutocompleteItems.value.map((i) => i.text);
213
- if (propsObj.addOnlyFromAutocomplete && options.indexOf(tag.text) === -1) return;
214
- vue.nextTick(() => {
215
- const maximumReached = propsObj.maxTags && propsObj.maxTags <= tagsCopy.value.length;
216
- if (maximumReached) return emit("max-tags-reached", tag);
217
- const dup = propsObj.avoidAddingDuplicates && !duplicateFilter(tag);
218
- if (dup) return emit("adding-duplicate", tag);
219
- if (hasForbiddingAddRule(tag.tiClasses)) return;
220
- newTag.value = "";
221
- tagsCopy.value = [...tagsCopy.value, tag];
222
- tagsEditStatus.value.push(false);
223
- emit("update:tags", tagsCopy.value);
224
- if (source === "autocomplete") newTagInputRef.value?.focus();
225
- emit("tags-changed", tagsCopy.value);
226
- });
227
- };
228
- const performSaveTag = (index2, event) => {
229
- const tag = tagsCopy.value[index2];
230
- if (propsObj.disabled || event && noTriggerKey(event, "addOnKey")) return;
231
- if (tag.text.trim().length === 0) return;
232
- if (!propsObj["onBeforeSavingTag"]) {
233
- saveTag(index2, tag);
234
- } else {
235
- emit("before-saving-tag", {
236
- index: index2,
237
- tag,
238
- saveTag: () => saveTag(index2, tag)
239
- });
240
- }
241
- };
242
- const saveTag = (index2, tag) => {
243
- if (propsObj.avoidAddingDuplicates) {
244
- const tagsDiff = createTags.clone(tagsCopy.value);
245
- const inputTag = tagsDiff.splice(index2, 1)[0];
246
- const dup = propsObj.isDuplicate ? propsObj.isDuplicate(tagsDiff, inputTag) : tagsDiff.map((t) => t.text).indexOf(inputTag.text) !== -1;
247
- if (dup) return emit("saving-duplicate", tag);
248
- }
249
- if (hasForbiddingAddRule(tag.tiClasses)) return;
250
- const newTags = [...tagsCopy.value];
251
- newTags[index2] = tag;
252
- tagsCopy.value = newTags;
253
- toggleEditMode(index2);
254
- emit("update:tags", tagsCopy.value);
255
- emit("tags-changed", tagsCopy.value);
256
- };
257
- const tagsEqual = () => {
258
- return !tagsCopy.value.some((t, i) => !index.default(t, propsObj.tags[i]));
259
- };
260
- const updateNewTag = (event) => {
261
- const value = event.target.value;
262
- newTag.value = value;
263
- emit("update:modelValue", value);
264
- };
265
- const initTags = () => {
266
- tagsCopy.value = createTags.createTags(propsObj.tags, propsObj.validation, propsObj.isDuplicate);
267
- tagsEditStatus.value = new Array(propsObj.tags.length).fill(false);
268
- if (!tagsEqual()) {
269
- emit("update:tags", tagsCopy.value);
270
- }
271
- };
272
- const blurredOnClick = (e) => {
273
- const el = e.currentTarget;
274
- if (el?.contains(e.target) || el?.contains(document.activeElement)) return;
275
- performBlur();
276
- };
277
- const performBlur = () => {
278
- if (propsObj.addOnBlur && focused.value) performAddTags(newTag.value);
279
- focused.value = false;
280
- };
281
- const handleKeyDown = (event) => {
282
- const item = filteredAutocompleteItems.value[selectedItem.value] || newTag.value;
283
- performAddTags(item, event);
284
- };
285
- vue.watch(() => propsObj.modelValue, (newValue) => {
286
- if (!propsObj.addOnlyFromAutocomplete) selectedItem.value = null;
287
- newTag.value = newValue;
288
- });
289
- vue.watch(() => propsObj.tags, () => {
290
- initTags();
291
- }, { deep: true });
292
- vue.watch(autocompleteOpen, selectDefaultItem);
293
- initTags();
294
- vue.onMounted(() => {
295
- selectDefaultItem();
296
- document.addEventListener("click", blurredOnClick);
297
- });
298
- vue.onBeforeUnmount(() => {
299
- document.removeEventListener("click", blurredOnClick);
300
- clearTimeout(deletionMarkTimer.value);
301
- });
302
- __expose({
303
- createClasses: createTags.createClasses
304
- });
305
- return (_ctx, _cache) => {
306
- return vue.openBlock(), vue.createElementBlock("div", {
307
- class: vue.normalizeClass(["vue-tags-input pos-relative", [{ "ti-disabled": _ctx.disabled }, { "ti-focus": focused.value }, _ctx.$attrs.class]]),
308
- style: vue.normalizeStyle(_ctx.$attrs.style)
309
- }, [
310
- vue.createElementVNode("div", _hoisted_1, [
311
- tagsCopy.value.length || !_ctx.disabled ? (vue.openBlock(), vue.createElementBlock("ul", _hoisted_2, [
312
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(tagsCopy.value, (tag, index2) => {
313
- return vue.openBlock(), vue.createElementBlock("li", {
314
- key: `tag-${index2}-${tag.text}`,
315
- style: vue.normalizeStyle(tag.style),
316
- class: vue.normalizeClass([[
317
- { "ti-editing": tagsEditStatus.value[index2] },
318
- tag.tiClasses,
319
- tag.classes,
320
- { "ti-deletion-mark": isMarked(index2) }
321
- ], "ti-tag t-medium"]),
322
- tabindex: "0",
323
- onClick: ($event) => emit("tag-clicked", { tag, index: index2 })
324
- }, [
325
- vue.createElementVNode("div", _hoisted_4, [
326
- _ctx.$slots["tag-left"] ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_5, [
327
- vue.renderSlot(_ctx.$slots, "tag-left", {
328
- tag,
329
- index: index2,
330
- edit: tagsEditStatus.value[index2],
331
- performSaveEdit: performSaveTag,
332
- performDelete: performDeleteTag,
333
- performCancelEdit: cancelEdit,
334
- performOpenEdit: performEditTag,
335
- deletionMark: isMarked(index2)
336
- })
337
- ])) : vue.createCommentVNode("", true),
338
- vue.createElementVNode("div", {
339
- ref_for: true,
340
- ref: (el) => setTagCenter(el, index2),
341
- class: "ti-tag-center"
342
- }, [
343
- !_ctx.$slots["tag-center"] ? (vue.openBlock(), vue.createElementBlock("span", {
344
- key: 0,
345
- class: vue.normalizeClass({ "ti-hidden": tagsEditStatus.value[index2] }),
346
- onClick: ($event) => performEditTag(index2)
347
- }, vue.toDisplayString(tag.text), 11, _hoisted_6)) : vue.createCommentVNode("", true),
348
- !_ctx.$slots["tag-center"] ? (vue.openBlock(), vue.createBlock(tagInput.default, {
349
- key: 1,
350
- scope: {
351
- edit: tagsEditStatus.value[index2],
352
- maxlength: _ctx.maxlength,
353
- tag,
354
- index: index2,
355
- validateTag: createChangedTag,
356
- performCancelEdit: cancelEdit,
357
- performSaveEdit: performSaveTag
358
- }
359
- }, null, 8, ["scope"])) : vue.createCommentVNode("", true),
360
- vue.renderSlot(_ctx.$slots, "tag-center", {
361
- tag,
362
- index: index2,
363
- maxlength: _ctx.maxlength,
364
- edit: tagsEditStatus.value[index2],
365
- performSaveEdit: performSaveTag,
366
- performDelete: performDeleteTag,
367
- performCancelEdit: cancelEdit,
368
- validateTag: createChangedTag,
369
- performOpenEdit: performEditTag,
370
- deletionMark: isMarked(index2)
371
- })
372
- ], 512),
373
- _ctx.$slots["tag-right"] ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_7, [
374
- vue.renderSlot(_ctx.$slots, "tag-right", {
375
- tag,
376
- index: index2,
377
- edit: tagsEditStatus.value[index2],
378
- performSaveEdit: performSaveTag,
379
- performDelete: performDeleteTag,
380
- performCancelEdit: cancelEdit,
381
- performOpenEdit: performEditTag,
382
- deletionMark: isMarked(index2)
383
- })
384
- ])) : vue.createCommentVNode("", true)
385
- ]),
386
- vue.createElementVNode("div", _hoisted_8, [
387
- !_ctx.$slots["tag-actions"] ? vue.withDirectives((vue.openBlock(), vue.createElementBlock("i", {
388
- key: 0,
389
- class: "ti-icon-undo",
390
- onClick: vue.withModifiers(($event) => cancelEdit(index2), ["stop"])
391
- }, null, 8, _hoisted_9)), [
392
- [vue.vShow, tagsEditStatus.value[index2]]
393
- ]) : vue.createCommentVNode("", true),
394
- !_ctx.$slots["tag-actions"] ? vue.withDirectives((vue.openBlock(), vue.createElementBlock("i", {
395
- key: 1,
396
- class: "ti-icon-close",
397
- onClick: vue.withModifiers(($event) => performDeleteTag(index2), ["stop"])
398
- }, null, 8, _hoisted_10)), [
399
- [vue.vShow, !tagsEditStatus.value[index2]]
400
- ]) : vue.createCommentVNode("", true),
401
- _ctx.$slots["tag-actions"] ? vue.renderSlot(_ctx.$slots, "tag-actions", {
402
- key: 2,
403
- tag,
404
- index: index2,
405
- edit: tagsEditStatus.value[index2],
406
- performSaveEdit: performSaveTag,
407
- performDelete: performDeleteTag,
408
- performCancelEdit: cancelEdit,
409
- performOpenEdit: performEditTag,
410
- deletionMark: isMarked(index2)
411
- }) : vue.createCommentVNode("", true)
412
- ])
413
- ], 14, _hoisted_3);
414
- }), 128)),
415
- vue.createElementVNode("li", _hoisted_11, [
416
- vue.createElementVNode("input", {
417
- ref_key: "newTagInputRef",
418
- ref: newTagInputRef,
419
- class: vue.normalizeClass([[vue.unref(createTags.createClasses)(newTag.value, _ctx.tags, _ctx.validation, _ctx.isDuplicate)], "ti-new-tag-input"]),
420
- placeholder: _ctx.placeholder,
421
- value: newTag.value,
422
- maxlength: _ctx.maxlength,
423
- disabled: _ctx.disabled,
424
- type: "text",
425
- size: "1",
426
- onKeydown: [
427
- handleKeyDown,
428
- vue.withKeys(invokeDelete, ["delete"]),
429
- vue.withKeys(performBlur, ["tab"]),
430
- _cache[0] || (_cache[0] = vue.withKeys(vue.withModifiers(($event) => selectItem("before"), ["prevent"]), ["up"])),
431
- _cache[1] || (_cache[1] = vue.withKeys(vue.withModifiers(($event) => selectItem("after"), ["prevent"]), ["down"]))
432
- ],
433
- onPaste: addTagsFromPaste,
434
- onInput: updateNewTag,
435
- onFocus: _cache[2] || (_cache[2] = ($event) => focused.value = true),
436
- onClick: _cache[3] || (_cache[3] = ($event) => !_ctx.addOnlyFromAutocomplete && (selectedItem.value = null))
437
- }, null, 42, _hoisted_12)
438
- ])
439
- ])) : vue.createCommentVNode("", true)
440
- ]),
441
- vue.renderSlot(_ctx.$slots, "between-elements"),
442
- autocompleteOpen.value ? (vue.openBlock(), vue.createElementBlock("div", {
443
- key: 0,
444
- class: vue.normalizeClass(["ti-autocomplete", _ctx.$attrs.class]),
445
- onMouseleave: _cache[4] || (_cache[4] = ($event) => selectedItem.value = null)
446
- }, [
447
- vue.renderSlot(_ctx.$slots, "autocomplete-header"),
448
- vue.createElementVNode("ul", null, [
449
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(filteredAutocompleteItems.value, (item, index2) => {
450
- return vue.openBlock(), vue.createElementBlock("li", {
451
- key: `autocomplete-${index2}-${item.text}`,
452
- style: vue.normalizeStyle(item.style),
453
- class: vue.normalizeClass([[
454
- item.tiClasses,
455
- item.classes,
456
- { "ti-selected-item": isSelected(index2) }
457
- ], "ti-item"]),
458
- onMouseenter: ($event) => !_ctx.disabled && (selectedItem.value = index2)
459
- }, [
460
- !_ctx.$slots["autocomplete-item"] ? (vue.openBlock(), vue.createElementBlock("div", {
461
- key: 0,
462
- onClick: ($event) => performAddTags(item, void 0, "autocomplete")
463
- }, vue.toDisplayString(item.text), 9, _hoisted_14)) : vue.renderSlot(_ctx.$slots, "autocomplete-item", {
464
- key: 1,
465
- item,
466
- index: index2,
467
- performAdd: (item2) => performAddTags(item2, void 0, "autocomplete"),
468
- selected: isSelected(index2)
469
- })
470
- ], 46, _hoisted_13);
471
- }), 128))
472
- ]),
473
- vue.renderSlot(_ctx.$slots, "autocomplete-footer")
474
- ], 34)) : vue.createCommentVNode("", true)
475
- ], 6);
476
- };
477
- }
478
- };
479
- exports.default = _sfc_main;
480
- //# sourceMappingURL=FieldTags.vue.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"FieldTags.vue.cjs","sources":["../../../../../src/components/FieldTags/FieldTags.vue"],"sourcesContent":["<template>\n <div\n class=\"vue-tags-input pos-relative\"\n :class=\"[{ 'ti-disabled': disabled }, { 'ti-focus': focused }, $attrs.class]\"\n :style=\"$attrs.style\"\n >\n <div class=\"ti-input\">\n <ul v-if=\"tagsCopy.length || !disabled\" class=\"ti-tags\">\n <li\n v-for=\"(tag, index) in tagsCopy\"\n :key=\"`tag-${index}-${tag.text}`\"\n :style=\"tag.style\"\n :class=\"[\n { 'ti-editing': tagsEditStatus[index] },\n tag.tiClasses,\n tag.classes,\n { 'ti-deletion-mark': isMarked(index) }\n ]\"\n tabindex=\"0\"\n class=\"ti-tag t-medium\"\n @click=\"emit('tag-clicked', { tag, index })\"\n >\n <div class=\"ti-content\">\n <div\n v-if=\"$slots['tag-left']\"\n class=\"ti-tag-left\"\n >\n <slot\n name=\"tag-left\"\n :tag=\"tag\"\n :index=\"index\"\n :edit=\"tagsEditStatus[index]\"\n :perform-save-edit=\"performSaveTag\"\n :perform-delete=\"performDeleteTag\"\n :perform-cancel-edit=\"cancelEdit\"\n :perform-open-edit=\"performEditTag\"\n :deletion-mark=\"isMarked(index)\"\n />\n </div>\n <div :ref=\"el => setTagCenter(el, index)\" class=\"ti-tag-center\">\n <span\n v-if=\"!$slots['tag-center']\"\n :class=\"{ 'ti-hidden': tagsEditStatus[index] }\"\n @click=\"performEditTag(index)\"\n >{{ tag.text }}</span>\n <tag-input\n v-if=\"!$slots['tag-center']\"\n :scope=\"{\n edit: tagsEditStatus[index],\n maxlength,\n tag,\n index,\n validateTag: createChangedTag,\n performCancelEdit: cancelEdit,\n performSaveEdit: performSaveTag,\n }\"\n />\n <slot\n name=\"tag-center\"\n :tag=\"tag\"\n :index=\"index\"\n :maxlength=\"maxlength\"\n :edit=\"tagsEditStatus[index]\"\n :perform-save-edit=\"performSaveTag\"\n :perform-delete=\"performDeleteTag\"\n :perform-cancel-edit=\"cancelEdit\"\n :validate-tag=\"createChangedTag\"\n :perform-open-edit=\"performEditTag\"\n :deletion-mark=\"isMarked(index)\"\n />\n </div>\n <div\n v-if=\"$slots['tag-right']\"\n class=\"ti-tag-right\"\n >\n <slot\n name=\"tag-right\"\n :tag=\"tag\"\n :index=\"index\"\n :edit=\"tagsEditStatus[index]\"\n :perform-save-edit=\"performSaveTag\"\n :perform-delete=\"performDeleteTag\"\n :perform-cancel-edit=\"cancelEdit\"\n :perform-open-edit=\"performEditTag\"\n :deletion-mark=\"isMarked(index)\"\n />\n </div>\n </div>\n <div class=\"ti-actions\">\n <i\n v-if=\"!$slots['tag-actions']\"\n v-show=\"tagsEditStatus[index]\"\n class=\"ti-icon-undo\"\n @click.stop=\"cancelEdit(index)\"\n />\n <i\n v-if=\"!$slots['tag-actions']\"\n v-show=\"!tagsEditStatus[index]\"\n class=\"ti-icon-close\"\n @click.stop=\"performDeleteTag(index)\"\n />\n <slot\n v-if=\"$slots['tag-actions']\"\n name=\"tag-actions\"\n :tag=\"tag\"\n :index=\"index\"\n :edit=\"tagsEditStatus[index]\"\n :perform-save-edit=\"performSaveTag\"\n :perform-delete=\"performDeleteTag\"\n :perform-cancel-edit=\"cancelEdit\"\n :perform-open-edit=\"performEditTag\"\n :deletion-mark=\"isMarked(index)\"\n />\n </div>\n </li>\n <li class=\"ti-new-tag-input-wrapper\">\n <input\n ref=\"newTagInputRef\"\n :class=\"[createClasses(newTag, tags, validation, isDuplicate)]\"\n :placeholder=\"placeholder\"\n :value=\"newTag\"\n :maxlength=\"maxlength\"\n :disabled=\"disabled\"\n type=\"text\"\n size=\"1\"\n class=\"ti-new-tag-input\"\n @keydown=\"handleKeyDown\"\n @paste=\"addTagsFromPaste\"\n @keydown.delete=\"invokeDelete\"\n @keydown.tab=\"performBlur\"\n @keydown.up.prevent=\"selectItem('before')\"\n @keydown.down.prevent=\"selectItem('after')\"\n @input=\"updateNewTag\"\n @focus=\"focused = true\"\n @click=\"!addOnlyFromAutocomplete && (selectedItem = null)\"\n >\n </li>\n </ul>\n </div>\n <slot name=\"between-elements\" />\n <div\n v-if=\"autocompleteOpen\"\n class=\"ti-autocomplete\"\n :class=\"$attrs.class\"\n @mouseleave=\"selectedItem = null\"\n >\n <slot name=\"autocomplete-header\" />\n <ul>\n <li\n v-for=\"(item, index) in filteredAutocompleteItems\"\n :key=\"`autocomplete-${index}-${item.text}`\"\n :style=\"item.style\"\n :class=\"[\n item.tiClasses,\n item.classes,\n { 'ti-selected-item': isSelected(index) }\n ]\"\n class=\"ti-item\"\n @mouseenter=\"!disabled && (selectedItem = index)\"\n >\n <div\n v-if=\"!$slots['autocomplete-item']\"\n @click=\"performAddTags(item, undefined, 'autocomplete')\"\n >\n {{ item.text }}\n </div>\n <slot\n v-else\n name=\"autocomplete-item\"\n :item=\"item\"\n :index=\"index\"\n :perform-add=\"item => performAddTags(item, undefined, 'autocomplete')\"\n :selected=\"isSelected(index)\"\n />\n </li>\n </ul>\n <slot name=\"autocomplete-footer\" />\n </div>\n </div>\n</template>\n\n<script setup>\nimport { ref, computed, watch, nextTick, onMounted, onBeforeUnmount, shallowRef, toRef } from 'vue';\nimport equal from 'fast-deep-equal';\nimport { clone, createClasses, createTag, createTags } from './create-tags.js';\nimport TagInput from './tag-input.vue';\nimport props from './vue-tags-input.props.js';\n\n// Props\nconst propsObj = defineProps(props);\n\n// Emits\nconst emit = defineEmits([\n 'adding-duplicate',\n 'before-adding-tag',\n 'before-deleting-tag',\n 'before-editing-tag',\n 'before-saving-tag',\n 'max-tags-reached',\n 'saving-duplicate',\n 'tags-changed',\n 'tag-clicked',\n 'update:modelValue',\n 'update:tags',\n]);\n\n// State\nconst tagCenterRefs = ref(new Map());\nconst newTag = ref(propsObj.modelValue || '');\nconst tagsCopy = shallowRef([]);\nconst tagsEditStatus = ref([]);\nconst deletionMark = ref(null);\nconst deletionMarkTimer = ref(null);\nconst selectedItem = ref(null);\nconst focused = ref(false);\nconst newTagInputRef = ref(null);\n\n// Computed\nconst autocompleteOpen = computed(() => {\n if (propsObj.autocompleteAlwaysOpen) return true;\n return newTag.value !== null && \n newTag.value.length >= propsObj.autocompleteMinLength && \n filteredAutocompleteItems.value.length > 0 && \n focused.value;\n});\n\nconst filteredAutocompleteItems = computed(() => {\n const items = propsObj.autocompleteItems.map(i => \n createTag(i, propsObj.tags, propsObj.validation, propsObj.isDuplicate)\n );\n\n if (!propsObj.autocompleteFilterDuplicates) return items;\n return items.filter(duplicateFilter);\n});\n\n// Methods\nconst getSelectedIndex = (method) => {\n const items = filteredAutocompleteItems.value;\n const current = selectedItem.value;\n const lastItem = items.length - 1;\n \n if (items.length === 0) return;\n if (current === null) return 0;\n if (method === 'before' && current === 0) return lastItem;\n if (method === 'after' && current === lastItem) return 0;\n return method === 'after' ? current + 1 : current - 1;\n};\n\nconst selectDefaultItem = () => {\n selectedItem.value = propsObj.addOnlyFromAutocomplete && filteredAutocompleteItems.value.length > 0 ? 0 : null;\n};\n\nconst selectItem = (method) => {\n selectedItem.value = getSelectedIndex(method);\n};\n\nconst isSelected = (index) => selectedItem.value === index;\nconst isMarked = (index) => deletionMark.value === index;\n\nconst setTagCenter = (el, index) => {\n if (el) {\n tagCenterRefs.value.set(index, el);\n } else {\n tagCenterRefs.value.delete(index);\n }\n};\n\nconst invokeDelete = () => {\n if (!propsObj.deleteOnBackspace || newTag.value.length > 0) return;\n \n const lastIndex = tagsCopy.value.length - 1;\n if (deletionMark.value === null) {\n clearTimeout(deletionMarkTimer.value);\n deletionMarkTimer.value = setTimeout(() => (deletionMark.value = null), 1000);\n deletionMark.value = lastIndex;\n } else {\n performDeleteTag(lastIndex);\n }\n};\n\nconst addTagsFromPaste = () => {\n if (!propsObj.addFromPaste) return;\n setTimeout(() => performAddTags(newTag.value), 10);\n};\n\nconst performEditTag = (index) => {\n if (!propsObj.allowEditTags) return;\n \n if (!propsObj.onBeforeEditingTag) {\n editTag(index);\n } else {\n emit('before-editing-tag', {\n index,\n tag: tagsCopy.value[index],\n editTag: () => editTag(index),\n });\n }\n};\n\nconst editTag = (index) => {\n if (!propsObj.allowEditTags) return;\n toggleEditMode(index);\n focus(index);\n};\n\nconst toggleEditMode = (index) => {\n if (!propsObj.allowEditTags || propsObj.disabled) return;\n tagsEditStatus.value[index] = !tagsEditStatus.value[index];\n};\n\nconst createChangedTag = (index, event) => {\n const tag = tagsCopy.value[index];\n tag.text = event ? event.target.value : tagsCopy.value[index].text;\n \n const newTags = [...tagsCopy.value];\n newTags[index] = createTag(tag, tagsCopy.value, propsObj.validation, propsObj.isDuplicate);\n tagsCopy.value = newTags;\n};\n\nconst focus = (index) => {\n nextTick(() => {\n const el = tagCenterRefs.value.get(index)?.querySelector('input.ti-tag-input');\n if (el) el.focus();\n });\n};\n\nconst quote = (regex) => regex.replace(/([()[{*+.$^\\\\|?])/g, '\\\\$1');\n\nconst cancelEdit = (index) => {\n if (!propsObj.tags[index]) return;\n \n const newTags = [...tagsCopy.value];\n newTags[index] = clone(createTag(propsObj.tags[index], propsObj.tags, propsObj.validation, propsObj.isDuplicate));\n tagsCopy.value = newTags;\n tagsEditStatus.value[index] = false;\n};\n\nconst hasForbiddingAddRule = (tiClasses) => {\n return tiClasses.some(type => {\n const rule = propsObj.validation.find(rule => type === rule.classes);\n return rule ? rule.disableAdd : false;\n });\n};\n\nconst createTagTexts = (string) => {\n const regex = new RegExp(propsObj.separators.map(s => quote(s)).join('|'));\n return string.split(regex).map(text => ({ text }));\n};\n\nconst performDeleteTag = (index) => {\n if (!propsObj.onBeforeDeletingTag) {\n deleteTag(index);\n } else {\n emit('before-deleting-tag', {\n index,\n tag: tagsCopy.value[index],\n deleteTag: () => deleteTag(index),\n });\n }\n};\n\nconst deleteTag = (index) => {\n if (propsObj.disabled) return;\n \n deletionMark.value = null;\n clearTimeout(deletionMarkTimer.value);\n \n const newTags = [...tagsCopy.value];\n newTags.splice(index, 1);\n tagsCopy.value = newTags;\n \n tagsEditStatus.value.splice(index, 1);\n \n emit('update:tags', tagsCopy.value);\n emit('tags-changed', tagsCopy.value);\n};\n\nconst noTriggerKey = (event, category) => {\n const triggerKey = propsObj[category].indexOf(event.keyCode) !== -1 || \n propsObj[category].indexOf(event.key) !== -1;\n if (triggerKey) event.preventDefault();\n return !triggerKey;\n};\n\nconst performAddTags = (tag, event, source) => {\n if (propsObj.disabled || (event && noTriggerKey(event, 'addOnKey'))) return;\n\n let tags = [];\n if (typeof tag === 'object') tags = [tag];\n if (typeof tag === 'string') tags = createTagTexts(tag);\n\n tags = tags.filter(tag => tag.text.trim().length > 0);\n\n tags.forEach(tag => {\n tag = createTag(tag, propsObj.tags, propsObj.validation, propsObj.isDuplicate);\n if (!propsObj.onBeforeAddingTag) {\n addTag(tag, source);\n } else {\n emit('before-adding-tag', {\n tag,\n addTag: () => addTag(tag, source),\n });\n }\n });\n};\n\nconst duplicateFilter = (tag) => {\n return propsObj.isDuplicate ? \n !propsObj.isDuplicate(tagsCopy.value, tag) : \n !tagsCopy.value.find(t => t.text === tag.text);\n};\n\nconst addTag = (tag, source = 'new-tag-input') => {\n const options = filteredAutocompleteItems.value.map(i => i.text);\n if (propsObj.addOnlyFromAutocomplete && options.indexOf(tag.text) === -1) return;\n\n nextTick(() => {\n const maximumReached = propsObj.maxTags && propsObj.maxTags <= tagsCopy.value.length;\n if (maximumReached) return emit('max-tags-reached', tag);\n\n const dup = propsObj.avoidAddingDuplicates && !duplicateFilter(tag);\n if (dup) return emit('adding-duplicate', tag);\n\n if (hasForbiddingAddRule(tag.tiClasses)) return;\n\n newTag.value = '';\n tagsCopy.value = [...tagsCopy.value, tag];\n tagsEditStatus.value.push(false);\n\n emit('update:tags', tagsCopy.value);\n\n if (source === 'autocomplete') newTagInputRef.value?.focus();\n\n emit('tags-changed', tagsCopy.value);\n });\n};\n\nconst performSaveTag = (index, event) => {\n const tag = tagsCopy.value[index];\n\n if (propsObj.disabled || (event && noTriggerKey(event, 'addOnKey'))) return;\n if (tag.text.trim().length === 0) return;\n\n if (!propsObj['onBeforeSavingTag']) {\n saveTag(index, tag);\n } else {\n emit('before-saving-tag', {\n index,\n tag,\n saveTag: () => saveTag(index, tag),\n });\n }\n};\n\nconst saveTag = (index, tag) => {\n if (propsObj.avoidAddingDuplicates) {\n const tagsDiff = clone(tagsCopy.value);\n const inputTag = tagsDiff.splice(index, 1)[0];\n const dup = propsObj.isDuplicate ? \n propsObj.isDuplicate(tagsDiff, inputTag) : \n tagsDiff.map(t => t.text).indexOf(inputTag.text) !== -1;\n\n if (dup) return emit('saving-duplicate', tag);\n }\n\n if (hasForbiddingAddRule(tag.tiClasses)) return;\n\n const newTags = [...tagsCopy.value];\n newTags[index] = tag;\n tagsCopy.value = newTags;\n toggleEditMode(index);\n\n emit('update:tags', tagsCopy.value);\n emit('tags-changed', tagsCopy.value);\n};\n\nconst tagsEqual = () => {\n return !tagsCopy.value.some((t, i) => !equal(t, propsObj.tags[i]));\n};\n\nconst updateNewTag = (event) => {\n const value = event.target.value;\n newTag.value = value;\n emit('update:modelValue', value);\n};\n\nconst initTags = () => {\n tagsCopy.value = createTags(propsObj.tags, propsObj.validation, propsObj.isDuplicate);\n tagsEditStatus.value = new Array(propsObj.tags.length).fill(false);\n\n if (!tagsEqual()) {\n emit('update:tags', tagsCopy.value);\n }\n};\n\nconst blurredOnClick = (e) => {\n const el = e.currentTarget;\n if (el?.contains(e.target) || el?.contains(document.activeElement)) return;\n performBlur();\n};\n\nconst performBlur = () => {\n if (propsObj.addOnBlur && focused.value) performAddTags(newTag.value);\n focused.value = false;\n};\n\nconst handleKeyDown = (event) => {\n const item = filteredAutocompleteItems.value[selectedItem.value] || newTag.value;\n performAddTags(item, event);\n};\n\n// Watchers\nwatch(() => propsObj.modelValue, (newValue) => {\n if (!propsObj.addOnlyFromAutocomplete) selectedItem.value = null;\n newTag.value = newValue;\n});\n\nwatch(() => propsObj.tags, () => {\n initTags();\n}, { deep: true });\n\nwatch(autocompleteOpen, selectDefaultItem);\n\n// Lifecycle\ninitTags();\n\nonMounted(() => {\n selectDefaultItem();\n document.addEventListener('click', blurredOnClick);\n});\n\nonBeforeUnmount(() => {\n document.removeEventListener('click', blurredOnClick);\n clearTimeout(deletionMarkTimer.value);\n});\n\n// Expose for template\ndefineExpose({\n createClasses\n});\n</script>\n\n<style lang=\"scss\" src=\"./vue-tags-input.scss\"></style>"],"names":["ref","shallowRef","computed","createTag","index","nextTick","clone","rule","tag","equal","createTags","watch","onMounted","onBeforeUnmount","createClasses"],"mappings":"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"}