aril 0.0.6 → 0.0.8
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.
- package/README.md +48 -48
- package/esm2022/http/index.mjs +1 -1
- package/esm2022/http/lib/enums.mjs +7 -6
- package/esm2022/http/lib/interfaces.mjs +10 -31
- package/esm2022/http/src/httpClient.mjs +3 -3
- package/esm2022/http/src/serviceBase.mjs +25 -27
- package/esm2022/http/src/serviceStateMethods.mjs +3 -3
- package/esm2022/public-api.mjs +2 -2
- package/esm2022/theme/layout/app/breadcrumb/app.breadcrumb.component.mjs +41 -0
- package/esm2022/theme/layout/app/config/app.config.component.mjs +132 -0
- package/esm2022/theme/layout/app/layout/app.layout.component.mjs +137 -0
- package/esm2022/theme/layout/app/menu/app.menu.component.mjs +381 -0
- package/esm2022/theme/layout/app/profileSidebar/app.profilesidebar.component.mjs +25 -0
- package/esm2022/theme/layout/app/sidebar/app.sidebar.component.mjs +41 -0
- package/esm2022/theme/layout/app/topbar/app.topbar.component.mjs +29 -0
- package/esm2022/theme/layout/aril-theme-layout.mjs +5 -0
- package/esm2022/theme/layout/index.mjs +2 -0
- package/esm2022/theme/layout/service/app.layout.service.mjs +127 -0
- package/esm2022/theme/layout/service/app.menu.service.mjs +27 -0
- package/esm2022/theme/layout/service/menuchangeevent.mjs +2 -0
- package/esm2022/ui/badge/index.mjs +1 -1
- package/esm2022/ui/badge/src/badge.component.mjs +3 -3
- package/esm2022/ui/button/index.mjs +1 -1
- package/esm2022/ui/button/src/button.component.mjs +2 -2
- package/esm2022/ui/button/src/split-button.component.mjs +3 -3
- package/esm2022/ui/calendar/index.mjs +1 -1
- package/esm2022/ui/calendar/src/calendar.component.mjs +26 -13
- package/esm2022/ui/checkbox/index.mjs +1 -1
- package/esm2022/ui/checkbox/src/check-box.component.mjs +5 -5
- package/esm2022/ui/checkbox/src/tri-state-checkbox.component.mjs +5 -5
- package/esm2022/ui/dxField/index.mjs +1 -1
- package/esm2022/ui/dxField/src/dx-field.component.mjs +5 -5
- package/esm2022/ui/field/index.mjs +1 -1
- package/esm2022/ui/field/src/field.component.mjs +11 -9
- package/esm2022/ui/fileUpload/index.mjs +1 -1
- package/esm2022/ui/fileUpload/src/file-upload.component.mjs +11 -11
- package/esm2022/ui/form/index.mjs +20 -13
- package/esm2022/ui/form/src/form-submit-button.component.mjs +4 -3
- package/esm2022/ui/form/src/form.component.mjs +4 -4
- package/esm2022/ui/index.mjs +2 -2
- package/esm2022/ui/lib/index.mjs +1 -1
- package/esm2022/ui/lib/src/form/form-error-message.component.mjs +9 -9
- package/esm2022/ui/lib/src/form/form-error-message.directive.mjs +1 -1
- package/esm2022/ui/lib/src/form/form-field-builder.mjs +4 -4
- package/esm2022/ui/lib/src/form/form-validation.mjs +3 -3
- package/esm2022/ui/lib/src/grid/flex-grid.directive.mjs +2 -2
- package/esm2022/ui/lib/src/input/baseInput.mjs +4 -4
- package/esm2022/ui/lib/src/input/common-input-validators.service.mjs +6 -6
- package/esm2022/ui/lib/src/input/dx-input-error-message.pipe.mjs +3 -3
- package/esm2022/ui/lib/src/input/input-disabled.directive.mjs +1 -1
- package/esm2022/ui/lib/src/input/input-error-message.pipe.mjs +3 -2
- package/esm2022/ui/lib/src/input/input-transforms.mjs +1 -1
- package/esm2022/ui/lib/src/input/value-accessor.directive.mjs +12 -6
- package/esm2022/ui/mask/index.mjs +1 -1
- package/esm2022/ui/mask/src/mask.component.mjs +9 -9
- package/esm2022/ui/number/index.mjs +1 -1
- package/esm2022/ui/number/src/number.component.mjs +10 -10
- package/esm2022/ui/overlayPanel/index.mjs +1 -1
- package/esm2022/ui/overlayPanel/src/overlay-panel.component.mjs +4 -7
- package/esm2022/ui/panel/index.mjs +1 -1
- package/esm2022/ui/panel/src/panel.component.mjs +4 -4
- package/esm2022/ui/password/index.mjs +1 -1
- package/esm2022/ui/password/src/password.component.mjs +6 -6
- package/esm2022/ui/radioButton/index.mjs +1 -1
- package/esm2022/ui/radioButton/src/radio-button.component.mjs +7 -7
- package/esm2022/ui/selectBox/index.mjs +1 -1
- package/esm2022/ui/selectBox/src/select-box.component.mjs +7 -7
- package/esm2022/ui/switch/index.mjs +1 -1
- package/esm2022/ui/switch/src/switch.component.mjs +6 -6
- package/esm2022/ui/table/index.mjs +24 -17
- package/esm2022/ui/table/src/i18n.mjs +53 -90
- package/esm2022/ui/table/src/table-column.component.mjs +8 -10
- package/esm2022/ui/table/src/table.component.mjs +26 -41
- package/esm2022/ui/tagBox/index.mjs +1 -1
- package/esm2022/ui/tagBox/src/tag-box.component.mjs +12 -12
- package/esm2022/ui/text/index.mjs +1 -1
- package/esm2022/ui/text/src/text.component.mjs +4 -4
- package/esm2022/ui/textArea/index.mjs +1 -1
- package/esm2022/ui/textArea/src/text-area.component.mjs +3 -3
- package/esm2022/ui/tree/index.mjs +1 -1
- package/esm2022/ui/tree/src/tree.component.mjs +29 -45
- package/esm2022/ui/treeTable/index.mjs +1 -1
- package/esm2022/ui/treeTable/src/tree-table.component.mjs +39 -43
- package/esm2022/ui/value/index.mjs +1 -1
- package/esm2022/ui/value/src/value.component.mjs +13 -13
- package/esm2022/util/index.mjs +2 -2
- package/esm2022/util/init-event/index.mjs +1 -1
- package/esm2022/util/init-event/src/init-event.directive.mjs +1 -1
- package/esm2022/util/lib/index.mjs +1 -1
- package/esm2022/util/lib/src/interfaces.mjs +1 -1
- package/esm2022/util/lib/src/types.mjs +1 -1
- package/esm2022/util/primitive-extensions/index.mjs +5 -5
- package/esm2022/util/primitive-extensions/src/boolean.extensions.mjs +1 -1
- package/esm2022/util/primitive-extensions/src/date.extensions.mjs +68 -47
- package/esm2022/util/primitive-extensions/src/number.extensions.mjs +13 -7
- package/esm2022/util/primitive-extensions/src/string.extensions.mjs +4 -4
- package/esm2022/util/pub-sub/index.mjs +1 -1
- package/esm2022/util/pub-sub/src/pub-sub.service.mjs +7 -5
- package/fesm2022/aril-http.mjs +39 -60
- package/fesm2022/aril-http.mjs.map +1 -1
- package/fesm2022/aril-theme-layout.mjs +899 -0
- package/fesm2022/aril-theme-layout.mjs.map +1 -0
- package/fesm2022/aril-ui-badge.mjs +2 -2
- package/fesm2022/aril-ui-badge.mjs.map +1 -1
- package/fesm2022/aril-ui-button.mjs +3 -3
- package/fesm2022/aril-ui-button.mjs.map +1 -1
- package/fesm2022/aril-ui-calendar.mjs +24 -11
- package/fesm2022/aril-ui-calendar.mjs.map +1 -1
- package/fesm2022/aril-ui-checkbox.mjs +8 -8
- package/fesm2022/aril-ui-checkbox.mjs.map +1 -1
- package/fesm2022/aril-ui-dxField.mjs +4 -4
- package/fesm2022/aril-ui-dxField.mjs.map +1 -1
- package/fesm2022/aril-ui-field.mjs +9 -7
- package/fesm2022/aril-ui-field.mjs.map +1 -1
- package/fesm2022/aril-ui-fileUpload.mjs +10 -10
- package/fesm2022/aril-ui-fileUpload.mjs.map +1 -1
- package/fesm2022/aril-ui-form.mjs +23 -20
- package/fesm2022/aril-ui-form.mjs.map +1 -1
- package/fesm2022/aril-ui-lib.mjs +30 -23
- package/fesm2022/aril-ui-lib.mjs.map +1 -1
- package/fesm2022/aril-ui-mask.mjs +10 -10
- package/fesm2022/aril-ui-mask.mjs.map +1 -1
- package/fesm2022/aril-ui-number.mjs +11 -11
- package/fesm2022/aril-ui-number.mjs.map +1 -1
- package/fesm2022/aril-ui-overlayPanel.mjs +2 -5
- package/fesm2022/aril-ui-overlayPanel.mjs.map +1 -1
- package/fesm2022/aril-ui-panel.mjs +2 -2
- package/fesm2022/aril-ui-panel.mjs.map +1 -1
- package/fesm2022/aril-ui-password.mjs +6 -6
- package/fesm2022/aril-ui-password.mjs.map +1 -1
- package/fesm2022/aril-ui-radioButton.mjs +6 -6
- package/fesm2022/aril-ui-radioButton.mjs.map +1 -1
- package/fesm2022/aril-ui-selectBox.mjs +4 -4
- package/fesm2022/aril-ui-selectBox.mjs.map +1 -1
- package/fesm2022/aril-ui-switch.mjs +6 -6
- package/fesm2022/aril-ui-switch.mjs.map +1 -1
- package/fesm2022/aril-ui-table.mjs +99 -150
- package/fesm2022/aril-ui-table.mjs.map +1 -1
- package/fesm2022/aril-ui-tagBox.mjs +10 -10
- package/fesm2022/aril-ui-tagBox.mjs.map +1 -1
- package/fesm2022/aril-ui-text.mjs +3 -3
- package/fesm2022/aril-ui-text.mjs.map +1 -1
- package/fesm2022/aril-ui-textArea.mjs +2 -2
- package/fesm2022/aril-ui-textArea.mjs.map +1 -1
- package/fesm2022/aril-ui-tree.mjs +28 -44
- package/fesm2022/aril-ui-tree.mjs.map +1 -1
- package/fesm2022/aril-ui-treeTable.mjs +38 -42
- package/fesm2022/aril-ui-treeTable.mjs.map +1 -1
- package/fesm2022/aril-ui-value.mjs +11 -11
- package/fesm2022/aril-ui-value.mjs.map +1 -1
- package/fesm2022/aril-ui.mjs +1 -1
- package/fesm2022/aril-ui.mjs.map +1 -1
- package/fesm2022/aril-util-init-event.mjs.map +1 -1
- package/fesm2022/aril-util-lib.mjs.map +1 -1
- package/fesm2022/aril-util-primitive-extensions.mjs +82 -55
- package/fesm2022/aril-util-primitive-extensions.mjs.map +1 -1
- package/fesm2022/aril-util-pub-sub.mjs +6 -4
- package/fesm2022/aril-util-pub-sub.mjs.map +1 -1
- package/fesm2022/aril-util.mjs +1 -1
- package/fesm2022/aril-util.mjs.map +1 -1
- package/fesm2022/aril.mjs +1 -1
- package/fesm2022/aril.mjs.map +1 -1
- package/http/lib/enums.d.ts +6 -5
- package/http/lib/interfaces.d.ts +9 -29
- package/http/src/httpClient.d.ts +3 -3
- package/http/src/serviceBase.d.ts +2 -1
- package/http/src/serviceStateMethods.d.ts +1 -1
- package/package.json +13 -7
- package/styles/ui/ui.common.scss +8 -8
- package/theme/layout/app/breadcrumb/app.breadcrumb.component.d.ts +16 -0
- package/theme/layout/app/breadcrumb/app.breadcrumb.component.html +10 -0
- package/theme/layout/app/breadcrumb/app.breadcrumb.component.ts +50 -0
- package/theme/layout/app/config/app.config.component.d.ts +36 -0
- package/theme/layout/app/config/app.config.component.html +142 -0
- package/theme/layout/app/config/app.config.component.ts +143 -0
- package/theme/layout/app/layout/app.layout.component.d.ts +51 -0
- package/theme/layout/app/layout/app.layout.component.html +13 -0
- package/theme/layout/app/layout/app.layout.component.ts +170 -0
- package/theme/layout/app/menu/app.menu.component.d.ts +44 -0
- package/theme/layout/app/menu/app.menu.component.html +9 -0
- package/theme/layout/app/menu/app.menu.component.ts +343 -0
- package/theme/layout/app/profileSidebar/app.profilesidebar.component.d.ts +10 -0
- package/theme/layout/app/profileSidebar/app.profilesidebar.component.html +152 -0
- package/theme/layout/app/profileSidebar/app.profilesidebar.component.ts +24 -0
- package/theme/layout/app/sidebar/app.sidebar.component.d.ts +15 -0
- package/theme/layout/app/sidebar/app.sidebar.component.html +45 -0
- package/theme/layout/app/sidebar/app.sidebar.component.ts +43 -0
- package/theme/layout/app/topbar/app.topbar.component.d.ts +13 -0
- package/theme/layout/app/topbar/app.topbar.component.html +37 -0
- package/theme/layout/app/topbar/app.topbar.component.ts +28 -0
- package/theme/layout/index.d.ts +1 -0
- package/theme/layout/index.ts +1 -0
- package/theme/layout/ng-package.json +6 -0
- package/theme/layout/service/app.layout.service.d.ts +51 -0
- package/theme/layout/service/app.layout.service.ts +178 -0
- package/theme/layout/service/app.menu.service.d.ts +14 -0
- package/theme/layout/service/app.menu.service.ts +27 -0
- package/theme/layout/service/menuchangeevent.d.ts +4 -0
- package/theme/layout/service/menuchangeevent.ts +4 -0
- package/theme/styles/layout/_animation.scss +53 -53
- package/theme/styles/layout/_breadcrumb.scss +21 -21
- package/theme/styles/layout/_config.scss +42 -42
- package/theme/styles/layout/_content.scss +3 -3
- package/theme/styles/layout/_fonts.scss +40 -36
- package/theme/styles/layout/_layout_dark.scss +5 -5
- package/theme/styles/layout/_layout_dim.scss +5 -5
- package/theme/styles/layout/_layout_light.scss +5 -5
- package/theme/styles/layout/_main.scss +28 -28
- package/theme/styles/layout/_profile.scss +10 -10
- package/theme/styles/layout/_responsive.scss +111 -113
- package/theme/styles/layout/_sidebar_drawer.scss +234 -236
- package/theme/styles/layout/_sidebar_horizontal.scss +163 -163
- package/theme/styles/layout/_sidebar_reveal.scss +201 -203
- package/theme/styles/layout/_sidebar_slim.scss +144 -145
- package/theme/styles/layout/_sidebar_slim_plus.scss +162 -163
- package/theme/styles/layout/_sidebar_vertical.scss +153 -153
- package/theme/styles/layout/_topbar.scss +78 -78
- package/theme/styles/layout/_typography.scss +68 -63
- package/theme/styles/layout/_utils.scss +24 -24
- package/theme/styles/layout/layout.scss +24 -24
- package/theme/styles/layout/menutheme/_colorscheme.scss +11 -11
- package/theme/styles/layout/menutheme/_menutheme.scss +3 -3
- package/theme/styles/layout/menutheme/_primarycolor.scss +16 -16
- package/theme/styles/layout/menutheme/_transparent.scss +26 -26
- package/theme/styles/layout/preloading.scss +84 -84
- package/theme/styles/theme/base/_colors.scss +14 -15
- package/theme/styles/theme/base/_common.scss +39 -38
- package/theme/styles/theme/base/_components.scss +97 -97
- package/theme/styles/theme/base/_mixins.scss +281 -281
- package/theme/styles/theme/base/components/button/_button.scss +535 -535
- package/theme/styles/theme/base/components/button/_speeddial.scss +60 -60
- package/theme/styles/theme/base/components/button/_splitbutton.scss +328 -334
- package/theme/styles/theme/base/components/data/_carousel.scss +31 -31
- package/theme/styles/theme/base/components/data/_datatable.scss +336 -336
- package/theme/styles/theme/base/components/data/_dataview.scss +38 -38
- package/theme/styles/theme/base/components/data/_filter.scss +124 -125
- package/theme/styles/theme/base/components/data/_organizationchart.scss +48 -48
- package/theme/styles/theme/base/components/data/_paginator.scss +78 -78
- package/theme/styles/theme/base/components/data/_timeline.scss +33 -36
- package/theme/styles/theme/base/components/data/_treetable.scss +253 -254
- package/theme/styles/theme/base/components/data/_virtualscroller.scss +24 -24
- package/theme/styles/theme/base/components/file/_fileupload.scss +51 -51
- package/theme/styles/theme/base/components/input/_autocomplete.scss +120 -120
- package/theme/styles/theme/base/components/input/_calendar.scss +250 -250
- package/theme/styles/theme/base/components/input/_cascadeselect.scss +117 -118
- package/theme/styles/theme/base/components/input/_checkbox.scss +71 -71
- package/theme/styles/theme/base/components/input/_chips.scss +49 -49
- package/theme/styles/theme/base/components/input/_colorpicker.scss +11 -11
- package/theme/styles/theme/base/components/input/_dropdown.scss +141 -141
- package/theme/styles/theme/base/components/input/_editor.scss +120 -120
- package/theme/styles/theme/base/components/input/_inputgroup.scss +42 -42
- package/theme/styles/theme/base/components/input/_inputmask.scss +10 -10
- package/theme/styles/theme/base/components/input/_inputnumber.scss +21 -21
- package/theme/styles/theme/base/components/input/_inputswitch.scss +54 -54
- package/theme/styles/theme/base/components/input/_inputtext.scss +62 -62
- package/theme/styles/theme/base/components/input/_listbox.scss +80 -80
- package/theme/styles/theme/base/components/input/_multiselect.scss +158 -160
- package/theme/styles/theme/base/components/input/_password.scss +42 -42
- package/theme/styles/theme/base/components/input/_radiobutton.scss +57 -57
- package/theme/styles/theme/base/components/input/_rating.scss +53 -53
- package/theme/styles/theme/base/components/input/_selectbutton.scss +46 -46
- package/theme/styles/theme/base/components/input/_slider.scss +59 -55
- package/theme/styles/theme/base/components/input/_togglebutton.scss +44 -44
- package/theme/styles/theme/base/components/input/_treeselect.scss +119 -119
- package/theme/styles/theme/base/components/menu/_breadcrumb.scss +33 -33
- package/theme/styles/theme/base/components/menu/_contextmenu.scss +31 -31
- package/theme/styles/theme/base/components/menu/_dock.scss +80 -80
- package/theme/styles/theme/base/components/menu/_megamenu.scss +54 -54
- package/theme/styles/theme/base/components/menu/_menu.scss +30 -30
- package/theme/styles/theme/base/components/menu/_menubar.scss +136 -137
- package/theme/styles/theme/base/components/menu/_panelmenu.scss +151 -151
- package/theme/styles/theme/base/components/menu/_slidemenu.scss +57 -57
- package/theme/styles/theme/base/components/menu/_steps.scss +46 -46
- package/theme/styles/theme/base/components/menu/_tabmenu.scss +60 -61
- package/theme/styles/theme/base/components/menu/_tieredmenu.scss +34 -34
- package/theme/styles/theme/base/components/messages/_inlinemessage.scss +55 -55
- package/theme/styles/theme/base/components/messages/_message.scss +105 -105
- package/theme/styles/theme/base/components/messages/_toast.scss +97 -98
- package/theme/styles/theme/base/components/misc/_avatar.scss +22 -22
- package/theme/styles/theme/base/components/misc/_badge.scss +40 -40
- package/theme/styles/theme/base/components/misc/_chip.scss +39 -39
- package/theme/styles/theme/base/components/misc/_inplace.scss +12 -13
- package/theme/styles/theme/base/components/misc/_progressbar.scss +13 -13
- package/theme/styles/theme/base/components/misc/_scrolltop.scss +20 -20
- package/theme/styles/theme/base/components/misc/_skeleton.scss +6 -6
- package/theme/styles/theme/base/components/misc/_tag.scss +31 -31
- package/theme/styles/theme/base/components/misc/_terminal.scss +1 -1
- package/theme/styles/theme/base/components/multimedia/_galleria.scss +150 -150
- package/theme/styles/theme/base/components/multimedia/_image.scss +35 -35
- package/theme/styles/theme/base/components/overlay/_confirmpopup.scss +57 -59
- package/theme/styles/theme/base/components/overlay/_dialog.scss +56 -56
- package/theme/styles/theme/base/components/overlay/_overlaypanel.scss +58 -60
- package/theme/styles/theme/base/components/overlay/_sidebar.scss +20 -20
- package/theme/styles/theme/base/components/overlay/_tooltip.scss +27 -27
- package/theme/styles/theme/base/components/panel/_accordion.scss +104 -104
- package/theme/styles/theme/base/components/panel/_card.scss +23 -23
- package/theme/styles/theme/base/components/panel/_divider.scss +24 -24
- package/theme/styles/theme/base/components/panel/_fieldset.scss +38 -38
- package/theme/styles/theme/base/components/panel/_panel.scss +61 -61
- package/theme/styles/theme/base/components/panel/_scrollpanel.scss +5 -5
- package/theme/styles/theme/base/components/panel/_splitter.scss +15 -15
- package/theme/styles/theme/base/components/panel/_tabview.scss +68 -68
- package/theme/styles/theme/base/components/panel/_toolbar.scss +8 -8
- package/theme/styles/theme/dark/_extensions.scss +134 -120
- package/theme/styles/theme/dark/_variables.scss +918 -896
- package/theme/styles/theme/dark/blue/theme.scss +14 -14
- package/theme/styles/theme/dark/indigo/theme.scss +14 -14
- package/theme/styles/theme/light/_extensions.scss +116 -102
- package/theme/styles/theme/light/_variables.scss +911 -898
- package/theme/styles/theme/light/blue/theme.scss +14 -14
- package/theme/styles/theme/light/indigo/theme.scss +14 -14
- package/ui/calendar/src/calendar.component.d.ts +2 -2
- package/ui/form/index.d.ts +9 -0
- package/ui/form/src/form-submit-button.component.d.ts +1 -1
- package/ui/form/src/form.component.d.ts +1 -1
- package/ui/lib/src/form/form-validation.d.ts +1 -1
- package/ui/lib/src/input/baseInput.d.ts +2 -2
- package/ui/lib/src/input/common-input-validators.service.d.ts +3 -3
- package/ui/lib/src/input/dx-input-error-message.pipe.d.ts +2 -2
- package/ui/lib/src/input/input-transforms.d.ts +1 -1
- package/ui/mask/src/mask.component.d.ts +3 -3
- package/ui/number/src/number.component.d.ts +4 -4
- package/ui/overlayPanel/src/overlay-panel.component.d.ts +1 -1
- package/ui/password/src/password.component.d.ts +3 -3
- package/ui/selectBox/src/select-box.component.d.ts +2 -2
- package/ui/switch/src/switch.component.d.ts +3 -3
- package/ui/table/index.d.ts +13 -0
- package/ui/table/src/table-column.component.d.ts +6 -5
- package/ui/table/src/table.component.d.ts +8 -15
- package/ui/tree/src/tree.component.d.ts +14 -19
- package/ui/treeTable/src/tree-table.component.d.ts +14 -18
- package/ui/value/src/value.component.d.ts +2 -2
- package/util/lib/src/types.d.ts +2 -2
- package/util/primitive-extensions/index.d.ts +4 -4
|
@@ -1,61 +1,57 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { EventEmitter, Component, ChangeDetectionStrategy,
|
|
2
|
+
import { input, EventEmitter, Component, ChangeDetectionStrategy, Output, ContentChildren } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { NgFor, NgForOf, NgTemplateOutlet } from '@angular/common';
|
|
3
5
|
import * as i1 from 'primeng/treetable';
|
|
4
6
|
import { TreeTableModule } from 'primeng/treetable';
|
|
7
|
+
import * as FileSaver from 'file-saver';
|
|
8
|
+
import { ButtonComponent } from 'aril/ui/button';
|
|
9
|
+
import { TextComponent } from 'aril/ui/text';
|
|
10
|
+
import { TableColumnComponent } from 'aril/ui/table';
|
|
5
11
|
import * as i2 from 'primeng/api';
|
|
6
12
|
|
|
7
13
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
14
|
+
const pageOptions = [10, 20, 50, 100];
|
|
8
15
|
class TreeTableComponent {
|
|
9
16
|
constructor() {
|
|
10
|
-
this.
|
|
11
|
-
this.
|
|
12
|
-
this.
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.
|
|
17
|
-
this.
|
|
17
|
+
this.data = input.required();
|
|
18
|
+
this.checkboxSelection = input();
|
|
19
|
+
this.pageSize = input(10);
|
|
20
|
+
this.scrollable = input(false);
|
|
21
|
+
this.scrollHeight = input();
|
|
22
|
+
this.expandEvent = new EventEmitter();
|
|
23
|
+
this.selectionEvent = new EventEmitter();
|
|
24
|
+
this.pageOptions = pageOptions;
|
|
18
25
|
}
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
26
|
+
excelExport() {
|
|
27
|
+
import('xlsx').then((xlsx) => {
|
|
28
|
+
const worksheet = xlsx.utils.json_to_sheet(this.data());
|
|
29
|
+
const workbook = { Sheets: { data: worksheet }, SheetNames: ['data'] };
|
|
30
|
+
const excelBuffer = xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });
|
|
31
|
+
this.saveAsExcelFile(excelBuffer, 'excel_worksheet');
|
|
32
|
+
});
|
|
22
33
|
}
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
34
|
+
saveAsExcelFile(buffer, fileName) {
|
|
35
|
+
const EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8';
|
|
36
|
+
const EXCEL_EXTENSION = '.xlsx';
|
|
37
|
+
const data = new Blob([buffer], {
|
|
38
|
+
type: EXCEL_TYPE
|
|
39
|
+
});
|
|
40
|
+
FileSaver.saveAs(data, fileName + '_export_' + new Date().getTime() + EXCEL_EXTENSION);
|
|
28
41
|
}
|
|
29
42
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TreeTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
30
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: TreeTableComponent, isStandalone: true, selector: "aril-tree-table", inputs: {
|
|
43
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: TreeTableComponent, isStandalone: true, selector: "aril-tree-table", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, checkboxSelection: { classPropertyName: "checkboxSelection", publicName: "checkboxSelection", isSignal: true, isRequired: false, transformFunction: null }, pageSize: { classPropertyName: "pageSize", publicName: "pageSize", isSignal: true, isRequired: false, transformFunction: null }, scrollable: { classPropertyName: "scrollable", publicName: "scrollable", isSignal: true, isRequired: false, transformFunction: null }, scrollHeight: { classPropertyName: "scrollHeight", publicName: "scrollHeight", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { expandEvent: "expandEvent", selectionEvent: "selectionEvent" }, queries: [{ propertyName: "columns", predicate: TableColumnComponent }], ngImport: i0, template: "<p-treeTable\n\t#ref\n\t[value]=\"data()\"\n\t[columns]=\"columns._results\"\n\t[rows]=\"pageSize()\"\n\t[rowHover]=\"true\"\n\t[paginator]=\"true\"\n\t[rowsPerPageOptions]=\"pageOptions\"\n\t[filterDelay]=\"0\"\n\tsortMode=\"multiple\"\n\t[scrollable]=\"scrollable()\"\n\t[scrollHeight]=\"scrollHeight()\"\n\t[(selection)]=\"selectedNodes\"\n\t(onNodeExpand)=\"expandEvent.emit($event.node)\"\n\t(selectionChange)=\"selectionEvent.emit(selectedNodes)\"\n\t[showCurrentPageReport]=\"true\"\n\tcurrentPageReportTemplate=\"Toplam : {totalRecords} kay\u0131t | Sayfa : {currentPage} / {totalPages}\"\n\tstyleClass=\"p-treetable-gridlines p-treetable-striped p-treetable-sm\">\n\t<ng-template pTemplate=\"caption\">\n\t\t<div class=\"flex\">\n\t\t\t<aril-button\n\t\t\t\tsize=\"sm\"\n\t\t\t\ticon=\"FILE_EXCEL\"\n\t\t\t\tcolor=\"primary\"\n\t\t\t\tpTooltip=\"XLS\"\n\t\t\t\ttooltipPosition=\"top\"\n\t\t\t\t(clickEvent)=\"excelExport()\">\n\t\t\t</aril-button>\n\t\t\t<!-- <span class=\"p-input-icon-left ml-auto\">\n\t\t\t\t<aril-text\n\t\t\t\t\ticon=\"SEARCH\"\n\t\t\t\t\ticonPos=\"left\"\n\t\t\t\t\tplaceholder=\"Arama\"\n\t\t\t\t\t[ngModel]=\"filterText\"\n\t\t\t\t\t(ngModelChange)=\"ref.filterGlobal($event, 'contains')\">\n\t\t\t\t</aril-text>\n\t\t\t</span> -->\n\t\t</div>\n\t</ng-template>\n\t<ng-template pTemplate=\"header\" let-columns>\n\t\t<tr>\n\t\t\t@if (checkboxSelection()) {\n\t\t\t\t<th>\n\t\t\t\t\t<p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\n\t\t\t\t</th>\n\t\t\t}\n\t\t\t@for (column of columns; track $index) {\n\t\t\t\t@if (column.isOperation) {\n\t\t\t\t\t<th>\n\t\t\t\t\t\t<div class=\"flex justify-content-center\">Operations</div>\n\t\t\t\t\t</th>\n\t\t\t\t} @else {\n\t\t\t\t\t<th [ttSortableColumn]=\"column.field\">\n\t\t\t\t\t\t<div class=\"flex justify-content-between align-items-center\">\n\t\t\t\t\t\t\t{{ column.header }}\n\t\t\t\t\t\t\t<!-- <p-treeTableSortIcon [field]=\"column.field\"></p-treeTableSortIcon> -->\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</th>\n\t\t\t\t}\n\t\t\t}\n\t\t</tr>\n\t</ng-template>\n\t<ng-template pTemplate=\"body\" let-rowNode let-rowData=\"rowData\" let-columns=\"columns\">\n\t\t<tr [ttRow]=\"rowNode\">\n\t\t\t@if (checkboxSelection()) {\n\t\t\t\t<td>\n\t\t\t\t\t<p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\n\t\t\t\t</td>\n\t\t\t}\n\t\t\t@for (column of columns; track $index) {\n\t\t\t\t<td>\n\t\t\t\t\t@if ($first) {\n\t\t\t\t\t\t<p-treeTableToggler [rowNode]=\"rowNode\"></p-treeTableToggler>\n\t\t\t\t\t}\n\t\t\t\t\t<ng-template ngFor [ngForOf]=\"[rowNode.node]\" [ngForTemplate]=\"column.template\"> </ng-template>\n\t\t\t\t</td>\n\t\t\t}\n\t\t</tr>\n\t</ng-template>\n\t<ng-template pTemplate=\"summary\">\n\t\t<ng-content select=\"[footer]\"></ng-content>\n\t</ng-template>\n\t<ng-template pTemplate=\"emptymessage\">\n\t\t<tr>\n\t\t\t<td [attr.colspan]=\"columns._results.length\">No Data Found</td>\n\t\t</tr>\n\t</ng-template>\n</p-treeTable>\n", dependencies: [{ kind: "ngmodule", type: TreeTableModule }, { kind: "component", type: i1.TreeTable, selector: "p-treeTable", inputs: ["columns", "style", "styleClass", "tableStyle", "tableStyleClass", "autoLayout", "lazy", "lazyLoadOnInit", "paginator", "rows", "first", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorStyleClass", "paginatorDropdownAppendTo", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "customSort", "selectionMode", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "compareSelectionBy", "rowHover", "loading", "loadingIcon", "showLoader", "scrollable", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "frozenColumns", "resizableColumns", "columnResizeMode", "reorderableColumns", "contextMenu", "rowTrackBy", "filters", "globalFilterFields", "filterDelay", "filterMode", "filterLocale", "paginatorLocale", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "value", "virtualRowHeight"], outputs: ["selectionChange", "contextMenuSelectionChange", "onFilter", "onNodeExpand", "onNodeCollapse", "onPage", "onSort", "onLazyLoad", "sortFunction", "onColResize", "onColReorder", "onNodeSelect", "onNodeUnselect", "onContextMenuSelect", "onHeaderCheckboxToggle", "onEditInit", "onEditComplete", "onEditCancel"] }, { kind: "directive", type: i2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i1.TreeTableToggler, selector: "p-treeTableToggler", inputs: ["rowNode"] }, { kind: "directive", type: i1.TTSortableColumn, selector: "[ttSortableColumn]", inputs: ["ttSortableColumn", "ttSortableColumnDisabled"] }, { kind: "directive", type: i1.TTRow, selector: "[ttRow]", inputs: ["ttRow"] }, { kind: "component", type: i1.TTCheckbox, selector: "p-treeTableCheckbox", inputs: ["disabled", "value"] }, { kind: "component", type: i1.TTHeaderCheckbox, selector: "p-treeTableHeaderCheckbox" }, { kind: "component", type: ButtonComponent, selector: "aril-button:not([click])", inputs: ["label", "loading", "disabled", "raised", "outlined", "badge", "size", "icon", "color"], outputs: ["clickEvent"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
31
44
|
}
|
|
32
45
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: TreeTableComponent, decorators: [{
|
|
33
46
|
type: Component,
|
|
34
|
-
args: [{ standalone: true, selector: 'aril-tree-table', imports: [TreeTableModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "
|
|
35
|
-
}], propDecorators: {
|
|
36
|
-
type:
|
|
37
|
-
|
|
38
|
-
}], columns: [{
|
|
39
|
-
type: Input,
|
|
40
|
-
args: [{ required: true }]
|
|
41
|
-
}], rows: [{
|
|
42
|
-
type: Input
|
|
43
|
-
}], rowsPerPageOptions: [{
|
|
44
|
-
type: Input
|
|
45
|
-
}], scrollable: [{
|
|
46
|
-
type: Input
|
|
47
|
-
}], scrollHeight: [{
|
|
48
|
-
type: Input
|
|
49
|
-
}], loading: [{
|
|
50
|
-
type: Input
|
|
51
|
-
}], sortMode: [{
|
|
52
|
-
type: Input
|
|
53
|
-
}], filterMode: [{
|
|
54
|
-
type: Input
|
|
55
|
-
}], selectionMode: [{
|
|
56
|
-
type: Input
|
|
57
|
-
}], selectEvent: [{
|
|
47
|
+
args: [{ standalone: true, selector: 'aril-tree-table', imports: [TreeTableModule, ButtonComponent, TextComponent, FormsModule, NgFor, NgForOf, NgTemplateOutlet], changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-treeTable\n\t#ref\n\t[value]=\"data()\"\n\t[columns]=\"columns._results\"\n\t[rows]=\"pageSize()\"\n\t[rowHover]=\"true\"\n\t[paginator]=\"true\"\n\t[rowsPerPageOptions]=\"pageOptions\"\n\t[filterDelay]=\"0\"\n\tsortMode=\"multiple\"\n\t[scrollable]=\"scrollable()\"\n\t[scrollHeight]=\"scrollHeight()\"\n\t[(selection)]=\"selectedNodes\"\n\t(onNodeExpand)=\"expandEvent.emit($event.node)\"\n\t(selectionChange)=\"selectionEvent.emit(selectedNodes)\"\n\t[showCurrentPageReport]=\"true\"\n\tcurrentPageReportTemplate=\"Toplam : {totalRecords} kay\u0131t | Sayfa : {currentPage} / {totalPages}\"\n\tstyleClass=\"p-treetable-gridlines p-treetable-striped p-treetable-sm\">\n\t<ng-template pTemplate=\"caption\">\n\t\t<div class=\"flex\">\n\t\t\t<aril-button\n\t\t\t\tsize=\"sm\"\n\t\t\t\ticon=\"FILE_EXCEL\"\n\t\t\t\tcolor=\"primary\"\n\t\t\t\tpTooltip=\"XLS\"\n\t\t\t\ttooltipPosition=\"top\"\n\t\t\t\t(clickEvent)=\"excelExport()\">\n\t\t\t</aril-button>\n\t\t\t<!-- <span class=\"p-input-icon-left ml-auto\">\n\t\t\t\t<aril-text\n\t\t\t\t\ticon=\"SEARCH\"\n\t\t\t\t\ticonPos=\"left\"\n\t\t\t\t\tplaceholder=\"Arama\"\n\t\t\t\t\t[ngModel]=\"filterText\"\n\t\t\t\t\t(ngModelChange)=\"ref.filterGlobal($event, 'contains')\">\n\t\t\t\t</aril-text>\n\t\t\t</span> -->\n\t\t</div>\n\t</ng-template>\n\t<ng-template pTemplate=\"header\" let-columns>\n\t\t<tr>\n\t\t\t@if (checkboxSelection()) {\n\t\t\t\t<th>\n\t\t\t\t\t<p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\n\t\t\t\t</th>\n\t\t\t}\n\t\t\t@for (column of columns; track $index) {\n\t\t\t\t@if (column.isOperation) {\n\t\t\t\t\t<th>\n\t\t\t\t\t\t<div class=\"flex justify-content-center\">Operations</div>\n\t\t\t\t\t</th>\n\t\t\t\t} @else {\n\t\t\t\t\t<th [ttSortableColumn]=\"column.field\">\n\t\t\t\t\t\t<div class=\"flex justify-content-between align-items-center\">\n\t\t\t\t\t\t\t{{ column.header }}\n\t\t\t\t\t\t\t<!-- <p-treeTableSortIcon [field]=\"column.field\"></p-treeTableSortIcon> -->\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</th>\n\t\t\t\t}\n\t\t\t}\n\t\t</tr>\n\t</ng-template>\n\t<ng-template pTemplate=\"body\" let-rowNode let-rowData=\"rowData\" let-columns=\"columns\">\n\t\t<tr [ttRow]=\"rowNode\">\n\t\t\t@if (checkboxSelection()) {\n\t\t\t\t<td>\n\t\t\t\t\t<p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\n\t\t\t\t</td>\n\t\t\t}\n\t\t\t@for (column of columns; track $index) {\n\t\t\t\t<td>\n\t\t\t\t\t@if ($first) {\n\t\t\t\t\t\t<p-treeTableToggler [rowNode]=\"rowNode\"></p-treeTableToggler>\n\t\t\t\t\t}\n\t\t\t\t\t<ng-template ngFor [ngForOf]=\"[rowNode.node]\" [ngForTemplate]=\"column.template\"> </ng-template>\n\t\t\t\t</td>\n\t\t\t}\n\t\t</tr>\n\t</ng-template>\n\t<ng-template pTemplate=\"summary\">\n\t\t<ng-content select=\"[footer]\"></ng-content>\n\t</ng-template>\n\t<ng-template pTemplate=\"emptymessage\">\n\t\t<tr>\n\t\t\t<td [attr.colspan]=\"columns._results.length\">No Data Found</td>\n\t\t</tr>\n\t</ng-template>\n</p-treeTable>\n" }]
|
|
48
|
+
}], propDecorators: { expandEvent: [{
|
|
49
|
+
type: Output
|
|
50
|
+
}], selectionEvent: [{
|
|
58
51
|
type: Output
|
|
52
|
+
}], columns: [{
|
|
53
|
+
type: ContentChildren,
|
|
54
|
+
args: [TableColumnComponent]
|
|
59
55
|
}] } });
|
|
60
56
|
|
|
61
57
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aril-ui-treeTable.mjs","sources":["../../projects/aril/ui/treeTable/src/tree-table.component.ts","../../projects/aril/ui/treeTable/src/tree-table.component.html","../../projects/aril/ui/treeTable/aril-ui-treeTable.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\r\n\r\nimport { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { TreeNode, TreeTableNode } from 'primeng/api';\r\nimport { TreeTableModule } from 'primeng/treetable';\r\n\r\n/* TODO : \r\n 1. InputSignal\r\n 2. ContentProjection\r\n 3. ContextMenu ?\r\n*/\r\n\r\ntype SortMode = 'single' | 'multiple';\r\ntype FilterMode = 'lenient' | 'strict';\r\ntype SelectionModes = 'single' | 'multiple' | 'checkbox';\r\n\r\n@Component({\r\n standalone: true,\r\n selector: 'aril-tree-table',\r\n templateUrl: './tree-table.component.html',\r\n styles: [`\r\n :host ::ng-deep .p-icon-wrapper {\r\n display: inline-block !important;\r\n }`\r\n ],\r\n imports: [TreeTableModule],\r\n changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TreeTableComponent {\r\n @Input({ required: true }) items!: TreeNode[];\r\n @Input({ required: true }) columns!: Array<object>;\r\n @Input() rows = 10;\r\n @Input() rowsPerPageOptions = [10, 20, 50, 100];\r\n @Input() scrollable = false;\r\n @Input() scrollHeight!: string;\r\n @Input() loading = false;\r\n @Input() sortMode: SortMode = \"single\";\r\n @Input() filterMode: FilterMode = \"lenient\";\r\n @Input() selectionMode: SelectionModes = \"single\";\r\n\r\n @Output() selectEvent: EventEmitter<any> = new EventEmitter();\r\n\r\n selectedNodes!: TreeTableNode<any> | TreeTableNode<any>[] | null;\r\n\r\n getFilterTargetValue(event: Event) {\r\n const inputElement = event.target as HTMLInputElement;\r\n return inputElement.value;\r\n }\r\n\r\n emitSelectedRows() {\r\n if (!this.selectedNodes) return;\r\n\r\n this.selectEvent.emit(this.selectedNodes);\r\n this.selectedNodes = null;\r\n }\r\n}\r\n","@if (items && columns) {\r\n\t<p-treeTable\r\n\t\t#ref\r\n\t\t[value]=\"items\"\r\n\t\t[columns]=\"columns\"\r\n\t\t[rows]=\"rows\"\r\n\t\t[paginator]=\"true\"\r\n\t\t[rowsPerPageOptions]=\"rowsPerPageOptions\"\r\n\t\t[scrollable]=\"scrollable\"\r\n\t\t[scrollHeight]=\"scrollHeight\"\r\n\t\t[sortMode]=\"sortMode\"\r\n\t\t[filterMode]=\"filterMode\"\r\n\t\t[loading]=\"loading\"\r\n\t\t[selectionMode]=\"selectionMode\"\r\n\t\t[(selection)]=\"selectedNodes\"\r\n\t\tstyleClass=\"p-treetable-sm\">\r\n\t\t<ng-template pTemplate=\"caption\">\r\n\t\t\t<div class=\"flex justify-content-between align-items-center\">\r\n\t\t\t\t<div class=\"flex\">\r\n\t\t\t\t\t<p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\r\n\t\t\t\t\t<span class=\"ml-2\">Tümünü seç</span>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"p-input-icon-left\">\r\n\t\t\t\t\t<i class=\"pi pi-search\"></i>\r\n\t\t\t\t\t<input\r\n\t\t\t\t\t\ttype=\"text\"\r\n\t\t\t\t\t\tpInputText\r\n\t\t\t\t\t\tplaceholder=\"Arama\"\r\n\t\t\t\t\t\t(input)=\"\r\n\t\t\t\t\t\t\tref.filterGlobal(getFilterTargetValue($event), 'contains')\r\n\t\t\t\t\t\t\" />\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</ng-template>\r\n\t\t<ng-template pTemplate=\"header\" let-columns>\r\n\t\t\t<tr>\r\n\t\t\t\t@for (col of columns; track col) {\r\n\t\t\t\t\t<th [ttSortableColumn]=\"col.field\">\r\n\t\t\t\t\t\t<span>{{ col.header }}</span>\r\n\t\t\t\t\t\t<p-treeTableSortIcon [field]=\"col.field\"></p-treeTableSortIcon>\r\n\t\t\t\t\t</th>\r\n\t\t\t\t}\r\n\t\t\t</tr>\r\n\t\t</ng-template>\r\n\t\t<ng-template\r\n\t\t\tpTemplate=\"body\"\r\n\t\t\tlet-rowNode\r\n\t\t\tlet-rowData=\"rowData\"\r\n\t\t\tlet-columns=\"columns\">\r\n\t\t\t<tr [ttRow]=\"rowNode\">\r\n\t\t\t\t@for (col of columns; track col; let first = $first) {\r\n\t\t\t\t\t<td>\r\n\t\t\t\t\t\t@if (first) {\r\n\t\t\t\t\t\t\t<p-treeTableToggler [rowNode]=\"rowNode\"></p-treeTableToggler>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t@if (first) {\r\n\t\t\t\t\t\t\t<p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\t{{ rowData[col.field] }}\r\n\t\t\t\t\t</td>\r\n\t\t\t\t}\r\n\t\t\t</tr>\r\n\t\t</ng-template>\r\n\t\t<ng-template pTemplate=\"summary\">\r\n\t\t\t<div class=\"flex justify-content-end\">\r\n\t\t\t\t<div [attr.role]=\"'none'\" (click)=\"emitSelectedRows()\">\r\n\t\t\t\t\t<ng-content select=\"[exportBtn]\"></ng-content>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</ng-template>\r\n\t\t<ng-template pTemplate=\"emptymessage\">\r\n\t\t\t<tr>\r\n\t\t\t\t<td [attr.colspan]=\"columns.length\">Veri bulunamadı..</td>\r\n\t\t\t</tr>\r\n\t\t</ng-template>\r\n\t</p-treeTable>\r\n}\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"aril-ui-treeTable.mjs","sources":["../../projects/aril/ui/treeTable/src/tree-table.component.ts","../../projects/aril/ui/treeTable/src/tree-table.component.html","../../projects/aril/ui/treeTable/aril-ui-treeTable.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n\nimport { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, input, Output } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { NgFor, NgForOf, NgTemplateOutlet } from '@angular/common';\nimport { TreeNode, TreeTableNode } from 'primeng/api';\nimport { TreeTableModule } from 'primeng/treetable';\nimport * as FileSaver from 'file-saver';\nimport { ButtonComponent } from 'aril/ui/button';\nimport { TextComponent } from 'aril/ui/text';\nimport { TableColumnComponent, TableColumns } from 'aril/ui/table';\n\nconst pageOptions = [10, 20, 50, 100];\n\n@Component({\n\tstandalone: true,\n\tselector: 'aril-tree-table',\n\ttemplateUrl: './tree-table.component.html',\n\timports: [TreeTableModule, ButtonComponent, TextComponent, FormsModule, NgFor, NgForOf, NgTemplateOutlet],\n\tchangeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class TreeTableComponent {\n\tdata = input.required<TreeNode[]>();\n\tcheckboxSelection = input<boolean>();\n\tpageSize = input<(typeof pageOptions)[number]>(10);\n\tscrollable = input<boolean>(false);\n\tscrollHeight = input<string>();\n\n\t@Output() expandEvent: EventEmitter<unknown> = new EventEmitter();\n\t@Output() selectionEvent: EventEmitter<any> = new EventEmitter<any>();\n\n\t@ContentChildren(TableColumnComponent) columns!: TableColumns;\n\n\tfilterText!: string;\n\tpageOptions = pageOptions;\n\tselectedNodes!: TreeTableNode<any> | TreeTableNode<any>[] | null;\n\n\texcelExport() {\n\t\timport('xlsx').then((xlsx) => {\n\t\t\tconst worksheet = xlsx.utils.json_to_sheet(this.data());\n\t\t\tconst workbook = { Sheets: { data: worksheet }, SheetNames: ['data'] };\n\t\t\tconst excelBuffer: any = xlsx.write(workbook, { bookType: 'xlsx', type: 'array' });\n\t\t\tthis.saveAsExcelFile(excelBuffer, 'excel_worksheet');\n\t\t});\n\t}\n\n\tsaveAsExcelFile(buffer: any, fileName: string): void {\n\t\tconst EXCEL_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=UTF-8';\n\t\tconst EXCEL_EXTENSION = '.xlsx';\n\t\tconst data: Blob = new Blob([buffer], {\n\t\t\ttype: EXCEL_TYPE\n\t\t});\n\t\tFileSaver.saveAs(data, fileName + '_export_' + new Date().getTime() + EXCEL_EXTENSION);\n\t}\n}\n","<p-treeTable\n\t#ref\n\t[value]=\"data()\"\n\t[columns]=\"columns._results\"\n\t[rows]=\"pageSize()\"\n\t[rowHover]=\"true\"\n\t[paginator]=\"true\"\n\t[rowsPerPageOptions]=\"pageOptions\"\n\t[filterDelay]=\"0\"\n\tsortMode=\"multiple\"\n\t[scrollable]=\"scrollable()\"\n\t[scrollHeight]=\"scrollHeight()\"\n\t[(selection)]=\"selectedNodes\"\n\t(onNodeExpand)=\"expandEvent.emit($event.node)\"\n\t(selectionChange)=\"selectionEvent.emit(selectedNodes)\"\n\t[showCurrentPageReport]=\"true\"\n\tcurrentPageReportTemplate=\"Toplam : {totalRecords} kayıt | Sayfa : {currentPage} / {totalPages}\"\n\tstyleClass=\"p-treetable-gridlines p-treetable-striped p-treetable-sm\">\n\t<ng-template pTemplate=\"caption\">\n\t\t<div class=\"flex\">\n\t\t\t<aril-button\n\t\t\t\tsize=\"sm\"\n\t\t\t\ticon=\"FILE_EXCEL\"\n\t\t\t\tcolor=\"primary\"\n\t\t\t\tpTooltip=\"XLS\"\n\t\t\t\ttooltipPosition=\"top\"\n\t\t\t\t(clickEvent)=\"excelExport()\">\n\t\t\t</aril-button>\n\t\t\t<!-- <span class=\"p-input-icon-left ml-auto\">\n\t\t\t\t<aril-text\n\t\t\t\t\ticon=\"SEARCH\"\n\t\t\t\t\ticonPos=\"left\"\n\t\t\t\t\tplaceholder=\"Arama\"\n\t\t\t\t\t[ngModel]=\"filterText\"\n\t\t\t\t\t(ngModelChange)=\"ref.filterGlobal($event, 'contains')\">\n\t\t\t\t</aril-text>\n\t\t\t</span> -->\n\t\t</div>\n\t</ng-template>\n\t<ng-template pTemplate=\"header\" let-columns>\n\t\t<tr>\n\t\t\t@if (checkboxSelection()) {\n\t\t\t\t<th>\n\t\t\t\t\t<p-treeTableHeaderCheckbox></p-treeTableHeaderCheckbox>\n\t\t\t\t</th>\n\t\t\t}\n\t\t\t@for (column of columns; track $index) {\n\t\t\t\t@if (column.isOperation) {\n\t\t\t\t\t<th>\n\t\t\t\t\t\t<div class=\"flex justify-content-center\">Operations</div>\n\t\t\t\t\t</th>\n\t\t\t\t} @else {\n\t\t\t\t\t<th [ttSortableColumn]=\"column.field\">\n\t\t\t\t\t\t<div class=\"flex justify-content-between align-items-center\">\n\t\t\t\t\t\t\t{{ column.header }}\n\t\t\t\t\t\t\t<!-- <p-treeTableSortIcon [field]=\"column.field\"></p-treeTableSortIcon> -->\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</th>\n\t\t\t\t}\n\t\t\t}\n\t\t</tr>\n\t</ng-template>\n\t<ng-template pTemplate=\"body\" let-rowNode let-rowData=\"rowData\" let-columns=\"columns\">\n\t\t<tr [ttRow]=\"rowNode\">\n\t\t\t@if (checkboxSelection()) {\n\t\t\t\t<td>\n\t\t\t\t\t<p-treeTableCheckbox [value]=\"rowNode\"></p-treeTableCheckbox>\n\t\t\t\t</td>\n\t\t\t}\n\t\t\t@for (column of columns; track $index) {\n\t\t\t\t<td>\n\t\t\t\t\t@if ($first) {\n\t\t\t\t\t\t<p-treeTableToggler [rowNode]=\"rowNode\"></p-treeTableToggler>\n\t\t\t\t\t}\n\t\t\t\t\t<ng-template ngFor [ngForOf]=\"[rowNode.node]\" [ngForTemplate]=\"column.template\"> </ng-template>\n\t\t\t\t</td>\n\t\t\t}\n\t\t</tr>\n\t</ng-template>\n\t<ng-template pTemplate=\"summary\">\n\t\t<ng-content select=\"[footer]\"></ng-content>\n\t</ng-template>\n\t<ng-template pTemplate=\"emptymessage\">\n\t\t<tr>\n\t\t\t<td [attr.colspan]=\"columns._results.length\">No Data Found</td>\n\t\t</tr>\n\t</ng-template>\n</p-treeTable>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
@@ -4,29 +4,29 @@ import 'aril/util/primitive-extensions';
|
|
|
4
4
|
|
|
5
5
|
class ValueComponent {
|
|
6
6
|
constructor() {
|
|
7
|
-
this.type =
|
|
8
|
-
this.color =
|
|
9
|
-
this.display =
|
|
7
|
+
this.type = 'text';
|
|
8
|
+
this.color = '#333';
|
|
9
|
+
this.display = '';
|
|
10
10
|
}
|
|
11
11
|
ngOnChanges(changes) {
|
|
12
12
|
switch (this.type) {
|
|
13
|
-
case
|
|
13
|
+
case 'text':
|
|
14
14
|
this.display = this.model;
|
|
15
15
|
break;
|
|
16
|
-
case
|
|
16
|
+
case 'number':
|
|
17
17
|
this.format = this.format || '0.###';
|
|
18
18
|
this.display = format(this.format, this.model);
|
|
19
19
|
break;
|
|
20
|
-
case
|
|
20
|
+
case 'decimal':
|
|
21
21
|
this.format = this.format || '#.##0,###';
|
|
22
22
|
this.display = format(this.format, this.model);
|
|
23
23
|
break;
|
|
24
|
-
case
|
|
24
|
+
case 'date':
|
|
25
25
|
this.format = this.format || 'time';
|
|
26
26
|
this.display = this.model.longToString(this.format);
|
|
27
27
|
break;
|
|
28
|
-
case
|
|
29
|
-
this.display = this.model.replace(/./g,
|
|
28
|
+
case 'password':
|
|
29
|
+
this.display = this.model.replace(/./g, '*');
|
|
30
30
|
break;
|
|
31
31
|
default:
|
|
32
32
|
console.error("Invalid type: '" + this.type + "'");
|
|
@@ -34,11 +34,11 @@ class ValueComponent {
|
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
36
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ValueComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
37
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: ValueComponent, isStandalone: true, selector: "aril-value", inputs: { model: "model", type: "type", format: "format", color: "color" }, usesOnChanges: true, ngImport: i0, template: "@if (model == undefined || model == null) {\n\t<
|
|
37
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.2", type: ValueComponent, isStandalone: true, selector: "aril-value", inputs: { model: "model", type: "type", format: "format", color: "color" }, usesOnChanges: true, ngImport: i0, template: "@if (model == undefined || model == null) {\n\t<i class=\"pi pi-minus\" style=\"color: red\" pTooltip=\"No item to show\"></i>\n} @else {\n\t@if (type == 'bool') {\n\t\t@if (!!model) {\n\t\t\t<i class=\"pi pi-check\" style=\"color: green\"></i>\n\t\t} @else {\n\t\t\t<i class=\"pi pi-times\" style=\"color: crimson\"></i>\n\t\t}\n\t} @else {\n\t\t@if (display == undefined) {\n\t\t\t<i class=\"pi pi-exclamation-circle\" style=\"color: red\" pTooltip=\"Invalid Data\"> </i>\n\t\t} @else {\n\t\t\t<span [style.color]=\"color\">\n\t\t\t\t{{ display }}\n\t\t\t</span>\n\t\t}\n\t}\n}\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
38
38
|
}
|
|
39
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ValueComponent, decorators: [{
|
|
40
40
|
type: Component,
|
|
41
|
-
args: [{ standalone: true, selector: 'aril-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (model == undefined || model == null) {\n\t<
|
|
41
|
+
args: [{ standalone: true, selector: 'aril-value', changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (model == undefined || model == null) {\n\t<i class=\"pi pi-minus\" style=\"color: red\" pTooltip=\"No item to show\"></i>\n} @else {\n\t@if (type == 'bool') {\n\t\t@if (!!model) {\n\t\t\t<i class=\"pi pi-check\" style=\"color: green\"></i>\n\t\t} @else {\n\t\t\t<i class=\"pi pi-times\" style=\"color: crimson\"></i>\n\t\t}\n\t} @else {\n\t\t@if (display == undefined) {\n\t\t\t<i class=\"pi pi-exclamation-circle\" style=\"color: red\" pTooltip=\"Invalid Data\"> </i>\n\t\t} @else {\n\t\t\t<span [style.color]=\"color\">\n\t\t\t\t{{ display }}\n\t\t\t</span>\n\t\t}\n\t}\n}\n" }]
|
|
42
42
|
}], propDecorators: { model: [{
|
|
43
43
|
type: Input,
|
|
44
44
|
args: [{ required: true }]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aril-ui-value.mjs","sources":["../../projects/aril/ui/value/src/value.component.ts","../../projects/aril/ui/value/src/value.component.html","../../projects/aril/ui/value/aril-ui-value.ts"],"sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnChanges } from '@angular/core';\
|
|
1
|
+
{"version":3,"file":"aril-ui-value.mjs","sources":["../../projects/aril/ui/value/src/value.component.ts","../../projects/aril/ui/value/src/value.component.html","../../projects/aril/ui/value/aril-ui-value.ts"],"sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnChanges } from '@angular/core';\n\nimport 'aril/util/primitive-extensions';\n\n/* TODO : \n 1. InputSignal\n*/\n\n/* number-format.js */\ndeclare const format: Function;\n\ntype ValueTypes = 'text' | 'number' | 'bool' | 'decimal' | 'date' | 'password';\n\n@Component({\n\tstandalone: true,\n\tselector: 'aril-value',\n\ttemplateUrl: './value.component.html',\n\tchangeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ValueComponent implements OnChanges {\n\t@Input({ required: true }) model!: string | number | boolean | undefined;\n\t@Input() type: ValueTypes = 'text';\n\t@Input() format!: string;\n\t@Input() color: string = '#333';\n\n\tdisplay = '';\n\n\tngOnChanges(changes: any) {\n\t\tswitch (this.type) {\n\t\t\tcase 'text':\n\t\t\t\tthis.display = this.model as string;\n\t\t\t\tbreak;\n\t\t\tcase 'number':\n\t\t\t\tthis.format = this.format || '0.###';\n\t\t\t\tthis.display = format(this.format, this.model);\n\t\t\t\tbreak;\n\t\t\tcase 'decimal':\n\t\t\t\tthis.format = this.format || '#.##0,###';\n\t\t\t\tthis.display = format(this.format, this.model);\n\t\t\t\tbreak;\n\t\t\tcase 'date':\n\t\t\t\tthis.format = this.format || 'time';\n\t\t\t\tthis.display = (<number>this.model).longToString(this.format) as string;\n\t\t\t\tbreak;\n\t\t\tcase 'password':\n\t\t\t\tthis.display = (<string>this.model).replace(/./g, '*');\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tconsole.error(\"Invalid type: '\" + this.type + \"'\");\n\t\t\t\tbreak;\n\t\t}\n\t}\n}\n","@if (model == undefined || model == null) {\n\t<i class=\"pi pi-minus\" style=\"color: red\" pTooltip=\"No item to show\"></i>\n} @else {\n\t@if (type == 'bool') {\n\t\t@if (!!model) {\n\t\t\t<i class=\"pi pi-check\" style=\"color: green\"></i>\n\t\t} @else {\n\t\t\t<i class=\"pi pi-times\" style=\"color: crimson\"></i>\n\t\t}\n\t} @else {\n\t\t@if (display == undefined) {\n\t\t\t<i class=\"pi pi-exclamation-circle\" style=\"color: red\" pTooltip=\"Invalid Data\"> </i>\n\t\t} @else {\n\t\t\t<span [style.color]=\"color\">\n\t\t\t\t{{ display }}\n\t\t\t</span>\n\t\t}\n\t}\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;MAmBa,cAAc,CAAA;AAN3B,IAAA,WAAA,GAAA;QAQU,IAAI,CAAA,IAAA,GAAe,MAAM,CAAC;QAE1B,IAAK,CAAA,KAAA,GAAW,MAAM,CAAC;QAEhC,IAAO,CAAA,OAAA,GAAG,EAAE,CAAC;AA2Bb,KAAA;AAzBA,IAAA,WAAW,CAAC,OAAY,EAAA;AACvB,QAAA,QAAQ,IAAI,CAAC,IAAI;AAChB,YAAA,KAAK,MAAM;AACV,gBAAA,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAe,CAAC;gBACpC,MAAM;AACP,YAAA,KAAK,QAAQ;gBACZ,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,OAAO,CAAC;AACrC,gBAAA,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC/C,MAAM;AACP,YAAA,KAAK,SAAS;gBACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,WAAW,CAAC;AACzC,gBAAA,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC/C,MAAM;AACP,YAAA,KAAK,MAAM;gBACV,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC;AACpC,gBAAA,IAAI,CAAC,OAAO,GAAY,IAAI,CAAC,KAAM,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAW,CAAC;gBACxE,MAAM;AACP,YAAA,KAAK,UAAU;AACd,gBAAA,IAAI,CAAC,OAAO,GAAY,IAAI,CAAC,KAAM,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;gBACvD,MAAM;AACP,YAAA;gBACC,OAAO,CAAC,KAAK,CAAC,iBAAiB,GAAG,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC;gBACnD,MAAM;SACP;KACD;8GAhCW,cAAc,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;AAAd,IAAA,SAAA,IAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,QAAA,EAAA,IAAA,EAAA,cAAc,uKCnB3B,ukBAmBA,EAAA,eAAA,EAAA,EAAA,CAAA,uBAAA,CAAA,MAAA,EAAA,CAAA,CAAA,EAAA;;2FDAa,cAAc,EAAA,UAAA,EAAA,CAAA;kBAN1B,SAAS;AACG,YAAA,IAAA,EAAA,CAAA,EAAA,UAAA,EAAA,IAAI,EACN,QAAA,EAAA,YAAY,EAEL,eAAA,EAAA,uBAAuB,CAAC,MAAM,EAAA,QAAA,EAAA,ukBAAA,EAAA,CAAA;8BAGpB,KAAK,EAAA,CAAA;sBAA/B,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAA;gBAChB,IAAI,EAAA,CAAA;sBAAZ,KAAK;gBACG,MAAM,EAAA,CAAA;sBAAd,KAAK;gBACG,KAAK,EAAA,CAAA;sBAAb,KAAK;;;AEvBP;;AAEG;;;;"}
|
package/fesm2022/aril-ui.mjs
CHANGED
package/fesm2022/aril-ui.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aril-ui.mjs","sources":["../../projects/aril/ui/index.ts","../../projects/aril/ui/aril-ui.ts"],"sourcesContent":["export const aril_ui =
|
|
1
|
+
{"version":3,"file":"aril-ui.mjs","sources":["../../projects/aril/ui/index.ts","../../projects/aril/ui/aril-ui.ts"],"sourcesContent":["export const aril_ui = 'ARiL-UI';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"AAAO,MAAM,OAAO,GAAG;;ACAvB;;AAEG;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aril-util-init-event.mjs","sources":["../../projects/aril/util/init-event/src/init-event.directive.ts","../../projects/aril/util/init-event/aril-util-init-event.ts"],"sourcesContent":["import { Directive, EventEmitter, OnInit, Output } from '@angular/core';\
|
|
1
|
+
{"version":3,"file":"aril-util-init-event.mjs","sources":["../../projects/aril/util/init-event/src/init-event.directive.ts","../../projects/aril/util/init-event/aril-util-init-event.ts"],"sourcesContent":["import { Directive, EventEmitter, OnInit, Output } from '@angular/core';\n\n@Directive({\n\tstandalone: true,\n\tselector: '[arilInit]'\n})\nexport class InitEventDirective implements OnInit {\n\t@Output() arilInit: EventEmitter<never> = new EventEmitter<never>();\n\n\tngOnInit() {\n\t\tthis.arilInit.emit();\n\t}\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;MAMa,kBAAkB,CAAA;AAJ/B,IAAA,WAAA,GAAA;AAKW,QAAA,IAAA,CAAA,QAAQ,GAAwB,IAAI,YAAY,EAAS,CAAC;AAKpE,KAAA;IAHA,QAAQ,GAAA;AACP,QAAA,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;KACrB;8GALW,kBAAkB,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA,EAAA;kGAAlB,kBAAkB,EAAA,YAAA,EAAA,IAAA,EAAA,QAAA,EAAA,YAAA,EAAA,OAAA,EAAA,EAAA,QAAA,EAAA,UAAA,EAAA,EAAA,QAAA,EAAA,EAAA,EAAA,CAAA,CAAA,EAAA;;2FAAlB,kBAAkB,EAAA,UAAA,EAAA,CAAA;kBAJ9B,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACV,oBAAA,UAAU,EAAE,IAAI;AAChB,oBAAA,QAAQ,EAAE,YAAY;AACtB,iBAAA,CAAA;8BAEU,QAAQ,EAAA,CAAA;sBAAjB,MAAM;;;ACPR;;AAEG;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"aril-util-lib.mjs","sources":["../../projects/aril/util/lib/src/types.ts","../../projects/aril/util/lib/src/interfaces.ts","../../projects/aril/util/lib/aril-util-lib.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\
|
|
1
|
+
{"version":3,"file":"aril-util-lib.mjs","sources":["../../projects/aril/util/lib/src/types.ts","../../projects/aril/util/lib/src/interfaces.ts","../../projects/aril/util/lib/aril-util-lib.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/ban-types */\n/* eslint-disable @typescript-eslint/no-namespace */\n\nimport { InputSignal } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\n\nexport namespace Types {\n\ttype MarkComponentProps<Component> = {\n\t\t[Key in keyof Component]: Component[Key] extends Function ? never : Key;\n\t};\n\ttype KeyOfComponentProps<T> = MarkComponentProps<T>[keyof T];\n\ttype ComponentProps<T> = Pick<T, KeyOfComponentProps<T>>;\n\texport type NgChanges<Component, Props = ComponentProps<Component>> = {\n\t\t[Key in keyof Props]: {\n\t\t\tpreviousValue: Props[Key];\n\t\t\tcurrentValue: Props[Key];\n\t\t\tfirstChange: boolean;\n\t\t\tisFirstChange(): boolean;\n\t\t};\n\t};\n\n\texport type IsArray<T> = T extends (infer U)[] ? U : never;\n\n\texport type ControlsOf<T extends Record<string, any>> = {\n\t\t[K in keyof T]: T[K] extends Record<any, any> ?\n\t\t\tT[K] extends any[] ?\n\t\t\t\tFormControl<T[K] | null>\n\t\t\t:\tFormGroup<ControlsOf<T[K]>>\n\t\t:\tFormControl<T[K] | null>;\n\t};\n\n\ttype Enumerate<N extends number, Acc extends number[] = []> =\n\t\tAcc['length'] extends N ? Acc[number] : Enumerate<N, [...Acc, Acc['length']]>;\n\n\texport type NumberRange<F extends number, T extends number> = Exclude<Enumerate<T>, Enumerate<F>>;\n\n\texport type ComponentInputs<C> = {\n\t\t[K in keyof Pick<\n\t\t\tC,\n\t\t\t{\n\t\t\t\t[K in keyof C]: C[K] extends InputSignal<any> ? K : never;\n\t\t\t}[keyof C]\n\t\t>]: C[K] extends InputSignal<infer _, infer Write> ? Write : never;\n\t};\n}\n","/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/no-namespace */\n\nexport namespace Interfaces {\n\texport interface MapStringString {\n\t\t[key: string]: string;\n\t}\n\texport interface MapStringNumber {\n\t\t[key: string]: number;\n\t}\n\texport interface MapStringBoolean {\n\t\t[key: string]: boolean;\n\t}\n\texport interface MapStringObject<T> {\n\t\t[key: string]: T;\n\t}\n\texport interface MapStringAny {\n\t\t[key: string]: any;\n\t}\n\texport interface MapNumberString {\n\t\t[key: number]: string;\n\t}\n\texport interface MapNumberNumber {\n\t\t[key: number]: number;\n\t}\n\texport interface MapNumberBoolean {\n\t\t[key: number]: boolean;\n\t}\n\texport interface MapNumberObject<T> {\n\t\t[key: number]: T;\n\t}\n\texport interface MapNumberArray<T> {\n\t\t[key: number]: Array<T>;\n\t}\n\texport interface MapNumberAny {\n\t\t[key: number]: any;\n\t}\n\texport interface MapEnums {\n\t\t[key: number]: MapStringString;\n\t}\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"AAAA;AACA;AACA;AACA;;ACHA;AACA;;ACDA;;AAEG"}
|
|
@@ -5,49 +5,70 @@ Date.prototype.dateToString = function (format) {
|
|
|
5
5
|
if (!this || !this.getTime || isNaN(this.getTime()))
|
|
6
6
|
return undefined;
|
|
7
7
|
switch (format) {
|
|
8
|
-
case
|
|
9
|
-
format =
|
|
8
|
+
case 'hour':
|
|
9
|
+
format = 'hh:mm';
|
|
10
10
|
break;
|
|
11
|
-
case
|
|
12
|
-
format =
|
|
11
|
+
case 'time':
|
|
12
|
+
format = 'dd/MMMM/yyyy hh:mm';
|
|
13
13
|
break;
|
|
14
|
-
case
|
|
15
|
-
format =
|
|
14
|
+
case 'second':
|
|
15
|
+
format = 'dd/MMMM/yyyy hh:mm:ss';
|
|
16
16
|
break;
|
|
17
|
-
case
|
|
18
|
-
format =
|
|
17
|
+
case 'minute':
|
|
18
|
+
format = 'dd/MMMM/yyyy hh:mm';
|
|
19
19
|
break;
|
|
20
|
-
case
|
|
21
|
-
format =
|
|
20
|
+
case 'day':
|
|
21
|
+
format = 'dd/MMMM/yyyy';
|
|
22
22
|
break;
|
|
23
|
-
case
|
|
24
|
-
format =
|
|
23
|
+
case 'onlyDay':
|
|
24
|
+
format = 'dd';
|
|
25
25
|
break;
|
|
26
|
-
case
|
|
27
|
-
format =
|
|
26
|
+
case 'month':
|
|
27
|
+
format = 'MMMM/yyyy';
|
|
28
28
|
break;
|
|
29
|
-
case
|
|
30
|
-
format =
|
|
29
|
+
case 'monthInt':
|
|
30
|
+
format = 'MM/yyyy';
|
|
31
31
|
break;
|
|
32
|
-
case
|
|
33
|
-
format =
|
|
32
|
+
case 'onlyMonth':
|
|
33
|
+
format = 'MMMM';
|
|
34
34
|
break;
|
|
35
|
-
case
|
|
36
|
-
format =
|
|
35
|
+
case 'year':
|
|
36
|
+
format = 'yyyy';
|
|
37
37
|
break;
|
|
38
38
|
default:
|
|
39
|
-
format = format ? format :
|
|
39
|
+
format = format ? format : 'dd/MMMM/yyyy';
|
|
40
40
|
break;
|
|
41
41
|
}
|
|
42
|
-
const months = [
|
|
42
|
+
const months = [
|
|
43
|
+
'Ocak',
|
|
44
|
+
'Şubat',
|
|
45
|
+
'Mart',
|
|
46
|
+
'Nisan',
|
|
47
|
+
'Mayıs',
|
|
48
|
+
'Haziran',
|
|
49
|
+
'Temmuz',
|
|
50
|
+
'Ağustos',
|
|
51
|
+
'Eylül',
|
|
52
|
+
'Ekim',
|
|
53
|
+
'Kasım',
|
|
54
|
+
'Aralık'
|
|
55
|
+
];
|
|
43
56
|
const year = this.getFullYear().toString();
|
|
44
|
-
const month = this.getMonth() >= 9 ? (this.getMonth() + 1).toString() :
|
|
57
|
+
const month = this.getMonth() >= 9 ? (this.getMonth() + 1).toString() : '0' + (this.getMonth() + 1).toString();
|
|
45
58
|
const monthText = months[this.getMonth()];
|
|
46
|
-
const day = this.getDate() > 9 ? this.getDate().toString() :
|
|
47
|
-
const hour = this.getHours() > 9 ? this.getHours().toString() :
|
|
48
|
-
const minute = this.getMinutes() > 9 ? this.getMinutes().toString() :
|
|
49
|
-
const second = this.getSeconds() > 9 ? this.getSeconds().toString() :
|
|
50
|
-
const dictionary = {
|
|
59
|
+
const day = this.getDate() > 9 ? this.getDate().toString() : '0' + this.getDate().toString();
|
|
60
|
+
const hour = this.getHours() > 9 ? this.getHours().toString() : '0' + this.getHours().toString();
|
|
61
|
+
const minute = this.getMinutes() > 9 ? this.getMinutes().toString() : '0' + this.getMinutes().toString();
|
|
62
|
+
const second = this.getSeconds() > 9 ? this.getSeconds().toString() : '0' + this.getSeconds().toString();
|
|
63
|
+
const dictionary = {
|
|
64
|
+
dd: day,
|
|
65
|
+
hh: hour,
|
|
66
|
+
mm: minute,
|
|
67
|
+
ss: second,
|
|
68
|
+
yyyy: year,
|
|
69
|
+
MMMM: monthText,
|
|
70
|
+
MM: month
|
|
71
|
+
};
|
|
51
72
|
let result = format;
|
|
52
73
|
for (const i in dictionary) {
|
|
53
74
|
result = result.replace(i, dictionary[i]);
|
|
@@ -58,35 +79,35 @@ Date.prototype.dateToLong = function (zoomLevel) {
|
|
|
58
79
|
if (!this || !this.getFullYear)
|
|
59
80
|
return undefined;
|
|
60
81
|
const year = this.getFullYear().toString();
|
|
61
|
-
const month = this.getMonth() >= 9 ? (this.getMonth() + 1).toString() :
|
|
62
|
-
const day = this.getDate() > 9 ? this.getDate().toString() :
|
|
63
|
-
const hour = this.getHours() > 9 ? this.getHours().toString() :
|
|
64
|
-
const minute = this.getMinutes() > 9 ? this.getMinutes().toString() :
|
|
65
|
-
const second = this.getSeconds() > 9 ? this.getSeconds().toString() :
|
|
82
|
+
const month = this.getMonth() >= 9 ? (this.getMonth() + 1).toString() : '0' + (this.getMonth() + 1).toString();
|
|
83
|
+
const day = this.getDate() > 9 ? this.getDate().toString() : '0' + this.getDate().toString();
|
|
84
|
+
const hour = this.getHours() > 9 ? this.getHours().toString() : '0' + this.getHours().toString();
|
|
85
|
+
const minute = this.getMinutes() > 9 ? this.getMinutes().toString() : '0' + this.getMinutes().toString();
|
|
86
|
+
const second = this.getSeconds() > 9 ? this.getSeconds().toString() : '0' + this.getSeconds().toString();
|
|
66
87
|
let result;
|
|
67
88
|
if (!zoomLevel)
|
|
68
|
-
zoomLevel =
|
|
89
|
+
zoomLevel = 'day';
|
|
69
90
|
switch (zoomLevel) {
|
|
70
|
-
case
|
|
91
|
+
case 'time':
|
|
71
92
|
result = year + month + day + hour + minute + second;
|
|
72
93
|
break;
|
|
73
|
-
case
|
|
74
|
-
result = year + month + day + hour + minute +
|
|
94
|
+
case 'minute':
|
|
95
|
+
result = year + month + day + hour + minute + '00';
|
|
75
96
|
break;
|
|
76
|
-
case
|
|
77
|
-
result = year + month + day + hour +
|
|
97
|
+
case 'hour':
|
|
98
|
+
result = year + month + day + hour + '0000';
|
|
78
99
|
break;
|
|
79
|
-
case
|
|
80
|
-
result = year + month + day +
|
|
100
|
+
case 'day':
|
|
101
|
+
result = year + month + day + '000000';
|
|
81
102
|
break;
|
|
82
|
-
case
|
|
83
|
-
result = year + month +
|
|
103
|
+
case 'month':
|
|
104
|
+
result = year + month + '01000000';
|
|
84
105
|
break;
|
|
85
|
-
case
|
|
86
|
-
result = year +
|
|
106
|
+
case 'year':
|
|
107
|
+
result = year + '0101000000';
|
|
87
108
|
break;
|
|
88
109
|
default:
|
|
89
|
-
result = year + month + day +
|
|
110
|
+
result = year + month + day + '000000';
|
|
90
111
|
break;
|
|
91
112
|
}
|
|
92
113
|
return result;
|
|
@@ -95,11 +116,17 @@ Date.prototype.dateToLong = function (zoomLevel) {
|
|
|
95
116
|
Number.prototype.safeBool = function () {
|
|
96
117
|
return !!this;
|
|
97
118
|
};
|
|
98
|
-
Number.prototype.isNull = function () {
|
|
99
|
-
|
|
100
|
-
|
|
119
|
+
Number.prototype.isNull = function () {
|
|
120
|
+
return this === null;
|
|
121
|
+
};
|
|
122
|
+
Number.prototype.isUndefined = function () {
|
|
123
|
+
return this === undefined;
|
|
124
|
+
};
|
|
125
|
+
Number.prototype.isNullOrUndefined = function () {
|
|
126
|
+
return this.isNull() || this.isUndefined();
|
|
127
|
+
};
|
|
101
128
|
Number.prototype.longToDate = function () {
|
|
102
|
-
if (!this || this.toString() ==
|
|
129
|
+
if (!this || this.toString() == '0')
|
|
103
130
|
return undefined;
|
|
104
131
|
const str = this.toString();
|
|
105
132
|
const year = str.substring(0, 4);
|
|
@@ -108,10 +135,10 @@ Number.prototype.longToDate = function () {
|
|
|
108
135
|
const hour = str.substring(8, 10);
|
|
109
136
|
const min = str.substring(10, 12);
|
|
110
137
|
const sn = str.substring(12, 14);
|
|
111
|
-
return new Date(year +
|
|
138
|
+
return new Date(year + '-' + month + '-' + day + ' ' + hour + ':' + min + ':' + sn);
|
|
112
139
|
};
|
|
113
140
|
Number.prototype.longToString = function (format) {
|
|
114
|
-
if (!this || this.toString() ==
|
|
141
|
+
if (!this || this.toString() == '0')
|
|
115
142
|
return undefined;
|
|
116
143
|
return this.longToDate()?.dateToString(format);
|
|
117
144
|
};
|
|
@@ -128,19 +155,19 @@ String.prototype.safeBool = function () {
|
|
|
128
155
|
return !!this;
|
|
129
156
|
};
|
|
130
157
|
String.prototype.escapeRegExp = function () {
|
|
131
|
-
return this.replace(/[.*+?^${}()|[\]\\]/g,
|
|
158
|
+
return this.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
132
159
|
};
|
|
133
160
|
String.prototype.toCamelCase = function () {
|
|
134
161
|
return this.replace(/(?:^\w|[A-Z]|-|\b\w)/g, (character, index) => index === 0 ? character.toLocaleLowerCase() : character.toLocaleUpperCase());
|
|
135
162
|
};
|
|
136
163
|
String.prototype.toPascalCase = function () {
|
|
137
|
-
return this.replace(/(?:^\w|[A-Z]|-|\b\w)/g, firstCharacter => firstCharacter.toLocaleUpperCase());
|
|
164
|
+
return this.replace(/(?:^\w|[A-Z]|-|\b\w)/g, (firstCharacter) => firstCharacter.toLocaleUpperCase());
|
|
138
165
|
};
|
|
139
166
|
String.prototype.toCapitalizeFirstLetter = function () {
|
|
140
167
|
return this.charAt(0).toLocaleUpperCase() + this.slice(1);
|
|
141
168
|
};
|
|
142
169
|
String.prototype.stringToBool = function (str) {
|
|
143
|
-
if (str ==
|
|
170
|
+
if (str == 'true' || str == '1')
|
|
144
171
|
return true;
|
|
145
172
|
else
|
|
146
173
|
return false;
|