@updevs/components 1.0.0-alpha.1 → 1.0.0-alpha.100

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 (198) hide show
  1. package/README.md +1 -24
  2. package/assets/styles/_bootstrap-components.scss +55 -0
  3. package/assets/styles/_bootstrap-config.scss +7 -0
  4. package/assets/styles/_bootstrap-override.scss +78 -0
  5. package/assets/styles/_config.scss +9 -0
  6. package/assets/styles/_core.scss +80 -0
  7. package/assets/styles/_debug.scss +49 -0
  8. package/assets/styles/_mixins.scss +2 -0
  9. package/assets/styles/_props.scss +91 -0
  10. package/assets/styles/_seven-columns.scss +73 -0
  11. package/assets/styles/_updevs.scss +25 -0
  12. package/assets/styles/_utilities-marketing.scss +209 -0
  13. package/assets/styles/_utilities.scss +133 -0
  14. package/assets/styles/_variables-dark.scss +19 -0
  15. package/assets/styles/_variables.scss +1003 -0
  16. package/assets/styles/fonts/_webfonts.scss +15 -0
  17. package/assets/styles/helpers/_index.scss +143 -0
  18. package/assets/styles/layout/_animations.scss +62 -0
  19. package/assets/styles/layout/_core.scss +62 -0
  20. package/assets/styles/layout/_dark.scss +77 -0
  21. package/assets/styles/layout/_footer.scss +12 -0
  22. package/assets/styles/layout/_navbar.scss +392 -0
  23. package/assets/styles/layout/_page.scss +170 -0
  24. package/assets/styles/layout/_root.scss +64 -0
  25. package/assets/styles/marketing/_browser.scss +67 -0
  26. package/assets/styles/marketing/_core.scss +8 -0
  27. package/assets/styles/marketing/_filters.scss +0 -0
  28. package/assets/styles/marketing/_hero.scss +70 -0
  29. package/assets/styles/marketing/_pricing.scss +111 -0
  30. package/assets/styles/marketing/_sections.scss +124 -0
  31. package/assets/styles/marketing/_shape.scss +31 -0
  32. package/assets/styles/mixins/_functions.scss +96 -0
  33. package/assets/styles/mixins/_mixins.scss +68 -0
  34. package/assets/styles/ui/_accordion.scss +178 -0
  35. package/assets/styles/ui/_alerts.scss +101 -0
  36. package/assets/styles/ui/_avatars.scss +145 -0
  37. package/assets/styles/ui/_badges.scss +113 -0
  38. package/assets/styles/ui/_breadcrumbs.scss +50 -0
  39. package/assets/styles/ui/_button-group.scss +16 -0
  40. package/assets/styles/ui/_buttons.scss +261 -0
  41. package/assets/styles/ui/_calendars.scss +104 -0
  42. package/assets/styles/ui/_cards.scss +595 -0
  43. package/assets/styles/ui/_carousel.scss +68 -0
  44. package/assets/styles/ui/_charts.scss +61 -0
  45. package/assets/styles/ui/_chat.scss +38 -0
  46. package/assets/styles/ui/_chips.scss +0 -0
  47. package/assets/styles/ui/_close.scss +60 -0
  48. package/assets/styles/ui/_datagrid.scss +17 -0
  49. package/assets/styles/ui/_dropdowns.scss +120 -0
  50. package/assets/styles/ui/_empty.scss +60 -0
  51. package/assets/styles/ui/_flags.scss +31 -0
  52. package/assets/styles/ui/_forms.scss +250 -0
  53. package/assets/styles/ui/_grid.scss +115 -0
  54. package/assets/styles/ui/_icons.scss +72 -0
  55. package/assets/styles/ui/_images.scss +19 -0
  56. package/assets/styles/ui/_legend.scss +12 -0
  57. package/assets/styles/ui/_lists.scss +123 -0
  58. package/assets/styles/ui/_loaders.scss +72 -0
  59. package/assets/styles/ui/_login.scss +3 -0
  60. package/assets/styles/ui/_markdown.scss +53 -0
  61. package/assets/styles/ui/_modals.scss +67 -0
  62. package/assets/styles/ui/_nav.scss +106 -0
  63. package/assets/styles/ui/_offcanvas.scss +17 -0
  64. package/assets/styles/ui/_pagination.scss +58 -0
  65. package/assets/styles/ui/_payments.scss +28 -0
  66. package/assets/styles/ui/_placeholder.scss +9 -0
  67. package/assets/styles/ui/_popovers.scss +2 -0
  68. package/assets/styles/ui/_progress.scss +107 -0
  69. package/assets/styles/ui/_ribbons.scss +157 -0
  70. package/assets/styles/ui/_segmented.scss +101 -0
  71. package/assets/styles/ui/_signature.scss +15 -0
  72. package/assets/styles/ui/_social.scss +52 -0
  73. package/assets/styles/ui/_stars.scss +13 -0
  74. package/assets/styles/ui/_status.scss +163 -0
  75. package/assets/styles/ui/_steps.scss +156 -0
  76. package/assets/styles/ui/_switch-icon.scss +211 -0
  77. package/assets/styles/ui/_tables.scss +176 -0
  78. package/assets/styles/ui/_tags.scss +57 -0
  79. package/assets/styles/ui/_timeline.scss +61 -0
  80. package/assets/styles/ui/_toasts.scss +18 -0
  81. package/assets/styles/ui/_toolbar.scss +10 -0
  82. package/assets/styles/ui/_tracking.scss +29 -0
  83. package/assets/styles/ui/_type.scss +330 -0
  84. package/assets/styles/ui/forms/_form-check.scss +91 -0
  85. package/assets/styles/ui/forms/_form-colorinput.scss +54 -0
  86. package/assets/styles/ui/forms/_form-custom.scss +28 -0
  87. package/assets/styles/ui/forms/_form-icon.scss +35 -0
  88. package/assets/styles/ui/forms/_form-imagecheck.scss +105 -0
  89. package/assets/styles/ui/forms/_form-selectgroup.scss +153 -0
  90. package/assets/styles/ui/forms/_validation.scss +13 -0
  91. package/assets/styles/ui/typo/_hr.scss +76 -0
  92. package/assets/styles/utils/_background.scss +15 -0
  93. package/assets/styles/utils/_colors.scss +101 -0
  94. package/assets/styles/utils/_opacity.scss +7 -0
  95. package/assets/styles/utils/_scroll.scss +45 -0
  96. package/assets/styles/utils/_shadow.scss +17 -0
  97. package/assets/styles/utils/_sizing.scss +10 -0
  98. package/assets/styles/utils/_text.scss +14 -0
  99. package/assets/styles/vendor/_apexcharts.scss +52 -0
  100. package/assets/styles/vendor/_coloris.scss +72 -0
  101. package/assets/styles/vendor/_dropzone.scss +27 -0
  102. package/assets/styles/vendor/_fslightbox.scss +13 -0
  103. package/assets/styles/vendor/_jsvectormap.scss +47 -0
  104. package/assets/styles/vendor/_litepicker.scss +69 -0
  105. package/assets/styles/vendor/_nouislider.scss +49 -0
  106. package/assets/styles/vendor/_plyr.scss +3 -0
  107. package/assets/styles/vendor/_stars-rating.scss +22 -0
  108. package/assets/styles/vendor/_tom-select.scss +81 -0
  109. package/assets/styles/vendor/_turbo.scss +3 -0
  110. package/assets/styles/vendor/_typed.scss +4 -0
  111. package/assets/styles/vendor/_wysiwyg.scss +46 -0
  112. package/fesm2022/updevs-components-badge.mjs +89 -0
  113. package/fesm2022/updevs-components-badge.mjs.map +1 -0
  114. package/fesm2022/updevs-components-button.mjs +193 -0
  115. package/fesm2022/updevs-components-button.mjs.map +1 -0
  116. package/fesm2022/updevs-components-calendar.mjs +582 -0
  117. package/fesm2022/updevs-components-calendar.mjs.map +1 -0
  118. package/fesm2022/updevs-components-card.mjs +242 -0
  119. package/fesm2022/updevs-components-card.mjs.map +1 -0
  120. package/fesm2022/updevs-components-drag-and-drop.mjs +185 -0
  121. package/fesm2022/updevs-components-drag-and-drop.mjs.map +1 -0
  122. package/fesm2022/updevs-components-dropdown.mjs +247 -0
  123. package/fesm2022/updevs-components-dropdown.mjs.map +1 -0
  124. package/fesm2022/updevs-components-form-controls-abstractions.mjs +106 -0
  125. package/fesm2022/updevs-components-form-controls-abstractions.mjs.map +1 -0
  126. package/fesm2022/updevs-components-form-controls-checkbox.mjs +99 -0
  127. package/fesm2022/updevs-components-form-controls-checkbox.mjs.map +1 -0
  128. package/fesm2022/updevs-components-form-controls-date-picker.mjs +175 -0
  129. package/fesm2022/updevs-components-form-controls-date-picker.mjs.map +1 -0
  130. package/fesm2022/updevs-components-form-controls-file-upload.mjs +272 -0
  131. package/fesm2022/updevs-components-form-controls-file-upload.mjs.map +1 -0
  132. package/fesm2022/updevs-components-form-controls-input.mjs +281 -0
  133. package/fesm2022/updevs-components-form-controls-input.mjs.map +1 -0
  134. package/fesm2022/updevs-components-form-controls-radio.mjs +98 -0
  135. package/fesm2022/updevs-components-form-controls-radio.mjs.map +1 -0
  136. package/fesm2022/updevs-components-form-controls-select.mjs +600 -0
  137. package/fesm2022/updevs-components-form-controls-select.mjs.map +1 -0
  138. package/fesm2022/updevs-components-form-controls-textarea.mjs +79 -0
  139. package/fesm2022/updevs-components-form-controls-textarea.mjs.map +1 -0
  140. package/fesm2022/updevs-components-form-controls-time-picker.mjs +345 -0
  141. package/fesm2022/updevs-components-form-controls-time-picker.mjs.map +1 -0
  142. package/fesm2022/updevs-components-form.mjs +562 -0
  143. package/fesm2022/updevs-components-form.mjs.map +1 -0
  144. package/fesm2022/updevs-components-layout.mjs +1054 -0
  145. package/fesm2022/updevs-components-layout.mjs.map +1 -0
  146. package/fesm2022/updevs-components-link.mjs +79 -0
  147. package/fesm2022/updevs-components-link.mjs.map +1 -0
  148. package/fesm2022/updevs-components-list.mjs +215 -0
  149. package/fesm2022/updevs-components-list.mjs.map +1 -0
  150. package/fesm2022/updevs-components-modal.mjs +505 -0
  151. package/fesm2022/updevs-components-modal.mjs.map +1 -0
  152. package/fesm2022/updevs-components-paginator.mjs +160 -0
  153. package/fesm2022/updevs-components-paginator.mjs.map +1 -0
  154. package/fesm2022/updevs-components-popover.mjs +215 -0
  155. package/fesm2022/updevs-components-popover.mjs.map +1 -0
  156. package/fesm2022/updevs-components-pricing.mjs +130 -0
  157. package/fesm2022/updevs-components-pricing.mjs.map +1 -0
  158. package/fesm2022/updevs-components-table.mjs +2060 -0
  159. package/fesm2022/updevs-components-table.mjs.map +1 -0
  160. package/fesm2022/updevs-components.mjs +33 -0
  161. package/fesm2022/updevs-components.mjs.map +1 -0
  162. package/package.json +127 -14
  163. package/types/updevs-components-badge.d.ts +44 -0
  164. package/types/updevs-components-button.d.ts +75 -0
  165. package/types/updevs-components-calendar.d.ts +175 -0
  166. package/types/updevs-components-card.d.ts +92 -0
  167. package/types/updevs-components-drag-and-drop.d.ts +74 -0
  168. package/types/updevs-components-dropdown.d.ts +124 -0
  169. package/types/updevs-components-form-controls-abstractions.d.ts +49 -0
  170. package/types/updevs-components-form-controls-checkbox.d.ts +33 -0
  171. package/types/updevs-components-form-controls-date-picker.d.ts +80 -0
  172. package/types/updevs-components-form-controls-file-upload.d.ts +69 -0
  173. package/types/updevs-components-form-controls-input.d.ts +95 -0
  174. package/types/updevs-components-form-controls-radio.d.ts +32 -0
  175. package/types/updevs-components-form-controls-select.d.ts +200 -0
  176. package/types/updevs-components-form-controls-textarea.d.ts +31 -0
  177. package/types/updevs-components-form-controls-time-picker.d.ts +164 -0
  178. package/types/updevs-components-form.d.ts +356 -0
  179. package/types/updevs-components-layout.d.ts +490 -0
  180. package/types/updevs-components-link.d.ts +34 -0
  181. package/types/updevs-components-list.d.ts +107 -0
  182. package/types/updevs-components-modal.d.ts +155 -0
  183. package/types/updevs-components-paginator.d.ts +58 -0
  184. package/types/updevs-components-popover.d.ts +63 -0
  185. package/types/updevs-components-pricing.d.ts +91 -0
  186. package/types/updevs-components-table.d.ts +619 -0
  187. package/types/updevs-components.d.ts +44 -0
  188. package/CHANGELOG.md +0 -8
  189. package/ng-package.json +0 -7
  190. package/src/lib/components.component.spec.ts +0 -23
  191. package/src/lib/components.component.ts +0 -14
  192. package/src/lib/components.module.ts +0 -17
  193. package/src/lib/components.service.spec.ts +0 -16
  194. package/src/lib/components.service.ts +0 -9
  195. package/src/public-api.ts +0 -7
  196. package/tsconfig.lib.json +0 -14
  197. package/tsconfig.lib.prod.json +0 -10
  198. package/tsconfig.spec.json +0 -14
@@ -0,0 +1 @@
1
+ {"version":3,"file":"updevs-components-calendar.mjs","sources":["../../../../libs/components/calendar/src/models/date-range.model.ts","../../../../libs/components/calendar/src/models/enums/calendar-view.enum.ts","../../../../libs/components/calendar/src/services/calendar-range-strategy.service.ts","../../../../libs/components/calendar/src/calendar.component.ts","../../../../libs/components/calendar/src/calendar.component.html","../../../../libs/components/calendar/src/services/calendar-signals.service.ts","../../../../libs/components/calendar/src/upd-calendar.module.ts","../../../../libs/components/calendar/src/updevs-components-calendar.ts"],"sourcesContent":["/**\n * A class representing a range of dates.\n */\nexport class DateRangeModel {\n constructor(\n /**\n * The start date of the range.\n */\n readonly start?: Date,\n /**\n * The end date of the range.\n */\n readonly end?: Date\n ) {\n }\n}\n","export enum CalendarViewEnum {\n Days = 'days',\n Months = 'months',\n Years = 'years'\n}\n","import { Injectable, inject } from '@angular/core';\nimport { DateService } from '@updevs/sdk/core';\nimport { OptionalType } from '@updevs/sdk/types';\n\nimport { DateRangeModel } from '../models/date-range.model';\n\n/**\n * Provides the default date range selection behavior.\n */\n@Injectable()\nexport class CalendarRangeStrategyService {\n private readonly dateService = inject(DateService);\n\n /**\n * Called when the user has finished selecting a value.\n * @param date Date that was selected. Will be null if the user cleared the selection.\n * @param currentRange Range that is currently show in the calendar.\n */\n selectionFinished(date: OptionalType<Date>, currentRange: DateRangeModel): DateRangeModel {\n let { start, end } = currentRange;\n\n if (start === undefined) {\n start = date;\n } else if (end === undefined && date && this.dateService.compare(date, start) >= 0) {\n end = date;\n } else {\n start = date;\n end = undefined;\n }\n\n return new DateRangeModel(start, end);\n }\n\n /**\n * Called when the user has activated a new date (e.g. by hovering over\n * it or moving focus) and the calendar tries to display a date range.\n *\n * @param activeDate Date that the user has activated. Will be null if the user moved\n * focus to an element that's no a calendar cell.\n * @param currentRange Range that is currently shown in the calendar.\n */\n createPreview(activeDate: OptionalType<Date>, currentRange: DateRangeModel): DateRangeModel {\n let start: OptionalType<Date>;\n let end: OptionalType<Date>;\n\n if (!!currentRange.start && !currentRange.end && !!activeDate) {\n start = currentRange.start;\n end = activeDate;\n }\n\n return new DateRangeModel(start, end);\n }\n\n /**\n * Called when the user has dragged a date in the currently selected range to another\n * date. Returns the date updated range that should result from this interaction.\n *\n * @param dragOrigin The date the user started dragging from.\n * @param originalRange The originally selected date range.\n * @param newDate The currently targeted date in the drag operation.\n */\n createDrag(dragOrigin: Date, originalRange: DateRangeModel, newDate: Date): OptionalType<DateRangeModel> {\n let start = originalRange.start;\n let end = originalRange.end;\n\n if (!start || !end) {\n // Can't drag from an incomplete range.\n return undefined;\n }\n\n const isRange = this.dateService.compare(start, end) !== 0;\n const diffYears = newDate.getFullYear() - dragOrigin.getFullYear();\n const diffMonths = newDate.getMonth() - dragOrigin.getMonth();\n const diffDays = newDate.getDate() - dragOrigin.getDate();\n\n if (isRange && this.dateService.areEqual(dragOrigin, originalRange.start)) {\n start = newDate;\n\n if (this.dateService.compare(newDate, end) > 0) {\n end = this.dateService.addYears(end, diffYears);\n end = this.dateService.addMonths(end, diffMonths);\n end = this.dateService.addDays(end, diffDays);\n }\n } else if (isRange && this.dateService.areEqual(dragOrigin, originalRange.end)) {\n end = newDate;\n\n if (this.dateService.compare(newDate, start) < 0) {\n start = this.dateService.addYears(start, diffYears);\n start = this.dateService.addMonths(start, diffMonths);\n start = this.dateService.addDays(start, diffDays);\n }\n } else {\n start = this.dateService.addYears(start, diffYears);\n start = this.dateService.addMonths(start, diffMonths);\n start = this.dateService.addDays(start, diffDays);\n end = this.dateService.addYears(end, diffYears);\n end = this.dateService.addMonths(end, diffMonths);\n end = this.dateService.addDays(end, diffDays);\n }\n\n return new DateRangeModel(start, end);\n }\n}\n","import { Component, OnInit, inject, signal, computed, input, output } from '@angular/core';\nimport { DateService } from '@updevs/sdk/core';\nimport { OptionalType } from '@updevs/sdk/types';\n\nimport { CalendarViewEnum } from './models/enums/calendar-view.enum';\nimport { CalendarDateModel } from './models/calendar-date.model';\nimport { CalendarMonthModel } from './models/calendar-month.model';\nimport { CalendarYearModel } from './models/calendar-year.model';\nimport { CalendarSelectedModel } from './models/calendar-selected.model';\n\n@Component({\n standalone: false,\n selector: 'upd-calendar',\n templateUrl: './calendar.component.html',\n styleUrls: ['./calendar.component.scss']\n})\nexport class CalendarComponent implements OnInit {\n readonly selectedDate = input<OptionalType<Date>>();\n readonly selectedStartDate = input<OptionalType<Date>>();\n readonly selectedEndDate = input<OptionalType<Date>>();\n readonly minDate = input<OptionalType<Date>>();\n readonly maxDate = input<OptionalType<Date>>();\n readonly disabledDatesFilter = input<OptionalType<(date: Date) => boolean>>();\n readonly isRange = input<boolean>(false);\n readonly shouldRemoveExternalBorder = input<boolean>(false);\n\n readonly selected = output<OptionalType<CalendarSelectedModel>>();\n readonly monthChanged = output<Date>();\n\n CalendarViewEnum = CalendarViewEnum;\n\n readonly currentView = signal<CalendarViewEnum>(CalendarViewEnum.Days);\n readonly currentDate = signal<Date>(new Date());\n readonly yearRange = signal<{ start: number; end: number }>({ start: 2020, end: 2030 });\n readonly currentYear = computed(() => this.currentDate().getFullYear());\n readonly currentMonth = computed(() => this.currentDate().getMonth());\n readonly currentMonthName = computed(() =>\n this.dateService.format(this.currentDate(), { month: 'short', year: 'numeric' }).toUpperCase()\n );\n readonly calendarDays = computed(() => this.generateCalendarDays());\n readonly calendarMonths = computed(() => this.generateCalendarMonths());\n readonly calendarYears = computed(() => this.generateCalendarYears());\n readonly weekDayNames = computed(() => this.dateService.getDayOfWeekNames('narrow'));\n\n private readonly internalSelectedDate = signal<OptionalType<Date>>(undefined);\n private readonly internalSelectedStartDate = signal<OptionalType<Date>>(undefined);\n private readonly internalSelectedEndDate = signal<OptionalType<Date>>(undefined);\n private readonly dateService = inject(DateService);\n private rangeSelectionState: 'start' | 'end' = 'start';\n\n ngOnInit(): void {\n this.syncInternalState();\n\n if (this.selectedDate()) {\n this.currentDate.set(new Date(this.selectedDate()!));\n } else if (this.selectedStartDate()) {\n this.currentDate.set(new Date(this.selectedStartDate()!));\n }\n\n this.updateYearRange();\n }\n\n onHeaderClick(): void {\n switch (this.currentView()) {\n case CalendarViewEnum.Days:\n this.currentView.set(CalendarViewEnum.Months);\n break;\n case CalendarViewEnum.Months:\n this.currentView.set(CalendarViewEnum.Years);\n break;\n }\n }\n\n onPreviousClick(): void {\n const current = this.currentDate();\n\n switch (this.currentView()) {\n case CalendarViewEnum.Days:\n this.currentDate.set(this.dateService.addMonths(current, -1));\n this.monthChanged.emit(this.currentDate());\n break;\n case CalendarViewEnum.Months:\n this.currentDate.set(this.dateService.addYears(current, -1));\n break;\n case CalendarViewEnum.Years:\n this.moveYearRange(-12);\n break;\n }\n }\n\n onNextClick(): void {\n const current = this.currentDate();\n\n switch (this.currentView()) {\n case CalendarViewEnum.Days:\n this.currentDate.set(this.dateService.addMonths(current, 1));\n this.monthChanged.emit(this.currentDate());\n break;\n case CalendarViewEnum.Months:\n this.currentDate.set(this.dateService.addYears(current, 1));\n break;\n case CalendarViewEnum.Years:\n this.moveYearRange(12);\n break;\n }\n }\n\n onDateClick(dateModel: CalendarDateModel): void {\n if (!dateModel.isCurrentMonth) {\n return;\n }\n\n if (dateModel.isDisabled) {\n return;\n }\n\n if (this.isRange()) {\n this.handleRangeSelection(dateModel.date);\n } else {\n this.internalSelectedDate.set(dateModel.date);\n this.selected.emit({ selectedDate: dateModel.date });\n }\n }\n\n onMonthClick(monthModel: CalendarMonthModel): void {\n if (monthModel.isDisabled) {\n return;\n }\n\n const newDate = new Date(this.currentYear(), monthModel.monthIndex, 1);\n\n this.currentDate.set(newDate);\n this.currentView.set(CalendarViewEnum.Days);\n this.monthChanged.emit(newDate);\n }\n\n onYearClick(yearModel: CalendarYearModel): void {\n if (yearModel.isDisabled) {\n return;\n }\n\n const newDate = new Date(yearModel.year, this.currentMonth(), 1);\n\n this.currentDate.set(newDate);\n this.currentView.set(CalendarViewEnum.Months);\n }\n\n clearSelection(): void {\n this.internalSelectedDate.set(undefined);\n this.internalSelectedStartDate.set(undefined);\n this.internalSelectedEndDate.set(undefined);\n\n this.rangeSelectionState = 'start';\n\n this.selected.emit(undefined);\n }\n\n private syncInternalState(): void {\n this.internalSelectedDate.set(this.selectedDate());\n this.internalSelectedStartDate.set(this.selectedStartDate());\n this.internalSelectedEndDate.set(this.selectedEndDate());\n }\n\n private handleRangeSelection(selectedDate: Date): void {\n if (this.rangeSelectionState === 'start' || !this.internalSelectedStartDate()) {\n this.internalSelectedStartDate.set(selectedDate);\n this.internalSelectedEndDate.set(undefined);\n this.rangeSelectionState = 'end';\n\n this.selected.emit({ startDate: selectedDate });\n } else {\n const startDate = this.internalSelectedStartDate()!;\n const endDate = selectedDate;\n\n if (this.dateService.compare(selectedDate, startDate) < 0) {\n this.internalSelectedStartDate.set(selectedDate);\n this.internalSelectedEndDate.set(startDate);\n this.selected.emit({\n startDate: selectedDate,\n endDate: startDate\n });\n } else {\n this.internalSelectedEndDate.set(endDate);\n this.selected.emit({\n startDate: startDate,\n endDate: endDate\n });\n }\n\n this.rangeSelectionState = 'start';\n }\n }\n\n private generateCalendarDays(): CalendarDateModel[] {\n const current = this.currentDate();\n const year = current.getFullYear();\n const month = current.getMonth();\n const firstDayOfMonth = new Date(year, month, 1);\n const lastDayOfMonth = new Date(year, month + 1, 0);\n const firstDayOfWeek = firstDayOfMonth.getDay();\n const days: CalendarDateModel[] = [];\n const today = new Date();\n\n if (firstDayOfWeek > 0) {\n const prevMonthLastDay = new Date(year, month, 0);\n const startDate = prevMonthLastDay.getDate() - firstDayOfWeek + 1;\n\n for (let day = startDate; day <= prevMonthLastDay.getDate(); day++) {\n const date = new Date(year, month - 1, day);\n days.push({\n date,\n isCurrentMonth: false,\n isToday: this.dateService.areEqual(date, today),\n isSelected: false,\n isDisabled: true,\n isInRange: false,\n isRangeStart: false,\n isRangeEnd: false\n });\n }\n }\n\n for (let day = 1; day <= lastDayOfMonth.getDate(); day++) {\n const date = new Date(year, month, day);\n days.push({\n date,\n isCurrentMonth: true,\n isToday: this.dateService.areEqual(date, today),\n isSelected: this.isDateSelected(date),\n isDisabled: this.isDateDisabled(date),\n isInRange: this.isDateInRange(date),\n isRangeStart: this.isDateRangeStart(date),\n isRangeEnd: this.isDateRangeEnd(date)\n });\n }\n\n const totalCells = Math.ceil(days.length / 7) * 7;\n const nextMonthDays = totalCells - days.length;\n\n for (let day = 1; day <= nextMonthDays; day++) {\n const date = new Date(year, month + 1, day);\n days.push({\n date,\n isCurrentMonth: false,\n isToday: this.dateService.areEqual(date, today),\n isSelected: false,\n isDisabled: true,\n isInRange: false,\n isRangeStart: false,\n isRangeEnd: false\n });\n }\n\n return days;\n }\n\n private generateCalendarMonths(): CalendarMonthModel[] {\n const currentYear = this.currentYear();\n const currentMonth = this.currentMonth();\n const today = new Date();\n const monthNames = this.dateService.getMonthNames('short');\n\n return monthNames.map((name, index) => ({\n monthIndex: index,\n name: name.toUpperCase(),\n isCurrentMonth: today.getFullYear() === currentYear && today.getMonth() === index,\n isSelected: currentMonth === index,\n isDisabled: this.isMonthDisabled(currentYear, index)\n }));\n }\n\n private generateCalendarYears(): CalendarYearModel[] {\n const range = this.yearRange();\n const currentYear = this.currentYear();\n const today = new Date();\n const years: CalendarYearModel[] = [];\n\n for (let year = range.start; year <= range.end; year++) {\n years.push({\n year,\n isCurrentYear: today.getFullYear() === year,\n isSelected: currentYear === year,\n isDisabled: this.isYearDisabled(year)\n });\n }\n\n return years;\n }\n\n private isDateSelected(date: Date): boolean {\n if (this.isRange()) {\n if (this.internalSelectedStartDate() && this.dateService.areEqual(date, this.internalSelectedStartDate()!)) {\n return true;\n }\n\n return !!(this.internalSelectedEndDate() && this.dateService.areEqual(date, this.internalSelectedEndDate()!));\n } else {\n return this.internalSelectedDate() ? this.dateService.areEqual(date, this.internalSelectedDate()!) : false;\n }\n }\n\n private isDateInRange(date: Date): boolean {\n if (!this.isRange() || !this.internalSelectedStartDate() || !this.internalSelectedEndDate()) {\n return false;\n }\n\n return this.dateService.compare(date, this.internalSelectedStartDate()!) > 0\n && this.dateService.compare(date, this.internalSelectedEndDate()!) < 0;\n }\n\n private isDateRangeStart(date: Date): boolean {\n return this.isRange() && this.internalSelectedStartDate()\n ? this.dateService.areEqual(date, this.internalSelectedStartDate()!)\n : false;\n }\n\n private isDateRangeEnd(date: Date): boolean {\n return this.isRange() && this.internalSelectedEndDate()\n ? this.dateService.areEqual(date, this.internalSelectedEndDate()!)\n : false;\n }\n\n private isDateDisabled(date: Date): boolean {\n if (this.minDate() && this.dateService.compare(date, this.minDate()!) < 0) {\n return true;\n }\n\n if (this.maxDate() && this.dateService.compare(date, this.maxDate()!) > 0) {\n return true;\n }\n\n const filterFn = this.disabledDatesFilter();\n\n if (!!filterFn) {\n return !filterFn(date);\n }\n\n return false;\n }\n\n private isMonthDisabled(year: number, month: number): boolean {\n const firstDayOfMonth = new Date(year, month, 1);\n const lastDayOfMonth = new Date(year, month + 1, 0);\n\n if (this.minDate() && this.dateService.compare(lastDayOfMonth, this.minDate()!) < 0) {\n return true;\n }\n\n return !!(this.maxDate() && this.dateService.compare(firstDayOfMonth, this.maxDate()!) > 0);\n }\n\n private isYearDisabled(year: number): boolean {\n const firstDayOfYear = new Date(year, 0, 1);\n const lastDayOfYear = new Date(year, 11, 31);\n\n if (this.minDate() && this.dateService.compare(lastDayOfYear, this.minDate()!) < 0) {\n return true;\n }\n\n return !!(this.maxDate() && this.dateService.compare(firstDayOfYear, this.maxDate()!) > 0);\n }\n\n private updateYearRange(): void {\n const currentYear = this.currentYear();\n this.yearRange.set({\n start: currentYear - 6,\n end: currentYear + 5\n });\n }\n\n private moveYearRange(offset: number): void {\n const current = this.yearRange();\n this.yearRange.set({\n start: current.start + offset,\n end: current.end + offset\n });\n }\n}\n","<div class=\"calendar\" [class.calendar-border]=\"!shouldRemoveExternalBorder()\">\n <div class=\"calendar-header\">\n <button type=\"button\" class=\"btn btn-sm btn-ghost-secondary\" (click)=\"onPreviousClick()\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" class=\"icon\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" stroke-width=\"2\"\n stroke=\"currentColor\" fill=\"none\">\n <path stroke=\"none\" d=\"m0 0h24v24H0z\" fill=\"none\" />\n <path d=\"m15 6-6 6 6 6\" />\n </svg>\n </button>\n\n <button type=\"button\" class=\"btn btn-sm btn-ghost-secondary calendar-title\" (click)=\"onHeaderClick()\">\n @switch (currentView()) {\n @case (CalendarViewEnum.Days) {\n {{ currentMonthName() }}\n }\n @case (CalendarViewEnum.Months) {\n {{ currentYear() }}\n }\n @case (CalendarViewEnum.Years) {\n {{ yearRange().start }} - {{ yearRange().end }}\n }\n }\n <svg xmlns=\"http://www.w3.org/2000/svg\" class=\"icon ms-1\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" stroke-width=\"2\"\n stroke=\"currentColor\" fill=\"none\">\n <path stroke=\"none\" d=\"m0 0h24v24H0z\" fill=\"none\" />\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n </button>\n\n <button type=\"button\" class=\"btn btn-sm btn-ghost-secondary\" (click)=\"onNextClick()\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" class=\"icon\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" stroke-width=\"2\"\n stroke=\"currentColor\" fill=\"none\">\n <path stroke=\"none\" d=\"m0 0h24v24H0z\" fill=\"none\" />\n <path d=\"m9 6 6 6-6 6\" />\n </svg>\n </button>\n </div>\n\n @if (currentView() === CalendarViewEnum.Days) {\n <div class=\"calendar-weekdays\">\n @for (dayName of weekDayNames(); track dayName) {\n <div class=\"calendar-weekday\">{{ dayName }}</div>\n }\n </div>\n\n <div class=\"calendar-days\">\n @for (day of calendarDays(); track day.date.getTime()) {\n <button type=\"button\" class=\"calendar-day\" [class.calendar-day-other-month]=\"!day.isCurrentMonth\"\n [class.calendar-day-today]=\"day.isToday\" [class.calendar-day-selected]=\"day.isSelected\"\n [class.calendar-day-in-range]=\"day.isInRange\" [class.calendar-day-range-start]=\"day.isRangeStart\"\n [class.calendar-day-range-end]=\"day.isRangeEnd\" [disabled]=\"day.isDisabled\" (click)=\"onDateClick(day)\">\n {{ day.date.getDate() }}\n </button>\n }\n </div>\n }\n\n @if (currentView() === CalendarViewEnum.Months) {\n <div class=\"calendar-months\">\n @for (month of calendarMonths(); track month.monthIndex) {\n <button type=\"button\" class=\"calendar-month\" [class.calendar-month-current]=\"month.isCurrentMonth\"\n [class.calendar-month-selected]=\"month.isSelected\" [disabled]=\"month.isDisabled\" (click)=\"onMonthClick(month)\">\n {{ month.name }}\n </button>\n }\n </div>\n }\n\n @if (currentView() === CalendarViewEnum.Years) {\n <div class=\"calendar-years\">\n @for (year of calendarYears(); track year.year) {\n <button type=\"button\" class=\"calendar-year\" [class.calendar-year-current]=\"year.isCurrentYear\"\n [class.calendar-year-selected]=\"year.isSelected\" [disabled]=\"year.isDisabled\" (click)=\"onYearClick(year)\">\n {{ year.year }}\n </button>\n }\n </div>\n }\n</div>\n","import { Injectable, signal, Signal } from '@angular/core';\nimport { OptionalType } from '@updevs/sdk/types';\n\nimport { CalendarViewType } from '../types/calendar-view.type';\nimport { DateRangeModel } from '../models/date-range.model';\n\n@Injectable()\nexport class CalendarSignalsService {\n get minDate(): Signal<OptionalType<Date>> {\n return this.minDateSignal.asReadonly();\n }\n set minDate(value: OptionalType<Date>) {\n this.minDateSignal.set(value);\n }\n get maxDate(): Signal<OptionalType<Date>> {\n return this.maxDateSignal.asReadonly();\n }\n set maxDate(value: OptionalType<Date>) {\n this.maxDateSignal.set(value);\n }\n get activeDate(): Signal<Date> {\n return this.activeDateSignal.asReadonly();\n }\n set activeDate(value: Date) {\n this.activeDateSignal.set(value);\n }\n get selectedDate(): Signal<DateRangeModel | OptionalType<Date>> {\n return this.selectedDateSignal.asReadonly();\n }\n set selectedDate(value: OptionalType<DateRangeModel | OptionalType<Date>>) {\n this.selectedDateSignal.set(value);\n }\n get currentView(): Signal<CalendarViewType> {\n return this.currentViewSignal.asReadonly();\n }\n set currentView(value: CalendarViewType) {\n this.currentViewSignal.set(value);\n }\n\n private readonly minDateSignal = signal<OptionalType<Date>>(undefined);\n private readonly maxDateSignal = signal<OptionalType<Date>>(undefined);\n private readonly activeDateSignal = signal<Date>(new Date());\n private readonly selectedDateSignal = signal<DateRangeModel | OptionalType<Date>>(undefined);\n private readonly currentViewSignal = signal<CalendarViewType>('month');\n}\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { UpdButtonModule } from '@updevs/components/button';\nimport { UpdIconsModule } from '@updevs/icons';\nimport { TranslocoService, TranslocoDirective } from '@jsverse/transloco';\n\nimport * as en from './assets/i18n/en.json';\nimport * as pt from './assets/i18n/pt.json';\nimport { CalendarSignalsService } from './services/calendar-signals.service';\nimport { CalendarRangeStrategyService } from './services/calendar-range-strategy.service';\nimport { CalendarComponent } from './calendar.component';\n\n@NgModule({\n imports: [\n CommonModule,\n UpdButtonModule,\n TranslocoDirective,\n UpdIconsModule\n ],\n declarations: [\n CalendarComponent\n ],\n exports: [\n CalendarComponent\n ],\n providers: [\n CalendarSignalsService,\n CalendarRangeStrategyService\n ]\n})\nexport class UpdCalendarModule {\n constructor(translocoService: TranslocoService) {\n translocoService.setFallbackLangForMissingTranslation({ fallbackLang: 'en' });\n translocoService.setTranslation(en, 'en');\n translocoService.setTranslation(pt, 'pt');\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":["en","pt"],"mappings":"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"}
@@ -0,0 +1,242 @@
1
+ import * as i0 from '@angular/core';
2
+ import { inject, TemplateRef, Directive, Input, ContentChild, HostBinding, ViewEncapsulation, Component, NgModule } from '@angular/core';
3
+ import * as i1 from '@angular/common';
4
+ import { CommonModule } from '@angular/common';
5
+ import * as i2 from '@updevs/icons';
6
+ import { UpdIconsModule } from '@updevs/icons';
7
+ import * as i3 from '@updevs/components/button';
8
+ import { UpdButtonModule } from '@updevs/components/button';
9
+
10
+ class CardActionsDirective {
11
+ constructor() {
12
+ this.templateRef = inject((TemplateRef));
13
+ }
14
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardActionsDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
15
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "21.1.4", type: CardActionsDirective, isStandalone: false, selector: "ng-template[updCardActions]", ngImport: i0 }); }
16
+ }
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardActionsDirective, decorators: [{
18
+ type: Directive,
19
+ args: [{
20
+ standalone: false,
21
+ selector: 'ng-template[updCardActions]'
22
+ }]
23
+ }] });
24
+
25
+ class CardFooterDirective {
26
+ constructor() {
27
+ this.templateRef = inject((TemplateRef));
28
+ }
29
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardFooterDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
30
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "21.1.4", type: CardFooterDirective, isStandalone: false, selector: "ng-template[updCardFooter]", ngImport: i0 }); }
31
+ }
32
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardFooterDirective, decorators: [{
33
+ type: Directive,
34
+ args: [{
35
+ standalone: false,
36
+ selector: 'ng-template[updCardFooter]'
37
+ }]
38
+ }] });
39
+
40
+ class CardHeaderDirective {
41
+ constructor() {
42
+ this.templateRef = inject((TemplateRef));
43
+ }
44
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardHeaderDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
45
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "21.1.4", type: CardHeaderDirective, isStandalone: false, selector: "ng-template[updCardHeader]", ngImport: i0 }); }
46
+ }
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardHeaderDirective, decorators: [{
48
+ type: Directive,
49
+ args: [{
50
+ standalone: false,
51
+ selector: 'ng-template[updCardHeader]'
52
+ }]
53
+ }] });
54
+
55
+ class CardImageDirective {
56
+ constructor() {
57
+ this.templateRef = inject((TemplateRef));
58
+ }
59
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardImageDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
60
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "21.1.4", type: CardImageDirective, isStandalone: false, selector: "ng-template[updCardImage]", ngImport: i0 }); }
61
+ }
62
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardImageDirective, decorators: [{
63
+ type: Directive,
64
+ args: [{
65
+ standalone: false,
66
+ selector: 'ng-template[updCardImage]'
67
+ }]
68
+ }] });
69
+
70
+ class CardComponent {
71
+ constructor() {
72
+ this.wrapperClasses = '';
73
+ this.stampBackground = 'primary';
74
+ this.statusPosition = 'top';
75
+ this.ribbonStyle = 'default';
76
+ this.ribbonIcon = { tablerIcon: 'star' };
77
+ this.removeBorder = false;
78
+ this.useLightHeader = false;
79
+ /**
80
+ * Whether the header should be displayed.
81
+ */
82
+ this.showHeader = true;
83
+ this.isFooterTransparent = false;
84
+ this.showProgressBar = false;
85
+ this.actions = [];
86
+ this.classes = [];
87
+ }
88
+ ngOnInit() {
89
+ this.updateClasses();
90
+ }
91
+ ngOnChanges(changes) {
92
+ this.updateClasses();
93
+ }
94
+ updateClasses() {
95
+ const lClasses = [];
96
+ if (this.removeBorder) {
97
+ lClasses.push('card-borderless');
98
+ }
99
+ if (!!this.hoverEffect) {
100
+ lClasses.push('card-link');
101
+ if (this.hoverEffect !== 'default') {
102
+ lClasses.push(`card-link-${this.hoverEffect}`);
103
+ }
104
+ }
105
+ if (!!this.state) {
106
+ lClasses.push(`card-${this.state}`);
107
+ }
108
+ if (!!this.bgColor) {
109
+ lClasses.push(`bg-${this.bgColor}`);
110
+ }
111
+ if (!!this.rotate) {
112
+ lClasses.push(`card-rotate-${this.rotate}`);
113
+ }
114
+ if (!!this.type) {
115
+ lClasses.push(`card-${this.type}`);
116
+ }
117
+ if (!!this.hoverEffect) {
118
+ this.classes = [...lClasses];
119
+ }
120
+ else {
121
+ this.wrapperClasses = 'card ' + lClasses.join(' ');
122
+ }
123
+ }
124
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
125
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.1.4", type: CardComponent, isStandalone: false, selector: "upd-card", inputs: { wrapperClasses: "wrapperClasses", title: "title", subtitle: "subtitle", hoverEffect: "hoverEffect", state: "state", type: "type", imagePosition: "imagePosition", bgColor: "bgColor", stampIcon: "stampIcon", stampBackground: "stampBackground", statusBackground: "statusBackground", statusPosition: "statusPosition", ribbonBackground: "ribbonBackground", ribbonStyle: "ribbonStyle", ribbonIcon: "ribbonIcon", ribbonText: "ribbonText", rotate: "rotate", removeBorder: "removeBorder", useLightHeader: "useLightHeader", showHeader: "showHeader", isFooterTransparent: "isFooterTransparent", footerText: "footerText", showProgressBar: "showProgressBar", progress: "progress", actions: "actions" }, host: { properties: { "class": "this.wrapperClasses" } }, queries: [{ propertyName: "headerTemplate", first: true, predicate: CardHeaderDirective, descendants: true }, { propertyName: "footerTemplate", first: true, predicate: CardFooterDirective, descendants: true }, { propertyName: "imageTemplate", first: true, predicate: CardImageDirective, descendants: true }, { propertyName: "actionsTemplate", first: true, predicate: CardActionsDirective, descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (!hoverEffect) {\n <ng-template [ngTemplateOutlet]=\"structureTpl\"></ng-template>\n} @else {\n <a href=\"#\" class=\"card\" [ngClass]=\"classes\">\n <ng-template [ngTemplateOutlet]=\"structureTpl\"></ng-template>\n </a>\n}\n\n<!-- Template for cards that are links -->\n\n<ng-template #structureTpl>\n <!-- Ribbon -->\n @if (!!ribbonBackground) {\n <div class=\"ribbon {{ribbonStyle === 'default' ? '' : 'ribbon-' + ribbonStyle}} bg-{{ribbonBackground}}\">\n @if (!!ribbonText) {\n <span>{{ribbonText}}</span>\n } @else {\n <upd-icon [model]=\"ribbonIcon\" wrapperClasses=\"icon\" [removeDefaultClasses]=\"true\"></upd-icon>\n }\n </div>\n }\n\n <!-- Status -->\n @if (!!statusBackground) {\n <div class=\"card-status-{{statusPosition}} bg-{{statusBackground}}\"></div>\n }\n\n <!-- Stamp -->\n @if (!!stampIcon) {\n <div class=\"card-stamp\">\n <div class=\"card-stamp-icon bg-{{stampBackground}}\">\n <upd-icon [model]=\"stampIcon\" wrapperClasses=\"icon\" [removeDefaultClasses]=\"true\"></upd-icon>\n </div>\n </div>\n }\n\n <!-- Header section -->\n @if (showHeader && (!!title || !!headerTemplate?.templateRef)) {\n <div class=\"card-header\" [class.card-header-light]=\"useLightHeader\">\n @if (!headerTemplate?.templateRef) {\n <h3 class=\"card-title\">{{title}} @if (!!subtitle) {\n <span class=\"card-subtitle\">{{subtitle}}</span>\n }</h3>\n } @else {\n <ng-template [ngTemplateOutlet]=\"headerTemplate?.templateRef || null\"></ng-template>\n }\n <!-- Actions -->\n @if (!!actionsTemplate || actions.length > 0) {\n <div class=\"card-actions\">\n @if (actions.length > 0) {\n @for (btn of actions; track btn) {\n <upd-button [model]=\"btn\" customClasses=\"me-1\"></upd-button>\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"actionsTemplate?.templateRef || null\"></ng-template>\n }\n </div>\n }\n </div>\n }\n\n <!-- Body -->\n @if (!!imageTemplate) {\n @if (imagePosition === 'left' || imagePosition === 'right') {\n <ng-template\n [ngTemplateOutlet]=\"bodyWithSideImageTpl\"></ng-template>\n } @else {\n @if (imagePosition === 'top') {\n <div class=\"img-responsive-21x9 card-img-top\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n }\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n @if (imagePosition === 'bottom') {\n <div class=\"img-responsive-21x9 card-img-bottom\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n }\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n }\n\n <!-- Footer -->\n @if (!!footerText || !!footerTemplate) {\n <div class=\"card-footer\" [class.card-footer-transparent]=\"isFooterTransparent\">\n @if (!footerTemplate?.templateRef) {\n @if (!!footerText) {\n <span>{{footerText}}</span>\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"footerTemplate?.templateRef || null\"></ng-template>\n }\n </div>\n }\n\n <!-- Progress bar -->\n @if (showProgressBar) {\n <div class=\"progress progress-sm card-progress\">\n <div class=\"progress-bar\" [style.width.%]=\"progress\" role=\"progressbar\" [attr.aria-valuenow]=\"progress\" aria-valuemin=\"0\"\n aria-valuemax=\"100\">\n </div>\n </div>\n }\n</ng-template>\n\n<!-- Body with an image on either side -->\n<ng-template #bodyWithSideImageTpl>\n <div class=\"row row-0\">\n <div class=\"col-3\" [class.order-md-last]=\"imagePosition === 'right'\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n <div class=\"col\">\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n </div>\n </div>\n</ng-template>\n\n<!-- Body with an image on top or bottom -->\n\n<!-- Body -->\n<ng-template #bodyTpl>\n <div class=\"card-body\">\n <!-- If title was set, but the header section is hidden, we add the title to the body -->\n @if (!showHeader && !!title) {\n <h3 class=\"card-title\">{{title}} @if (!!subtitle) {\n <span class=\"card-subtitle\">{{subtitle}}</span>\n }</h3>\n }\n <ng-content></ng-content>\n </div>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.IconComponent, selector: "upd-icon", inputs: ["model", "wrapperClasses", "color", "colorClass", "removeDefaultClasses", "customClasses", "tablerIcon", "tablerIconWeight", "tablerIconType", "tablerIconSize", "heroIcon", "heroIconSize", "heroIconType"] }, { kind: "component", type: i3.ButtonComponent, selector: "upd-button", inputs: ["model", "text", "brandColorStyle", "customClasses", "isOutline", "isGhost", "isSquare", "isPill", "isIcon", "isLoading", "isList", "isFloating", "isAction", "isNavigationLink", "isLink", "shouldIgnoreBtnClass", "iconModel", "iconPosition", "isDisabled", "isActive", "badgeConfig", "colorStyle", "size", "title", "stopPropagation"], outputs: ["clicked"] }], encapsulation: i0.ViewEncapsulation.None }); }
126
+ }
127
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: CardComponent, decorators: [{
128
+ type: Component,
129
+ args: [{ standalone: false, selector: 'upd-card', encapsulation: ViewEncapsulation.None, template: "@if (!hoverEffect) {\n <ng-template [ngTemplateOutlet]=\"structureTpl\"></ng-template>\n} @else {\n <a href=\"#\" class=\"card\" [ngClass]=\"classes\">\n <ng-template [ngTemplateOutlet]=\"structureTpl\"></ng-template>\n </a>\n}\n\n<!-- Template for cards that are links -->\n\n<ng-template #structureTpl>\n <!-- Ribbon -->\n @if (!!ribbonBackground) {\n <div class=\"ribbon {{ribbonStyle === 'default' ? '' : 'ribbon-' + ribbonStyle}} bg-{{ribbonBackground}}\">\n @if (!!ribbonText) {\n <span>{{ribbonText}}</span>\n } @else {\n <upd-icon [model]=\"ribbonIcon\" wrapperClasses=\"icon\" [removeDefaultClasses]=\"true\"></upd-icon>\n }\n </div>\n }\n\n <!-- Status -->\n @if (!!statusBackground) {\n <div class=\"card-status-{{statusPosition}} bg-{{statusBackground}}\"></div>\n }\n\n <!-- Stamp -->\n @if (!!stampIcon) {\n <div class=\"card-stamp\">\n <div class=\"card-stamp-icon bg-{{stampBackground}}\">\n <upd-icon [model]=\"stampIcon\" wrapperClasses=\"icon\" [removeDefaultClasses]=\"true\"></upd-icon>\n </div>\n </div>\n }\n\n <!-- Header section -->\n @if (showHeader && (!!title || !!headerTemplate?.templateRef)) {\n <div class=\"card-header\" [class.card-header-light]=\"useLightHeader\">\n @if (!headerTemplate?.templateRef) {\n <h3 class=\"card-title\">{{title}} @if (!!subtitle) {\n <span class=\"card-subtitle\">{{subtitle}}</span>\n }</h3>\n } @else {\n <ng-template [ngTemplateOutlet]=\"headerTemplate?.templateRef || null\"></ng-template>\n }\n <!-- Actions -->\n @if (!!actionsTemplate || actions.length > 0) {\n <div class=\"card-actions\">\n @if (actions.length > 0) {\n @for (btn of actions; track btn) {\n <upd-button [model]=\"btn\" customClasses=\"me-1\"></upd-button>\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"actionsTemplate?.templateRef || null\"></ng-template>\n }\n </div>\n }\n </div>\n }\n\n <!-- Body -->\n @if (!!imageTemplate) {\n @if (imagePosition === 'left' || imagePosition === 'right') {\n <ng-template\n [ngTemplateOutlet]=\"bodyWithSideImageTpl\"></ng-template>\n } @else {\n @if (imagePosition === 'top') {\n <div class=\"img-responsive-21x9 card-img-top\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n }\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n @if (imagePosition === 'bottom') {\n <div class=\"img-responsive-21x9 card-img-bottom\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n }\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n }\n\n <!-- Footer -->\n @if (!!footerText || !!footerTemplate) {\n <div class=\"card-footer\" [class.card-footer-transparent]=\"isFooterTransparent\">\n @if (!footerTemplate?.templateRef) {\n @if (!!footerText) {\n <span>{{footerText}}</span>\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"footerTemplate?.templateRef || null\"></ng-template>\n }\n </div>\n }\n\n <!-- Progress bar -->\n @if (showProgressBar) {\n <div class=\"progress progress-sm card-progress\">\n <div class=\"progress-bar\" [style.width.%]=\"progress\" role=\"progressbar\" [attr.aria-valuenow]=\"progress\" aria-valuemin=\"0\"\n aria-valuemax=\"100\">\n </div>\n </div>\n }\n</ng-template>\n\n<!-- Body with an image on either side -->\n<ng-template #bodyWithSideImageTpl>\n <div class=\"row row-0\">\n <div class=\"col-3\" [class.order-md-last]=\"imagePosition === 'right'\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n <div class=\"col\">\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n </div>\n </div>\n</ng-template>\n\n<!-- Body with an image on top or bottom -->\n\n<!-- Body -->\n<ng-template #bodyTpl>\n <div class=\"card-body\">\n <!-- If title was set, but the header section is hidden, we add the title to the body -->\n @if (!showHeader && !!title) {\n <h3 class=\"card-title\">{{title}} @if (!!subtitle) {\n <span class=\"card-subtitle\">{{subtitle}}</span>\n }</h3>\n }\n <ng-content></ng-content>\n </div>\n</ng-template>\n" }]
130
+ }], propDecorators: { wrapperClasses: [{
131
+ type: HostBinding,
132
+ args: ['class']
133
+ }, {
134
+ type: Input
135
+ }], headerTemplate: [{
136
+ type: ContentChild,
137
+ args: [CardHeaderDirective]
138
+ }], footerTemplate: [{
139
+ type: ContentChild,
140
+ args: [CardFooterDirective]
141
+ }], imageTemplate: [{
142
+ type: ContentChild,
143
+ args: [CardImageDirective]
144
+ }], actionsTemplate: [{
145
+ type: ContentChild,
146
+ args: [CardActionsDirective]
147
+ }], title: [{
148
+ type: Input
149
+ }], subtitle: [{
150
+ type: Input
151
+ }], hoverEffect: [{
152
+ type: Input
153
+ }], state: [{
154
+ type: Input
155
+ }], type: [{
156
+ type: Input
157
+ }], imagePosition: [{
158
+ type: Input
159
+ }], bgColor: [{
160
+ type: Input
161
+ }], stampIcon: [{
162
+ type: Input
163
+ }], stampBackground: [{
164
+ type: Input
165
+ }], statusBackground: [{
166
+ type: Input
167
+ }], statusPosition: [{
168
+ type: Input
169
+ }], ribbonBackground: [{
170
+ type: Input
171
+ }], ribbonStyle: [{
172
+ type: Input
173
+ }], ribbonIcon: [{
174
+ type: Input
175
+ }], ribbonText: [{
176
+ type: Input
177
+ }], rotate: [{
178
+ type: Input
179
+ }], removeBorder: [{
180
+ type: Input
181
+ }], useLightHeader: [{
182
+ type: Input
183
+ }], showHeader: [{
184
+ type: Input
185
+ }], isFooterTransparent: [{
186
+ type: Input
187
+ }], footerText: [{
188
+ type: Input
189
+ }], showProgressBar: [{
190
+ type: Input
191
+ }], progress: [{
192
+ type: Input
193
+ }], actions: [{
194
+ type: Input
195
+ }] } });
196
+
197
+ class UpdCardModule {
198
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: UpdCardModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
199
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "21.1.4", ngImport: i0, type: UpdCardModule, declarations: [CardComponent,
200
+ CardHeaderDirective,
201
+ CardFooterDirective,
202
+ CardImageDirective,
203
+ CardActionsDirective], imports: [CommonModule,
204
+ UpdIconsModule,
205
+ UpdButtonModule], exports: [CardComponent,
206
+ CardHeaderDirective,
207
+ CardFooterDirective,
208
+ CardImageDirective] }); }
209
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: UpdCardModule, imports: [CommonModule,
210
+ UpdIconsModule,
211
+ UpdButtonModule] }); }
212
+ }
213
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: UpdCardModule, decorators: [{
214
+ type: NgModule,
215
+ args: [{
216
+ imports: [
217
+ CommonModule,
218
+ UpdIconsModule,
219
+ UpdButtonModule
220
+ ],
221
+ declarations: [
222
+ CardComponent,
223
+ CardHeaderDirective,
224
+ CardFooterDirective,
225
+ CardImageDirective,
226
+ CardActionsDirective
227
+ ],
228
+ exports: [
229
+ CardComponent,
230
+ CardHeaderDirective,
231
+ CardFooterDirective,
232
+ CardImageDirective
233
+ ]
234
+ }]
235
+ }] });
236
+
237
+ /**
238
+ * Generated bundle index. Do not edit.
239
+ */
240
+
241
+ export { CardActionsDirective, CardComponent, CardFooterDirective, CardHeaderDirective, CardImageDirective, UpdCardModule };
242
+ //# sourceMappingURL=updevs-components-card.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"updevs-components-card.mjs","sources":["../../../../libs/components/card/src/directives/card-actions.directive.ts","../../../../libs/components/card/src/directives/card-footer.directive.ts","../../../../libs/components/card/src/directives/card-header.directive.ts","../../../../libs/components/card/src/directives/card-image.directive.ts","../../../../libs/components/card/src/card.component.ts","../../../../libs/components/card/src/card.component.html","../../../../libs/components/card/src/upd-card.module.ts","../../../../libs/components/card/src/updevs-components-card.ts"],"sourcesContent":["import { Directive, TemplateRef, inject } from '@angular/core';\n\n@Directive({\n standalone: false,\n selector: 'ng-template[updCardActions]'\n})\nexport class CardActionsDirective {\n public readonly templateRef = inject(TemplateRef<any>);\n}\n","import { Directive, TemplateRef, inject } from '@angular/core';\n\n@Directive({\n standalone: false,\n selector: 'ng-template[updCardFooter]'\n})\nexport class CardFooterDirective {\n public readonly templateRef = inject(TemplateRef<any>);\n}\n","import { Directive, TemplateRef, inject } from '@angular/core';\n\n@Directive({\n standalone: false,\n selector: 'ng-template[updCardHeader]'\n})\nexport class CardHeaderDirective {\n public readonly templateRef = inject(TemplateRef<any>);\n}\n","import { Directive, TemplateRef, inject } from '@angular/core';\n\n@Directive({\n standalone: false,\n selector: 'ng-template[updCardImage]'\n})\nexport class CardImageDirective {\n public readonly templateRef = inject(TemplateRef<any>);\n}\n","import {\n Component,\n Input,\n ContentChild,\n SimpleChanges,\n OnInit,\n OnChanges,\n ViewEncapsulation, HostBinding\n} from '@angular/core';\nimport { ButtonModel } from '@updevs/sdk/layout';\nimport { TopBottomLeftRightType, BgColorStyleType } from '@updevs/sdk/types';\nimport { IconModel } from '@updevs/icons';\n\nimport { CardFooterDirective } from './directives/card-footer.directive';\nimport { CardHeaderDirective } from './directives/card-header.directive';\nimport { HoverEffectType } from './types/hover-effect.type';\nimport { CardStateType } from './types/card-state.type';\nimport { StatusPositionType } from './types/status-position.type';\nimport { RibbonStyleType } from './types/ribbon-style.type';\nimport { CardStyleType } from './types/card-style.type';\nimport { CardImageDirective } from './directives/card-image.directive';\nimport { CardActionsDirective } from './directives/card-actions.directive';\n\n@Component({\n standalone: false,\n selector: 'upd-card',\n templateUrl: './card.component.html',\n styleUrls: ['./card.component.scss'],\n encapsulation: ViewEncapsulation.None\n})\nexport class CardComponent implements OnInit, OnChanges {\n @HostBinding('class') @Input() wrapperClasses = '';\n @ContentChild(CardHeaderDirective) headerTemplate?: CardHeaderDirective;\n @ContentChild(CardFooterDirective) footerTemplate?: CardFooterDirective;\n @ContentChild(CardImageDirective) imageTemplate?: CardImageDirective;\n @ContentChild(CardActionsDirective) actionsTemplate?: CardActionsDirective;\n\n @Input() title?: string;\n @Input() subtitle?: string;\n @Input() hoverEffect?: HoverEffectType;\n @Input() state?: CardStateType;\n @Input() type?: CardStyleType;\n @Input() imagePosition?: TopBottomLeftRightType;\n @Input() bgColor?: BgColorStyleType;\n @Input() stampIcon?: IconModel;\n @Input() stampBackground: BgColorStyleType = 'primary';\n @Input() statusBackground?: BgColorStyleType;\n @Input() statusPosition: StatusPositionType = 'top';\n @Input() ribbonBackground?: BgColorStyleType;\n @Input() ribbonStyle: RibbonStyleType = 'default';\n @Input() ribbonIcon?: IconModel = { tablerIcon: 'star' };\n @Input() ribbonText?: string;\n @Input() rotate?: 'right' | 'left';\n @Input() removeBorder = false;\n @Input() useLightHeader = false;\n /**\n * Whether the header should be displayed.\n */\n @Input() showHeader = true;\n @Input() isFooterTransparent = false;\n @Input() footerText?: string;\n @Input() showProgressBar = false;\n @Input() progress?: number;\n @Input() actions: ButtonModel[] = [];\n\n classes: string[] = [];\n\n ngOnInit(): void {\n this.updateClasses();\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n this.updateClasses();\n }\n\n private updateClasses(): void {\n const lClasses: string[] = [];\n\n if (this.removeBorder) {\n lClasses.push('card-borderless');\n }\n\n if (!!this.hoverEffect) {\n lClasses.push('card-link');\n\n if (this.hoverEffect !== 'default') {\n lClasses.push(`card-link-${this.hoverEffect}`);\n }\n }\n\n if (!!this.state) {\n lClasses.push(`card-${this.state}`);\n }\n\n if (!!this.bgColor) {\n lClasses.push(`bg-${this.bgColor}`);\n }\n\n if (!!this.rotate) {\n lClasses.push(`card-rotate-${this.rotate}`);\n }\n\n if (!!this.type) {\n lClasses.push(`card-${this.type}`);\n }\n\n if (!!this.hoverEffect) {\n this.classes = [...lClasses];\n } else {\n this.wrapperClasses = 'card ' + lClasses.join(' ');\n }\n }\n}\n","@if (!hoverEffect) {\n <ng-template [ngTemplateOutlet]=\"structureTpl\"></ng-template>\n} @else {\n <a href=\"#\" class=\"card\" [ngClass]=\"classes\">\n <ng-template [ngTemplateOutlet]=\"structureTpl\"></ng-template>\n </a>\n}\n\n<!-- Template for cards that are links -->\n\n<ng-template #structureTpl>\n <!-- Ribbon -->\n @if (!!ribbonBackground) {\n <div class=\"ribbon {{ribbonStyle === 'default' ? '' : 'ribbon-' + ribbonStyle}} bg-{{ribbonBackground}}\">\n @if (!!ribbonText) {\n <span>{{ribbonText}}</span>\n } @else {\n <upd-icon [model]=\"ribbonIcon\" wrapperClasses=\"icon\" [removeDefaultClasses]=\"true\"></upd-icon>\n }\n </div>\n }\n\n <!-- Status -->\n @if (!!statusBackground) {\n <div class=\"card-status-{{statusPosition}} bg-{{statusBackground}}\"></div>\n }\n\n <!-- Stamp -->\n @if (!!stampIcon) {\n <div class=\"card-stamp\">\n <div class=\"card-stamp-icon bg-{{stampBackground}}\">\n <upd-icon [model]=\"stampIcon\" wrapperClasses=\"icon\" [removeDefaultClasses]=\"true\"></upd-icon>\n </div>\n </div>\n }\n\n <!-- Header section -->\n @if (showHeader && (!!title || !!headerTemplate?.templateRef)) {\n <div class=\"card-header\" [class.card-header-light]=\"useLightHeader\">\n @if (!headerTemplate?.templateRef) {\n <h3 class=\"card-title\">{{title}} @if (!!subtitle) {\n <span class=\"card-subtitle\">{{subtitle}}</span>\n }</h3>\n } @else {\n <ng-template [ngTemplateOutlet]=\"headerTemplate?.templateRef || null\"></ng-template>\n }\n <!-- Actions -->\n @if (!!actionsTemplate || actions.length > 0) {\n <div class=\"card-actions\">\n @if (actions.length > 0) {\n @for (btn of actions; track btn) {\n <upd-button [model]=\"btn\" customClasses=\"me-1\"></upd-button>\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"actionsTemplate?.templateRef || null\"></ng-template>\n }\n </div>\n }\n </div>\n }\n\n <!-- Body -->\n @if (!!imageTemplate) {\n @if (imagePosition === 'left' || imagePosition === 'right') {\n <ng-template\n [ngTemplateOutlet]=\"bodyWithSideImageTpl\"></ng-template>\n } @else {\n @if (imagePosition === 'top') {\n <div class=\"img-responsive-21x9 card-img-top\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n }\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n @if (imagePosition === 'bottom') {\n <div class=\"img-responsive-21x9 card-img-bottom\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n }\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n }\n\n <!-- Footer -->\n @if (!!footerText || !!footerTemplate) {\n <div class=\"card-footer\" [class.card-footer-transparent]=\"isFooterTransparent\">\n @if (!footerTemplate?.templateRef) {\n @if (!!footerText) {\n <span>{{footerText}}</span>\n }\n } @else {\n <ng-template [ngTemplateOutlet]=\"footerTemplate?.templateRef || null\"></ng-template>\n }\n </div>\n }\n\n <!-- Progress bar -->\n @if (showProgressBar) {\n <div class=\"progress progress-sm card-progress\">\n <div class=\"progress-bar\" [style.width.%]=\"progress\" role=\"progressbar\" [attr.aria-valuenow]=\"progress\" aria-valuemin=\"0\"\n aria-valuemax=\"100\">\n </div>\n </div>\n }\n</ng-template>\n\n<!-- Body with an image on either side -->\n<ng-template #bodyWithSideImageTpl>\n <div class=\"row row-0\">\n <div class=\"col-3\" [class.order-md-last]=\"imagePosition === 'right'\">\n <div class=\"card-image-{{imagePosition}}\">\n <ng-template [ngTemplateOutlet]=\"imageTemplate!.templateRef\"></ng-template>\n </div>\n </div>\n <div class=\"col\">\n <ng-template [ngTemplateOutlet]=\"bodyTpl\"></ng-template>\n </div>\n </div>\n</ng-template>\n\n<!-- Body with an image on top or bottom -->\n\n<!-- Body -->\n<ng-template #bodyTpl>\n <div class=\"card-body\">\n <!-- If title was set, but the header section is hidden, we add the title to the body -->\n @if (!showHeader && !!title) {\n <h3 class=\"card-title\">{{title}} @if (!!subtitle) {\n <span class=\"card-subtitle\">{{subtitle}}</span>\n }</h3>\n }\n <ng-content></ng-content>\n </div>\n</ng-template>\n","import { NgModule } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { UpdIconsModule } from '@updevs/icons';\nimport { UpdButtonModule } from '@updevs/components/button';\n\nimport { CardComponent } from './card.component';\nimport { CardHeaderDirective } from './directives/card-header.directive';\nimport { CardFooterDirective } from './directives/card-footer.directive';\nimport { CardImageDirective } from './directives/card-image.directive';\nimport { CardActionsDirective } from './directives/card-actions.directive';\n\n@NgModule({\n imports: [\n CommonModule,\n UpdIconsModule,\n UpdButtonModule\n ],\n declarations: [\n CardComponent,\n CardHeaderDirective,\n CardFooterDirective,\n CardImageDirective,\n CardActionsDirective\n ],\n exports: [\n CardComponent,\n CardHeaderDirective,\n CardFooterDirective,\n CardImageDirective\n ]\n})\nexport class UpdCardModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;MAMa,oBAAoB,CAAA;AAJjC,IAAA,WAAA,GAAA;AAKoB,QAAA,IAAA,CAAA,WAAW,GAAG,MAAM,EAAC,WAAgB,EAAC;AACzD;8GAFY,oBAAoB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;kGAApB,oBAAoB,EAAA,YAAA,EAAA,KAAA,EAAA,QAAA,EAAA,6BAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA;;2FAApB,oBAAoB,EAAA,UAAA,EAAA,CAAA;kBAJhC,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,UAAU,EAAE,KAAK;AACjB,oBAAA,QAAQ,EAAE;AACb,iBAAA;;;MCCY,mBAAmB,CAAA;AAJhC,IAAA,WAAA,GAAA;AAKoB,QAAA,IAAA,CAAA,WAAW,GAAG,MAAM,EAAC,WAAgB,EAAC;AACzD;8GAFY,mBAAmB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;kGAAnB,mBAAmB,EAAA,YAAA,EAAA,KAAA,EAAA,QAAA,EAAA,4BAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA;;2FAAnB,mBAAmB,EAAA,UAAA,EAAA,CAAA;kBAJ/B,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,UAAU,EAAE,KAAK;AACjB,oBAAA,QAAQ,EAAE;AACb,iBAAA;;;MCCY,mBAAmB,CAAA;AAJhC,IAAA,WAAA,GAAA;AAKoB,QAAA,IAAA,CAAA,WAAW,GAAG,MAAM,EAAC,WAAgB,EAAC;AACzD;8GAFY,mBAAmB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;kGAAnB,mBAAmB,EAAA,YAAA,EAAA,KAAA,EAAA,QAAA,EAAA,4BAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA;;2FAAnB,mBAAmB,EAAA,UAAA,EAAA,CAAA;kBAJ/B,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,UAAU,EAAE,KAAK;AACjB,oBAAA,QAAQ,EAAE;AACb,iBAAA;;;MCCY,kBAAkB,CAAA;AAJ/B,IAAA,WAAA,GAAA;AAKoB,QAAA,IAAA,CAAA,WAAW,GAAG,MAAM,EAAC,WAAgB,EAAC;AACzD;8GAFY,kBAAkB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;kGAAlB,kBAAkB,EAAA,YAAA,EAAA,KAAA,EAAA,QAAA,EAAA,2BAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA;;2FAAlB,kBAAkB,EAAA,UAAA,EAAA,CAAA;kBAJ9B,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,UAAU,EAAE,KAAK;AACjB,oBAAA,QAAQ,EAAE;AACb,iBAAA;;;MCyBY,aAAa,CAAA;AAP1B,IAAA,WAAA,GAAA;QAQmC,IAAc,CAAA,cAAA,GAAG,EAAE;QAczC,IAAe,CAAA,eAAA,GAAqB,SAAS;QAE7C,IAAc,CAAA,cAAA,GAAuB,KAAK;QAE1C,IAAW,CAAA,WAAA,GAAoB,SAAS;AACxC,QAAA,IAAA,CAAA,UAAU,GAAe,EAAE,UAAU,EAAE,MAAM,EAAE;QAG/C,IAAY,CAAA,YAAA,GAAG,KAAK;QACpB,IAAc,CAAA,cAAA,GAAG,KAAK;AAC/B;;AAEG;QACM,IAAU,CAAA,UAAA,GAAG,IAAI;QACjB,IAAmB,CAAA,mBAAA,GAAG,KAAK;QAE3B,IAAe,CAAA,eAAA,GAAG,KAAK;QAEvB,IAAO,CAAA,OAAA,GAAkB,EAAE;QAEpC,IAAO,CAAA,OAAA,GAAa,EAAE;AA+CzB;IA7CG,QAAQ,GAAA;QACJ,IAAI,CAAC,aAAa,EAAE;;AAGxB,IAAA,WAAW,CAAC,OAAsB,EAAA;QAC9B,IAAI,CAAC,aAAa,EAAE;;IAGhB,aAAa,GAAA;QACjB,MAAM,QAAQ,GAAa,EAAE;AAE7B,QAAA,IAAI,IAAI,CAAC,YAAY,EAAE;AACnB,YAAA,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC;;AAGpC,QAAA,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE;AACpB,YAAA,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC;AAE1B,YAAA,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE;gBAChC,QAAQ,CAAC,IAAI,CAAC,CAAA,UAAA,EAAa,IAAI,CAAC,WAAW,CAAE,CAAA,CAAC;;;AAItD,QAAA,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE;YACd,QAAQ,CAAC,IAAI,CAAC,CAAA,KAAA,EAAQ,IAAI,CAAC,KAAK,CAAE,CAAA,CAAC;;AAGvC,QAAA,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE;YAChB,QAAQ,CAAC,IAAI,CAAC,CAAA,GAAA,EAAM,IAAI,CAAC,OAAO,CAAE,CAAA,CAAC;;AAGvC,QAAA,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE;YACf,QAAQ,CAAC,IAAI,CAAC,CAAA,YAAA,EAAe,IAAI,CAAC,MAAM,CAAE,CAAA,CAAC;;AAG/C,QAAA,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE;YACb,QAAQ,CAAC,IAAI,CAAC,CAAA,KAAA,EAAQ,IAAI,CAAC,IAAI,CAAE,CAAA,CAAC;;AAGtC,QAAA,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE;AACpB,YAAA,IAAI,CAAC,OAAO,GAAG,CAAC,GAAG,QAAQ,CAAC;;aACzB;YACH,IAAI,CAAC,cAAc,GAAG,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC;;;8GA/EjD,aAAa,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;kGAAb,aAAa,EAAA,YAAA,EAAA,KAAA,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,EAAA,cAAA,EAAA,gBAAA,EAAA,KAAA,EAAA,OAAA,EAAA,QAAA,EAAA,UAAA,EAAA,WAAA,EAAA,aAAA,EAAA,KAAA,EAAA,OAAA,EAAA,IAAA,EAAA,MAAA,EAAA,aAAA,EAAA,eAAA,EAAA,OAAA,EAAA,SAAA,EAAA,SAAA,EAAA,WAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,gBAAA,EAAA,kBAAA,EAAA,cAAA,EAAA,gBAAA,EAAA,gBAAA,EAAA,kBAAA,EAAA,WAAA,EAAA,aAAA,EAAA,UAAA,EAAA,YAAA,EAAA,UAAA,EAAA,YAAA,EAAA,MAAA,EAAA,QAAA,EAAA,YAAA,EAAA,cAAA,EAAA,cAAA,EAAA,gBAAA,EAAA,UAAA,EAAA,YAAA,EAAA,mBAAA,EAAA,qBAAA,EAAA,UAAA,EAAA,YAAA,EAAA,eAAA,EAAA,iBAAA,EAAA,QAAA,EAAA,UAAA,EAAA,OAAA,EAAA,SAAA,EAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,OAAA,EAAA,qBAAA,EAAA,EAAA,EAAA,OAAA,EAAA,CAAA,EAAA,YAAA,EAAA,gBAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAER,mBAAmB,EACnB,WAAA,EAAA,IAAA,EAAA,EAAA,EAAA,YAAA,EAAA,gBAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAAA,mBAAmB,gFACnB,kBAAkB,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,EAAA,YAAA,EAAA,iBAAA,EAAA,KAAA,EAAA,IAAA,EAAA,SAAA,EAClB,oBAAoB,EAAA,WAAA,EAAA,IAAA,EAAA,CAAA,EAAA,aAAA,EAAA,IAAA,EAAA,QAAA,EAAA,EAAA,EAAA,QAAA,ECnCtC,mlJA0IA,EAAA,MAAA,EAAA,CAAA,EAAA,CAAA,EAAA,YAAA,EAAA,CAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,OAAA,EAAA,QAAA,EAAA,WAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,SAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,gBAAA,EAAA,QAAA,EAAA,oBAAA,EAAA,MAAA,EAAA,CAAA,yBAAA,EAAA,kBAAA,EAAA,0BAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,aAAA,EAAA,QAAA,EAAA,UAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,gBAAA,EAAA,OAAA,EAAA,YAAA,EAAA,sBAAA,EAAA,eAAA,EAAA,YAAA,EAAA,kBAAA,EAAA,gBAAA,EAAA,gBAAA,EAAA,UAAA,EAAA,cAAA,EAAA,cAAA,CAAA,EAAA,EAAA,EAAA,IAAA,EAAA,WAAA,EAAA,IAAA,EAAA,EAAA,CAAA,eAAA,EAAA,QAAA,EAAA,YAAA,EAAA,MAAA,EAAA,CAAA,OAAA,EAAA,MAAA,EAAA,iBAAA,EAAA,eAAA,EAAA,WAAA,EAAA,SAAA,EAAA,UAAA,EAAA,QAAA,EAAA,QAAA,EAAA,WAAA,EAAA,QAAA,EAAA,YAAA,EAAA,UAAA,EAAA,kBAAA,EAAA,QAAA,EAAA,sBAAA,EAAA,WAAA,EAAA,cAAA,EAAA,YAAA,EAAA,UAAA,EAAA,aAAA,EAAA,YAAA,EAAA,MAAA,EAAA,OAAA,EAAA,iBAAA,CAAA,EAAA,OAAA,EAAA,CAAA,SAAA,CAAA,EAAA,CAAA,EAAA,aAAA,EAAA,EAAA,CAAA,iBAAA,CAAA,IAAA,EAAA,CAAA,CAAA;;2FD5Ga,aAAa,EAAA,UAAA,EAAA,CAAA;kBAPzB,SAAS;AACM,YAAA,IAAA,EAAA,CAAA,EAAA,UAAA,EAAA,KAAK,EACP,QAAA,EAAA,UAAU,EAGL,aAAA,EAAA,iBAAiB,CAAC,IAAI,EAAA,QAAA,EAAA,mlJAAA,EAAA;;sBAGpC,WAAW;uBAAC,OAAO;;sBAAG;;sBACtB,YAAY;uBAAC,mBAAmB;;sBAChC,YAAY;uBAAC,mBAAmB;;sBAChC,YAAY;uBAAC,kBAAkB;;sBAC/B,YAAY;uBAAC,oBAAoB;;sBAEjC;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;sBAIA;;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;;MEhCQ,aAAa,CAAA;8GAAb,aAAa,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA,CAAA;AAAb,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,aAAa,iBAblB,aAAa;YACb,mBAAmB;YACnB,mBAAmB;YACnB,kBAAkB;AAClB,YAAA,oBAAoB,aATpB,YAAY;YACZ,cAAc;AACd,YAAA,eAAe,aAUf,aAAa;YACb,mBAAmB;YACnB,mBAAmB;YACnB,kBAAkB,CAAA,EAAA,CAAA,CAAA;AAGb,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,aAAa,YAlBlB,YAAY;YACZ,cAAc;YACd,eAAe,CAAA,EAAA,CAAA,CAAA;;2FAgBV,aAAa,EAAA,UAAA,EAAA,CAAA;kBApBzB,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;AACN,oBAAA,OAAO,EAAE;wBACL,YAAY;wBACZ,cAAc;wBACd;AACH,qBAAA;AACD,oBAAA,YAAY,EAAE;wBACV,aAAa;wBACb,mBAAmB;wBACnB,mBAAmB;wBACnB,kBAAkB;wBAClB;AACH,qBAAA;AACD,oBAAA,OAAO,EAAE;wBACL,aAAa;wBACb,mBAAmB;wBACnB,mBAAmB;wBACnB;AACH;AACJ,iBAAA;;;AC9BD;;AAEG;;;;"}
@@ -0,0 +1,185 @@
1
+ import * as i0 from '@angular/core';
2
+ import { signal, input, model, computed, inject, Component, NgModule } from '@angular/core';
3
+ import { TextService } from '@updevs/sdk';
4
+ import * as i1 from '@updevs/icons';
5
+ import { UpdIconsModule } from '@updevs/icons';
6
+ import { CommonModule } from '@angular/common';
7
+
8
+ class DragAndDropItemModel {
9
+ get isDraggable() {
10
+ return this.canDrag && !this.isDisabled;
11
+ }
12
+ constructor(init) {
13
+ this.isDisabled = false;
14
+ this.canDrag = true;
15
+ this.canBeEmpty = true; // TODO: implement
16
+ this.isBeingDragged = signal(false, ...(ngDevMode ? [{ debugName: "isBeingDragged" }] : []));
17
+ Object.assign(this, init);
18
+ }
19
+ }
20
+
21
+ class DragAndDropColumnModel {
22
+ constructor(init) {
23
+ Object.assign(this, init);
24
+ this.items = signal(init.items.map(i => new DragAndDropItemModel(i)), ...(ngDevMode ? [{ debugName: "items" }] : []));
25
+ }
26
+ }
27
+
28
+ class DragAndDropComponent {
29
+ constructor() {
30
+ this.config = input.required(...(ngDevMode ? [{ debugName: "config" }] : []));
31
+ this.columns = model([], ...(ngDevMode ? [{ debugName: "columns" }] : []));
32
+ this.showHandler = computed(() => this.config().showHandler || false, ...(ngDevMode ? [{ debugName: "showHandler" }] : []));
33
+ this.canReorder = computed(() => this.config().canReorder || false, ...(ngDevMode ? [{ debugName: "canReorder" }] : []));
34
+ this.textService = inject(TextService);
35
+ this.isReordering = signal(false, ...(ngDevMode ? [{ debugName: "isReordering" }] : []));
36
+ this.draggedItem = signal(undefined, ...(ngDevMode ? [{ debugName: "draggedItem" }] : []));
37
+ this.dragEnterCounter = 0;
38
+ }
39
+ ngOnInit() {
40
+ this.columns.set(this.config().columns.map(c => new DragAndDropColumnModel(c)));
41
+ }
42
+ canShowHandler(item) {
43
+ return this.showHandler() && item.isDraggable;
44
+ }
45
+ startDrag(event, item, origin) {
46
+ item.origin = origin;
47
+ this.draggedItem.set(item);
48
+ item.isBeingDragged.set(true);
49
+ event.dataTransfer.effectAllowed = 'move';
50
+ }
51
+ endDrag(item) {
52
+ item.isBeingDragged.set(false);
53
+ this.draggedItem.set(undefined);
54
+ }
55
+ drop(event, destination) {
56
+ event.preventDefault();
57
+ this.dragEnterCounter = 0;
58
+ const dataTransfer = event.dataTransfer;
59
+ dataTransfer.dropEffect = 'move';
60
+ const itemName = this.draggedItem()?.name;
61
+ const origin = this.draggedItem()?.origin;
62
+ const item = this.columns().find(c => c.name === origin)?.items().find(i => i.name === itemName);
63
+ if (!!item && (this.canReorder() || destination !== origin)) {
64
+ const destinationColumn = this.columns().find(c => c.name === destination);
65
+ const originColumn = this.columns().find(c => c.name === origin);
66
+ if (!!destinationColumn) {
67
+ item.isBeingDragged.set(false);
68
+ this.draggedItem.set(undefined);
69
+ // We only move items if it's a move between containers, if it's a reorder, nothing needs to be done.
70
+ // The item was correctly replaced during dragOver.
71
+ if (destination !== origin) {
72
+ const originIdx = originColumn.items().findIndex(i => i.name === itemName);
73
+ const destinationIdx = destinationColumn.items().findIndex(i => i.name === itemName);
74
+ originColumn.items().splice(originIdx, 1);
75
+ // This is required, because the item may have been added during dragOver. TODO: check
76
+ if (destinationIdx >= 0) {
77
+ dataTransfer.clearData();
78
+ return;
79
+ }
80
+ destinationColumn.items().push(item);
81
+ const destinationColumnIdx = this.columns().findIndex(c => c.name === destination);
82
+ this.columns.update(curr => {
83
+ curr[destinationColumnIdx] = destinationColumn;
84
+ return [...curr];
85
+ });
86
+ }
87
+ dataTransfer.clearData();
88
+ }
89
+ }
90
+ }
91
+ dragOver(event, destination) {
92
+ event.preventDefault();
93
+ const destinationColumn = this.columns().find(c => c.name === destination);
94
+ if (this.isReordering() || destinationColumn.items().length === 0) {
95
+ return;
96
+ }
97
+ event.dataTransfer.dropEffect = 'move';
98
+ this.isReordering.set(true);
99
+ const element = event.target;
100
+ if (!!element.id && !!this.draggedItem() && element.id !== this.draggedItem().name) {
101
+ const destinationHoverIdx = destinationColumn.items().findIndex(i => i.name === element.id);
102
+ const rect = element.getBoundingClientRect();
103
+ const y = event.clientY - rect.top;
104
+ const newOverZone = y <= rect.height / 2 ? 'top' : 'bottom';
105
+ destinationColumn.items.update(curr => {
106
+ const originalArray = [...curr];
107
+ if (destinationHoverIdx >= 0) {
108
+ if (destinationHoverIdx === 0 && newOverZone === 'top') {
109
+ originalArray.unshift(this.draggedItem());
110
+ }
111
+ else if (destinationHoverIdx === curr.length - 1 && newOverZone === 'bottom') {
112
+ originalArray.push(this.draggedItem());
113
+ }
114
+ else {
115
+ const originalItem = curr[destinationHoverIdx];
116
+ originalArray.splice(destinationHoverIdx, 1);
117
+ originalArray.splice(destinationHoverIdx + (newOverZone === 'top' ? -1 : 1), 0, originalItem);
118
+ }
119
+ }
120
+ else if (!!this.draggedItem()) {
121
+ originalArray.push(this.draggedItem());
122
+ }
123
+ return originalArray;
124
+ });
125
+ const destinationColumnIdx = this.columns().findIndex(c => c.name === destination);
126
+ this.columns.update(curr => {
127
+ curr[destinationColumnIdx] = destinationColumn;
128
+ return [...curr];
129
+ });
130
+ }
131
+ this.isReordering.set(false);
132
+ }
133
+ dragEnter() {
134
+ this.dragEnterCounter++;
135
+ }
136
+ dragLeave(columnName) {
137
+ this.dragEnterCounter--;
138
+ if (this.dragEnterCounter === 0 && !!this.draggedItem()?.origin && this.draggedItem()?.origin !== columnName) {
139
+ const column = this.columns().find(c => c.name === columnName);
140
+ const idx = column.items().findIndex(i => i.name === this.draggedItem()?.name);
141
+ if (idx >= 0) {
142
+ column.items.update(curr => {
143
+ curr.splice(idx, 1);
144
+ return [...curr];
145
+ });
146
+ }
147
+ }
148
+ }
149
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: DragAndDropComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
150
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "21.1.4", type: DragAndDropComponent, isStandalone: false, selector: "upd-drag-and-drop", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null }, columns: { classPropertyName: "columns", publicName: "columns", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { columns: "columnsChange" }, ngImport: i0, template: "<div class=\"d-flex w-100\">\n @for (col of columns(); track col.name) {\n <div class=\"d-flex flex-column w-100 me-2 bg-body p-4 rounded\" (drop)=\"drop($event, col.name)\"\n (dragover)=\"dragOver($event, col.name)\" (dragenter)=\"dragEnter()\" (dragleave)=\"dragLeave(col.name)\">\n @if (!!col.title) {\n <div class=\"mb-2\">\n <h1>{{ textService.getText(col.title) }}</h1>\n </div>\n }\n @for (item of col.items(); track item.name) {\n <div class=\"d-flex border p-2 mb-1 bg-muted-lt rounded\" [attr.draggable]=\"item.isDraggable\" [attr.id]=\"item.name\"\n [class.draggable]=\"item.isDraggable\" [class.opacity-25]=\"item.isBeingDragged()\"\n (dragstart)=\"startDrag($event, item, col.name)\" (dragend)=\"endDrag(item)\">\n @if (canShowHandler(item)) {\n <upd-icon tablerIcon=\"grip-vertical\" customClasses=\"me-2\"></upd-icon>\n }\n <div class=\"flex-grow-1 align-content-center\">\n <span>{{ textService.getText(item.text) }}</span>\n </div>\n </div>\n }\n </div>\n }\n</div>\n", styles: [".draggable{cursor:move;-webkit-user-select:none;user-select:none}\n"], dependencies: [{ kind: "component", type: i1.IconComponent, selector: "upd-icon", inputs: ["model", "wrapperClasses", "color", "colorClass", "removeDefaultClasses", "customClasses", "tablerIcon", "tablerIconWeight", "tablerIconType", "tablerIconSize", "heroIcon", "heroIconSize", "heroIconType"] }] }); }
151
+ }
152
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: DragAndDropComponent, decorators: [{
153
+ type: Component,
154
+ args: [{ standalone: false, selector: 'upd-drag-and-drop', template: "<div class=\"d-flex w-100\">\n @for (col of columns(); track col.name) {\n <div class=\"d-flex flex-column w-100 me-2 bg-body p-4 rounded\" (drop)=\"drop($event, col.name)\"\n (dragover)=\"dragOver($event, col.name)\" (dragenter)=\"dragEnter()\" (dragleave)=\"dragLeave(col.name)\">\n @if (!!col.title) {\n <div class=\"mb-2\">\n <h1>{{ textService.getText(col.title) }}</h1>\n </div>\n }\n @for (item of col.items(); track item.name) {\n <div class=\"d-flex border p-2 mb-1 bg-muted-lt rounded\" [attr.draggable]=\"item.isDraggable\" [attr.id]=\"item.name\"\n [class.draggable]=\"item.isDraggable\" [class.opacity-25]=\"item.isBeingDragged()\"\n (dragstart)=\"startDrag($event, item, col.name)\" (dragend)=\"endDrag(item)\">\n @if (canShowHandler(item)) {\n <upd-icon tablerIcon=\"grip-vertical\" customClasses=\"me-2\"></upd-icon>\n }\n <div class=\"flex-grow-1 align-content-center\">\n <span>{{ textService.getText(item.text) }}</span>\n </div>\n </div>\n }\n </div>\n }\n</div>\n", styles: [".draggable{cursor:move;-webkit-user-select:none;user-select:none}\n"] }]
155
+ }], propDecorators: { config: [{ type: i0.Input, args: [{ isSignal: true, alias: "config", required: true }] }], columns: [{ type: i0.Input, args: [{ isSignal: true, alias: "columns", required: false }] }, { type: i0.Output, args: ["columnsChange"] }] } });
156
+
157
+ class UpdDragAndDropModule {
158
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: UpdDragAndDropModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
159
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "21.1.4", ngImport: i0, type: UpdDragAndDropModule, declarations: [DragAndDropComponent], imports: [CommonModule,
160
+ UpdIconsModule], exports: [DragAndDropComponent] }); }
161
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: UpdDragAndDropModule, imports: [CommonModule,
162
+ UpdIconsModule] }); }
163
+ }
164
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "21.1.4", ngImport: i0, type: UpdDragAndDropModule, decorators: [{
165
+ type: NgModule,
166
+ args: [{
167
+ imports: [
168
+ CommonModule,
169
+ UpdIconsModule
170
+ ],
171
+ declarations: [
172
+ DragAndDropComponent
173
+ ],
174
+ exports: [
175
+ DragAndDropComponent
176
+ ]
177
+ }]
178
+ }] });
179
+
180
+ /**
181
+ * Generated bundle index. Do not edit.
182
+ */
183
+
184
+ export { DragAndDropColumnModel, DragAndDropComponent, UpdDragAndDropModule };
185
+ //# sourceMappingURL=updevs-components-drag-and-drop.mjs.map