@bagelink/vue 0.0.1232 → 0.0.1236

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 (224) hide show
  1. package/dist/components/Accordion.d.ts +12 -0
  2. package/dist/components/Accordion.d.ts.map +1 -0
  3. package/dist/components/AccordionItem.d.ts +34 -0
  4. package/dist/components/AccordionItem.d.ts.map +1 -0
  5. package/dist/components/Alert.d.ts +34 -0
  6. package/dist/components/Alert.d.ts.map +1 -0
  7. package/dist/components/Avatar.d.ts +36 -0
  8. package/dist/components/Avatar.d.ts.map +1 -0
  9. package/dist/components/Badge.d.ts +22 -0
  10. package/dist/components/Badge.d.ts.map +1 -0
  11. package/dist/components/BglVideo.d.ts +20 -0
  12. package/dist/components/BglVideo.d.ts.map +1 -0
  13. package/dist/components/Btn.d.ts +99 -0
  14. package/dist/components/Btn.d.ts.map +1 -0
  15. package/dist/components/Card.d.ts +39 -0
  16. package/dist/components/Card.d.ts.map +1 -0
  17. package/dist/components/Carousel.d.ts +74 -0
  18. package/dist/components/Carousel.d.ts.map +1 -0
  19. package/dist/components/ComboBox.vue.d.ts +3 -3
  20. package/dist/components/Comments.vue.d.ts +2 -2
  21. package/dist/components/ContactSubmissions.vue.d.ts +2 -2
  22. package/dist/components/DataPreview.d.ts +42 -0
  23. package/dist/components/DataPreview.d.ts.map +1 -0
  24. package/dist/components/Drop.vue.d.ts +34 -0
  25. package/dist/components/Drop.vue.d.ts.map +1 -0
  26. package/dist/components/FileUploader.vue.d.ts +60 -0
  27. package/dist/components/FileUploader.vue.d.ts.map +1 -0
  28. package/dist/components/Flag.d.ts +20 -0
  29. package/dist/components/Flag.d.ts.map +1 -0
  30. package/dist/components/FormSchema.vue.d.ts +5 -4
  31. package/dist/components/Image.vue.d.ts.map +1 -1
  32. package/dist/components/LangText.vue.d.ts +2 -2
  33. package/dist/components/ListItem.d.ts +34 -0
  34. package/dist/components/ListItem.d.ts.map +1 -0
  35. package/dist/components/ListView.d.ts +13 -0
  36. package/dist/components/ListView.d.ts.map +1 -0
  37. package/dist/components/MapEmbed.d.ts +3 -0
  38. package/dist/components/MapEmbed.d.ts.map +1 -0
  39. package/dist/components/MaterialIcon.d.ts +26 -0
  40. package/dist/components/MaterialIcon.d.ts.map +1 -0
  41. package/dist/components/Modal.d.ts +46 -0
  42. package/dist/components/Modal.d.ts.map +1 -0
  43. package/dist/components/ModalBglForm.vue.d.ts +21 -20
  44. package/dist/components/ModalConfirm.d.ts +24 -0
  45. package/dist/components/ModalConfirm.d.ts.map +1 -0
  46. package/dist/components/ModalForm.d.ts +78 -0
  47. package/dist/components/ModalForm.d.ts.map +1 -0
  48. package/dist/components/NavBar.d.ts +64 -0
  49. package/dist/components/NavBar.d.ts.map +1 -0
  50. package/dist/components/PageTitle.d.ts +24 -0
  51. package/dist/components/PageTitle.d.ts.map +1 -0
  52. package/dist/components/PersonPreview.vue.d.ts +5 -4
  53. package/dist/components/PersonPreviewFormkit.vue.d.ts +4 -3
  54. package/dist/components/RTXEditor.vue.d.ts +3 -3
  55. package/dist/components/RouterWrapper.d.ts +3 -0
  56. package/dist/components/RouterWrapper.d.ts.map +1 -0
  57. package/dist/components/TabbedLayout.vue.d.ts +5 -4
  58. package/dist/components/TableSchema.d.ts +35 -0
  59. package/dist/components/TableSchema.d.ts.map +1 -0
  60. package/dist/components/TableSchema.vue.d.ts +2 -2
  61. package/dist/components/TableSchema.vue.d.ts.map +1 -1
  62. package/dist/components/Title.d.ts +42 -0
  63. package/dist/components/Title.d.ts.map +1 -0
  64. package/dist/components/TopBar.d.ts +12 -0
  65. package/dist/components/TopBar.d.ts.map +1 -0
  66. package/dist/components/charts/BarChart.vue.d.ts +2 -2
  67. package/dist/components/dashboard/Lineart.d.ts +20 -0
  68. package/dist/components/dashboard/Lineart.d.ts.map +1 -0
  69. package/dist/components/dialog/index.d.ts.map +1 -1
  70. package/dist/components/form/BglField.d.ts +25 -0
  71. package/dist/components/form/BglField.d.ts.map +1 -0
  72. package/dist/components/form/BglForm.d.ts +75 -0
  73. package/dist/components/form/BglForm.d.ts.map +1 -0
  74. package/dist/components/form/ItemRef.vue.d.ts +5 -3
  75. package/dist/components/form/ItemRef.vue.d.ts.map +1 -1
  76. package/dist/components/form/MaterialIcon.vue.d.ts +4 -3
  77. package/dist/components/form/PlainInputField.vue.d.ts +3 -3
  78. package/dist/components/form/inputs/CheckInput.d.ts +56 -0
  79. package/dist/components/form/inputs/CheckInput.d.ts.map +1 -0
  80. package/dist/components/form/inputs/Checkbox.d.ts +16 -0
  81. package/dist/components/form/inputs/Checkbox.d.ts.map +1 -0
  82. package/dist/components/form/inputs/ColorPicker.d.ts +48 -0
  83. package/dist/components/form/inputs/ColorPicker.d.ts.map +1 -0
  84. package/dist/components/form/inputs/CurrencyInput.vue.d.ts +3 -3
  85. package/dist/components/form/inputs/DateInput.d.ts +64 -0
  86. package/dist/components/form/inputs/DateInput.d.ts.map +1 -0
  87. package/dist/components/form/inputs/DatePicker.d.ts +33 -0
  88. package/dist/components/form/inputs/DatePicker.d.ts.map +1 -0
  89. package/dist/components/form/inputs/DatetimeInput.vue.d.ts +3 -3
  90. package/dist/components/form/inputs/DurationInput.vue.d.ts +3 -3
  91. package/dist/components/form/inputs/DynamicLinkField.vue.d.ts +3 -3
  92. package/dist/components/form/inputs/EmailInput.vue.d.ts +3 -3
  93. package/dist/components/form/inputs/FileUpload.d.ts +108 -0
  94. package/dist/components/form/inputs/FileUpload.d.ts.map +1 -0
  95. package/dist/components/form/inputs/FloatInput.vue.d.ts +3 -3
  96. package/dist/components/form/inputs/IntInput.vue.d.ts +3 -3
  97. package/dist/components/form/inputs/JSONInput.d.ts +53 -0
  98. package/dist/components/form/inputs/JSONInput.d.ts.map +1 -0
  99. package/dist/components/form/inputs/LinkField.vue.d.ts +3 -3
  100. package/dist/components/form/inputs/Password.vue.d.ts +3 -3
  101. package/dist/components/form/inputs/PlainText.vue.d.ts +3 -3
  102. package/dist/components/form/inputs/RadioGroup.d.ts +42 -0
  103. package/dist/components/form/inputs/RadioGroup.d.ts.map +1 -0
  104. package/dist/components/form/inputs/RadioPillsInput.d.ts +48 -0
  105. package/dist/components/form/inputs/RadioPillsInput.d.ts.map +1 -0
  106. package/dist/components/form/inputs/ReadOnlyInput.vue.d.ts +2 -2
  107. package/dist/components/form/inputs/RichText.d.ts +20 -0
  108. package/dist/components/form/inputs/RichText.d.ts.map +1 -0
  109. package/dist/components/form/inputs/RichText2/Toolbar.d.ts +22 -0
  110. package/dist/components/form/inputs/RichText2/Toolbar.d.ts.map +1 -0
  111. package/dist/components/form/inputs/RichText2/Toolbar.vue.d.ts.map +1 -1
  112. package/dist/components/form/inputs/RichText2/index.d.ts +24 -0
  113. package/dist/components/form/inputs/RichText2/index.d.ts.map +1 -0
  114. package/dist/components/form/inputs/RichText2/index.vue.d.ts +1 -0
  115. package/dist/components/form/inputs/RichText2/index.vue.d.ts.map +1 -1
  116. package/dist/components/form/inputs/RichTextEditor.vue.d.ts +3 -3
  117. package/dist/components/form/inputs/SelectField.vue.d.ts +6 -8
  118. package/dist/components/form/inputs/SelectField.vue.d.ts.map +1 -1
  119. package/dist/components/form/inputs/SelectInput.d.ts +55 -0
  120. package/dist/components/form/inputs/SelectInput.d.ts.map +1 -0
  121. package/dist/components/form/inputs/SignaturePad.d.ts +72 -0
  122. package/dist/components/form/inputs/SignaturePad.d.ts.map +1 -0
  123. package/dist/components/form/inputs/TableField.d.ts +45 -0
  124. package/dist/components/form/inputs/TableField.d.ts.map +1 -0
  125. package/dist/components/form/inputs/TelInput.d.ts +241 -0
  126. package/dist/components/form/inputs/TelInput.d.ts.map +1 -0
  127. package/dist/components/form/inputs/TextArea.vue.d.ts +3 -3
  128. package/dist/components/form/inputs/TextInput.d.ts +90 -0
  129. package/dist/components/form/inputs/TextInput.d.ts.map +1 -0
  130. package/dist/components/form/inputs/ToggleInput.d.ts +58 -0
  131. package/dist/components/form/inputs/ToggleInput.d.ts.map +1 -0
  132. package/dist/components/form/inputs/Upload/UploadInput.vue.d.ts.map +1 -1
  133. package/dist/components/formkit/AddressArray.vue.d.ts +2 -2
  134. package/dist/components/formkit/BankDetailsArray.vue.d.ts +2 -2
  135. package/dist/components/formkit/ContactArrayFormKit.vue.d.ts +2 -2
  136. package/dist/components/formkit/FileUploader.vue.d.ts +2 -2
  137. package/dist/components/formkit/MiscFields.vue.d.ts +2 -2
  138. package/dist/components/formkit/Toggle.vue.d.ts +2 -2
  139. package/dist/components/layout/BottomMenu.d.ts +27 -0
  140. package/dist/components/layout/BottomMenu.d.ts.map +1 -0
  141. package/dist/components/layout/Layout.d.ts +58 -0
  142. package/dist/components/layout/Layout.d.ts.map +1 -0
  143. package/dist/components/layout/SidebarMenu.d.ts +38 -0
  144. package/dist/components/layout/SidebarMenu.d.ts.map +1 -0
  145. package/dist/components/layout/TabbedLayout.d.ts +42 -0
  146. package/dist/components/layout/TabbedLayout.d.ts.map +1 -0
  147. package/dist/components/layout/Tabs.d.ts +31 -0
  148. package/dist/components/layout/Tabs.d.ts.map +1 -0
  149. package/dist/components/layout/TabsBody.d.ts +23 -0
  150. package/dist/components/layout/TabsBody.d.ts.map +1 -0
  151. package/dist/components/layout/TabsNav.d.ts +35 -0
  152. package/dist/components/layout/TabsNav.d.ts.map +1 -0
  153. package/dist/components/lightbox/Lightbox.vue.d.ts.map +1 -1
  154. package/dist/components/whatsapp/form/MsgTemplate.vue.d.ts +4 -3
  155. package/dist/components/whatsapp/form/TextVariableExamples.vue.d.ts +2 -2
  156. package/dist/index.cjs +24 -23
  157. package/dist/index.mjs +24 -23
  158. package/dist/style.css +53 -53
  159. package/dist/styles.css +14073 -0
  160. package/dist/utils/index.d.ts +1 -0
  161. package/dist/utils/index.d.ts.map +1 -1
  162. package/dist/utils/objects.d.ts +1 -0
  163. package/dist/vue.css +14073 -0
  164. package/package.json +1 -1
  165. package/src/components/Image.vue +3 -8
  166. package/src/components/form/inputs/Upload/UploadInput.vue +7 -9
  167. package/src/components/lightbox/Lightbox.vue +1 -1
  168. package/src/components/lightbox/index.ts +3 -3
  169. package/src/utils/index.ts +10 -0
  170. package/dist/common-C_IH8b5S.cjs +0 -12580
  171. package/dist/common-DoeNgx31.js +0 -12579
  172. package/dist/components/AddressSaerch.vue.d.ts +0 -7
  173. package/dist/components/AddressSaerch.vue.d.ts.map +0 -1
  174. package/dist/components/Calendar/index.d.ts +0 -4
  175. package/dist/components/Calendar/index.d.ts.map +0 -1
  176. package/dist/components/Popover.vue.d.ts +0 -10
  177. package/dist/components/Popover.vue.d.ts.map +0 -1
  178. package/dist/components/form/inputs/RichText/Toolbar.vue.d.ts +0 -14
  179. package/dist/components/form/inputs/RichText/Toolbar.vue.d.ts.map +0 -1
  180. package/dist/components/form/inputs/RichText/formatting.d.ts +0 -11
  181. package/dist/components/form/inputs/RichText/formatting.d.ts.map +0 -1
  182. package/dist/components/form/inputs/RichText/richtext-types.d.ts +0 -3
  183. package/dist/components/form/inputs/RichText/richtext-types.d.ts.map +0 -1
  184. package/dist/components/form/inputs/Upload/UploadFile.vue.d.ts +0 -86
  185. package/dist/components/form/inputs/Upload/UploadFile.vue.d.ts.map +0 -1
  186. package/dist/components/sortable/Animation.d.ts +0 -43
  187. package/dist/components/sortable/Animation.d.ts.map +0 -1
  188. package/dist/components/sortable/BrowserInfo.d.ts +0 -7
  189. package/dist/components/sortable/BrowserInfo.d.ts.map +0 -1
  190. package/dist/components/sortable/EventDispatcher.d.ts +0 -13
  191. package/dist/components/sortable/EventDispatcher.d.ts.map +0 -1
  192. package/dist/components/sortable/PluginManager.d.ts +0 -27
  193. package/dist/components/sortable/PluginManager.d.ts.map +0 -1
  194. package/dist/components/sortable/Sortable.d.ts +0 -81
  195. package/dist/components/sortable/Sortable.d.ts.map +0 -1
  196. package/dist/components/sortable/index.d.ts +0 -5
  197. package/dist/components/sortable/index.d.ts.map +0 -1
  198. package/dist/components/sortable/utils.d.ts +0 -49
  199. package/dist/components/sortable/utils.d.ts.map +0 -1
  200. package/dist/composables/drag-n-drop/useDraggable.d.ts +0 -2
  201. package/dist/composables/drag-n-drop/useDraggable.d.ts.map +0 -1
  202. package/dist/editor-CUDRLdmS.js +0 -4
  203. package/dist/editor-Cu374vEW.cjs +0 -4
  204. package/dist/editor-a8DSbb6P.js +0 -4
  205. package/dist/editor-xBt_vIha.cjs +0 -4
  206. package/dist/heic2any-8wMqMfB_.js +0 -933
  207. package/dist/heic2any-BrqcNzfV.js +0 -935
  208. package/dist/heic2any-C8KwH72N.cjs +0 -934
  209. package/dist/heic2any-k9wDCKka.cjs +0 -932
  210. package/dist/index-DiG-xM9T.cjs +0 -35016
  211. package/dist/index-nGuSAiY2.js +0 -35017
  212. package/dist/plugins/drag-n-drop/draggable.d.ts +0 -4
  213. package/dist/plugins/drag-n-drop/draggable.d.ts.map +0 -1
  214. package/dist/plugins/drag-n-drop/droppable.d.ts +0 -4
  215. package/dist/plugins/drag-n-drop/droppable.d.ts.map +0 -1
  216. package/dist/plugins/drag-n-drop/index.d.ts +0 -5
  217. package/dist/plugins/drag-n-drop/index.d.ts.map +0 -1
  218. package/dist/plugins/drag-n-drop/useDraggable.d.ts +0 -8
  219. package/dist/plugins/drag-n-drop/useDraggable.d.ts.map +0 -1
  220. package/dist/plugins/drag-n-drop/useDroppable.d.ts +0 -7
  221. package/dist/plugins/drag-n-drop/useDroppable.d.ts.map +0 -1
  222. package/dist/types/materialIcon.d.ts +0 -2
  223. package/dist/types/materialIcon.d.ts.map +0 -1
  224. /package/src/components/{Dialog → dialog}/index.ts +0 -0
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@bagelink/vue",
3
3
  "type": "module",
4
- "version": "0.0.1232",
4
+ "version": "0.0.1236",
5
5
  "description": "Bagel core sdk packages",
6
6
  "author": {
7
7
  "name": "Neveh Allon",
@@ -1,6 +1,6 @@
1
1
  <script setup lang="ts">
2
- import { Skeleton, normalizeDimension, appendScript, normalizeURL, Icon } from '@bagelink/vue'
3
- import { watch, computed } from 'vue'
2
+ import { Skeleton, normalizeDimension, appendScript, normalizeURL, Icon, pathKeyToURL } from '@bagelink/vue'
3
+ import { watch } from 'vue'
4
4
 
5
5
  interface ImageProps {
6
6
  src?: string
@@ -22,15 +22,10 @@ const props = defineProps<ImageProps>()
22
22
  let imageSrc = $ref<string | null>(null)
23
23
  let loadingError = $ref(false)
24
24
 
25
- const fileBaseUrl = computed(() => 'https://files.bagel.design')
26
-
27
25
  function getImageUrl(): string | null {
28
26
  if (!props.src && !props.pathKey) return null
29
27
  if (props.src) return props.src
30
- if (props.pathKey?.startsWith('static/')) {
31
- return `${import.meta.env.VITE_BAGEL_BASE_URL}/${props.pathKey}`
32
- }
33
- return `${fileBaseUrl.value}/${props.pathKey}`
28
+ return pathKeyToURL(props.pathKey)
34
29
  }
35
30
 
36
31
  async function getCachedImage(url: string): Promise<string | null> {
@@ -1,6 +1,6 @@
1
1
  <script setup lang="ts">
2
2
  import type { BglFile, QueueFile } from './upload.types'
3
- import { Btn, IMAGE_FORMATS_REGEXP, Icon, useBagel, Card, Image } from '@bagelink/vue'
3
+ import { Btn, IMAGE_FORMATS_REGEXP, Icon, useBagel, Card, Image, pathKeyToURL } from '@bagelink/vue'
4
4
  import { watch } from 'vue'
5
5
  import { files } from './upload'
6
6
 
@@ -33,8 +33,6 @@ const bagel = useBagel()
33
33
 
34
34
  files.setBaseUrl(bagel.host)
35
35
 
36
- const fileBaseUrl = $computed(() => (props.baseURL || bagel.fileBaseUrl || 'https://files.bagel.design').replace(/\/$/, ''))
37
- const pathToUrl = (path_key: string) => `${fileBaseUrl}/${path_key}`
38
36
  const fileQueue = $ref<QueueFile[]>([])
39
37
  let storageFiles = $ref<BglFile[]>([])
40
38
  const pk = $ref<string[]>([props.modelValue].flat().filter(Boolean) as string[])
@@ -184,13 +182,13 @@ watch(() => props.dirPath, () => {
184
182
  icon="download"
185
183
  flat
186
184
  thin
187
- :href="pathToUrl(path_key)"
185
+ :href="pathKeyToURL(path_key)"
188
186
  :download="path_key.split('/').pop()"
189
187
  />
190
188
  <div class="flex gap-025 rounded pe-1 ps-05 py-025 bg-gray-80 -my-1 ">
191
189
  <Icon icon="draft" :size="1.5" />
192
190
  <p
193
- v-lightbox="{ src: pathToUrl(path_key), download: true }"
191
+ v-lightbox="{ src: pathKeyToURL(path_key), download: true }"
194
192
  class="ellipsis-1 word-break-all h-20 m-0 color-black txt16"
195
193
  >
196
194
  {{ path_key.split('/').pop() }}
@@ -227,7 +225,7 @@ watch(() => props.dirPath, () => {
227
225
  <div
228
226
  v-for="path_key in pathKeys"
229
227
  :key="path_key"
230
- v-lightbox="{ src: pathToUrl(path_key), download: true }"
228
+ v-lightbox="{ src: pathKeyToURL(path_key), download: true }"
231
229
  class="multi-image-item-preview"
232
230
  :class="{ 'bgl_fill-image': fill }"
233
231
  >
@@ -308,13 +306,13 @@ watch(() => props.dirPath, () => {
308
306
  color="gray"
309
307
  thin
310
308
  icon="download"
311
- :href="pathToUrl(path_key)"
309
+ :href="pathKeyToURL(path_key)"
312
310
  :download="path_key.split('/').pop()"
313
311
  />
314
312
  </div>
315
313
  <div v-if="isImage(path_key)" class="h-100">
316
314
  <Image
317
- v-lightbox="{ src: pathToUrl(path_key), download: true }"
315
+ v-lightbox="{ src: pathKeyToURL(path_key), download: true }"
318
316
 
319
317
  class="single-preview"
320
318
  :pathKey="path_key"
@@ -323,7 +321,7 @@ watch(() => props.dirPath, () => {
323
321
  </div>
324
322
  <Icon
325
323
  v-else
326
- v-lightbox="{ src: pathToUrl(path_key), download: true }"
324
+ v-lightbox="{ src: pathKeyToURL(path_key), download: true }"
327
325
  :size="4"
328
326
  weight="2"
329
327
  icon="description"
@@ -117,7 +117,7 @@ defineExpose({ open, close })
117
117
  <Carousel v-model:index="currentIndex" :items="1" class="bgl-lightbox-item" :class="{ zoomed: zoom > 1 }" :freeDrag="zoom === 1">
118
118
  <template v-for="item in group" :key="item.src">
119
119
  <Zoomer v-if="item.type === 'image'" v-model:zoom="zoom" :disabled="!item?.enableZoom" :mouse-wheel-to-zoom="false">
120
- <Image :draggable="false" :src="item?.src" :pathKey="item?.pathKey" alt="Preview" class="vw90 lightbox-image" />
120
+ <Image :draggable="false" :src="item?.src" alt="Preview" class="vw90 lightbox-image" />
121
121
  </Zoomer>
122
122
 
123
123
  <BglVideo
@@ -1,6 +1,6 @@
1
1
  import type { App, Directive, DirectiveBinding } from 'vue'
2
2
  import type { LightboxItem } from './lightbox.types'
3
- import { IMAGE_FORMATS_REGEXP, VIDEO_FORMATS_REGEXP } from '@bagelink/vue'
3
+ import { IMAGE_FORMATS_REGEXP, pathKeyToURL, VIDEO_FORMATS_REGEXP } from '@bagelink/vue'
4
4
  import { createApp } from 'vue'
5
5
  import Lightbox from './Lightbox.vue'
6
6
 
@@ -48,8 +48,8 @@ function openClickHandler(e: MouseEvent, el: HTMLElement, binding: DirectiveBind
48
48
  }
49
49
 
50
50
  function bindingToItem(binding: DirectiveBinding, el: HTMLElement): LightboxItem {
51
- let { group, src, type, name, thumbnail, enableZoom, openFile, download } = binding.value || {}
52
- src = src || binding.value || el.getAttribute('src') || ''
51
+ let { group, src, type, name, thumbnail, enableZoom, openFile, download, pathKey } = binding.value || {}
52
+ src = src || pathKeyToURL(pathKey) || binding.value || el.getAttribute('src') || ''
53
53
  type = type || determineFileType(src)
54
54
  name = name || urlToName(src) || el.getAttribute('alt') || ''
55
55
  return { src, type, name, thumbnail, group, enableZoom, openFile, download }
@@ -168,3 +168,13 @@ export { useLang } from './lang'
168
168
 
169
169
  export { formatString } from './strings'
170
170
  export { useDebounceFn } from '@vueuse/core'
171
+
172
+ const fileBaseUrl = (import.meta.env.VITE_FILE_BASE_URL || 'https://files.bagel.design').replace(/\/$/, '')
173
+ const bagelBaseUrl = import.meta.env.VITE_BAGEL_BASE_URL
174
+
175
+ export function pathKeyToURL(pathKey?: string) {
176
+ if (pathKey?.startsWith('static/')) {
177
+ return `${bagelBaseUrl}/${pathKey}`
178
+ }
179
+ return `${fileBaseUrl}/${pathKey}`
180
+ }