@simitgroup/simpleapp-generator 1.6.6-i-alpha → 1.6.6-k-alpha
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/ReleaseNote.md +7 -0
- package/dist/buildinschemas/docnoformat.js +6 -6
- package/dist/buildinschemas/docnoformat.js.map +1 -1
- package/dist/buildinschemas/documentevent.js +1 -1
- package/dist/buildinschemas/documentevent.js.map +1 -1
- package/dist/buildinschemas/organization.js +1 -1
- package/dist/buildinschemas/organization.js.map +1 -1
- package/dist/buildinschemas/tenant.js +1 -1
- package/dist/buildinschemas/tenant.js.map +1 -1
- package/dist/buildinschemas/user.js +2 -2
- package/dist/buildinschemas/user.js.map +1 -1
- package/dist/buildinschemas/webhook.d.ts.map +1 -1
- package/dist/buildinschemas/webhook.js +1 -0
- package/dist/buildinschemas/webhook.js.map +1 -1
- package/dist/framework.d.ts.map +1 -1
- package/dist/framework.js +30 -3
- package/dist/framework.js.map +1 -1
- package/dist/generate.d.ts.map +1 -1
- package/dist/generate.js +21 -20
- package/dist/generate.js.map +1 -1
- package/dist/index.js +0 -0
- package/dist/processors/jrxmlbuilder.js +3 -3
- package/dist/processors/jrxmlbuilder.js.map +1 -1
- package/dist/processors/jsonschemabuilder.d.ts.map +1 -1
- package/dist/processors/jsonschemabuilder.js +17 -10
- package/dist/processors/jsonschemabuilder.js.map +1 -1
- package/dist/type.d.ts +1 -1
- package/dist/type.d.ts.map +1 -1
- package/package.json +2 -3
- package/reset-install.sh +3 -0
- package/src/buildinschemas/docnoformat.ts +6 -6
- package/src/buildinschemas/documentevent.ts +1 -1
- package/src/buildinschemas/organization.ts +1 -1
- package/src/buildinschemas/tenant.ts +1 -1
- package/src/buildinschemas/user.ts +2 -2
- package/src/buildinschemas/webhook.ts +1 -0
- package/src/framework.ts +33 -5
- package/src/generate.ts +22 -20
- package/src/processors/jrxmlbuilder.ts +3 -3
- package/src/processors/jsonschemabuilder.ts +27 -14
- package/src/type.ts +1 -1
- package/templates/basic/nest/controller.ts.eta +6 -5
- package/templates/basic/nest/resolver.ts.eta +4 -2
- package/templates/basic/nest/service.ts.eta +5 -2
- package/templates/basic/nuxt/simpleapp.generate.client.ts.eta +3 -3
- package/templates/nest/.gitignore.eta +4 -5
- package/templates/nest/src/{app.module.ts.eta → app.module.ts._eta} +2 -2
- package/templates/nest/src/{main.ts.eta → main.ts._eta} +2 -2
- package/templates/nest/src/printapi/printapi.service.ts.eta +7 -8
- package/templates/nest/src/simpleapp/.gitignore.eta +1 -1
- package/templates/nest/src/simpleapp/generate/commons/audittrail.service.ts.eta +2 -2
- package/templates/nest/src/simpleapp/generate/commons/customkeycloa.guard.ts.eta +14 -12
- package/templates/nest/src/simpleapp/generate/commons/customkeycloak.guard.ts.eta +36 -42
- package/templates/nest/src/simpleapp/generate/commons/docnogenerator.service.ts.eta +6 -3
- package/templates/nest/src/simpleapp/generate/commons/encryption.static.ts.eta +56 -61
- package/templates/nest/src/simpleapp/generate/commons/middlewares/tenant.middleware.ts.eta +65 -88
- package/templates/nest/src/simpleapp/generate/commons/robotuser.service.ts.eta +10 -9
- package/templates/nest/src/simpleapp/generate/commons/roles/roles.guard.ts.eta +10 -3
- package/templates/nest/src/simpleapp/generate/commons/runwebhook.service.ts.eta +71 -77
- package/templates/nest/src/simpleapp/generate/commons/user.context.ts.eta +439 -293
- package/templates/nest/src/simpleapp/generate/processors/autoinc.processor.ts.eta +20 -5
- package/templates/nest/src/simpleapp/generate/processors/simpleapp.processor.ts.eta +423 -38
- package/templates/nest/src/simpleapp/profile/{profile.controller.ts.eta → profile.controller.ts._eta} +2 -2
- package/templates/nest/src/simpleapp/profile/{profile.service.ts.eta → profile.service.ts._eta} +2 -2
- package/templates/nest/src/simpleapp/simpleapp.module.ts.eta +15 -4
- package/templates/nuxt/assets/css/style.css._eta +74 -28
- package/templates/nuxt/components/button/ButtonMultiple.vue._eta +1 -1
- package/templates/nuxt/components/calendar/{CalendarByResource.vue.eta → CalendarByResource.vue._eta} +2 -2
- package/templates/nuxt/components/calendar/{CalendarInput.vue.eta → CalendarInput.vue._eta} +3 -3
- package/templates/nuxt/components/calendar/{CalendarSmall.vue.eta → CalendarSmall.vue._eta} +13 -7
- package/templates/nuxt/components/debug/{DebugDocumentData.vue.eta → DebugDocumentData.vue._eta} +4 -5
- package/templates/nuxt/components/form/{FormDocnoformat.vue.eta → FormDocnoformat.vue._eta} +2 -1
- package/templates/nuxt/components/form/user/{FormUserPermission.vue.eta → FormUserPermission.vue._eta} +6 -0
- package/templates/nuxt/components/header/{HeaderBreadcrumb.vue.eta → HeaderBreadcrumb.vue._eta} +5 -5
- package/templates/nuxt/components/header/button/{HeaderButtonProfile.vue.eta → HeaderButtonProfile.vue._eta} +2 -2
- package/templates/nuxt/components/header/button/task/{HeaderButtonTaskList.vue.eta → HeaderButtonTaskList.vue._eta} +4 -4
- package/templates/nuxt/components/image/ImageAvatar.vue.eta +56 -0
- package/templates/nuxt/components/image/{ImageOrganization.vue.eta.vue → ImageOrganization.vue.eta} +15 -9
- package/templates/nuxt/components/image/{ImageToBase64Uploader.vue.eta.vue → ImageToBase64Uploader.vue.eta} +28 -18
- package/templates/nuxt/components/list/{ListDocumentTable.vue.eta → ListDocumentTable.vue._eta} +3 -3
- package/templates/nuxt/components/list/{ListItem.vue.eta → ListItem.vue._eta} +2 -2
- package/templates/nuxt/components/list/{ListMessages.vue.eta → ListMessages.vue._eta} +8 -2
- package/templates/nuxt/components/list/{ListView.vue.eta → ListView.vue._eta} +2 -2
- package/templates/nuxt/components/overlay/{OverlayPanelWithToolBar.vue.eta → OverlayPanelWithToolBar.vue._eta} +5 -5
- package/templates/nuxt/components/overlay/{OverlaySideBarCrud.vue.eta → OverlaySideBarCrud.vue._eta} +4 -4
- package/templates/nuxt/components/overlay/{OverlayViewer.vue.eta → OverlayViewer.vue._eta} +2 -2
- package/templates/nuxt/components/page/{PageDocList.vue.eta → PageDocList.vue._eta} +5 -5
- package/templates/nuxt/components/renderer/RendererDateAge.vue.eta +19 -0
- package/templates/nuxt/components/renderer/{RendererDateTime.vue.eta → RendererDateTime.vue._eta} +2 -2
- package/templates/nuxt/components/renderer/{RendererDocHistories.vue.eta → RendererDocHistories.vue._eta} +6 -0
- package/templates/nuxt/components/renderer/{RendererForeignKey.vue.eta → RendererForeignKey.vue._eta} +2 -2
- package/templates/nuxt/components/renderer/{RendererLink.vue.eta → RendererLink.vue._eta} +2 -2
- package/templates/nuxt/components/renderer/{RendererTime.vue.eta → RendererTime.vue._eta} +2 -2
- package/templates/nuxt/components/renderer/{RendererViewer.vue.eta → RendererViewer.vue._eta} +2 -2
- package/templates/nuxt/components/select/{SelectTemplate.vue.eta → SelectTemplate.vue._eta} +2 -2
- package/templates/nuxt/components/session/{SessionBlock.vue.eta → SessionBlock.vue._eta} +2 -2
- package/templates/nuxt/components/simpleApp/SimpleAppAutocomplete.vue.eta +55 -55
- package/templates/nuxt/components/simpleApp/SimpleAppCalendarInput.vue.eta +13 -11
- package/templates/nuxt/components/simpleApp/SimpleAppChildrenList.vue.eta +6 -3
- package/templates/nuxt/components/simpleApp/SimpleAppDocumentNo.vue.eta +33 -28
- package/templates/nuxt/components/simpleApp/SimpleAppFieldContainer.vue.eta +19 -28
- package/templates/nuxt/components/simpleApp/SimpleAppInput.vue.eta +113 -105
- package/templates/nuxt/components/simpleApp/SimpleAppInputTable.vue.eta +3 -3
- package/templates/nuxt/components/simpleApp/SimpleAppJsonSchemaForm.vue.eta +3 -16
- package/templates/nuxt/components/simpleApp/SimpleAppUserPicker.vue.eta +10 -12
- package/templates/nuxt/components/table/{TableDocuments.vue.eta → TableDocuments.vue._eta} +2 -2
- package/templates/nuxt/components/user/{UserButtonPermissionInfo.vue.eta → UserButtonPermissionInfo.vue._eta} +4 -4
- package/templates/nuxt/components/user/{UserInvitation.vue.eta → UserInvitation.vue._eta} +2 -2
- package/templates/nuxt/components/user/{UserProfileListItem.vue.eta → UserProfileListItem.vue._eta} +2 -2
- package/templates/nuxt/components/user/{UserTenantPicker.vue.eta → UserTenantPicker.vue._eta} +2 -2
- package/templates/nuxt/composables/getOpenApi.generate.ts.eta +11 -3
- package/templates/nuxt/composables/getUserStore.generate.ts.eta +1 -1
- package/templates/nuxt/composables/graphquery.generate.ts.eta +1 -1
- package/templates/nuxt/composables/recently.generate.ts.eta +0 -1
- package/templates/nuxt/composables/stringHelper.generate.ts.eta +5 -2
- package/templates/nuxt/nuxt.config.ts._eta +6 -5
- package/templates/nuxt/pages/[xorg]/docnoformat/[id].vue.eta +0 -1
- package/templates/nuxt/pages/[xorg]/{docnoformat.vue.eta → docnoformat.vue._eta} +1 -0
- package/templates/nuxt/pages/[xorg]/organization/[id].vue.eta +13 -9
- package/templates/nuxt/pages/[xorg]/organization/new.vue.eta +10 -12
- package/templates/nuxt/pages/[xorg]/{user.vue.eta → user.vue._eta} +2 -2
- package/templates/nuxt/pages/index.vue._eta +1 -1
- package/templates/nuxt/pages/{profile.vue.eta → profile.vue._eta} +2 -2
- package/templates/nuxt/plugins/10.simpleapp-event.ts.eta +6 -0
- package/templates/nuxt/plugins/20.simpleapp-userstore.ts.eta +89 -12
- package/templates/nuxt/plugins/40.pusher.ts.eta +8 -5
- package/templates/nuxt/presets/lara/accordion/index.js +79 -0
- package/templates/nuxt/presets/lara/accordioncontent/index.js +3 -0
- package/templates/nuxt/presets/lara/accordionheader/index.js +11 -0
- package/templates/nuxt/presets/lara/accordionpanel/index.js +18 -0
- package/templates/nuxt/presets/lara/autocomplete/index.js +208 -0
- package/templates/nuxt/presets/lara/avatar/index.js +43 -0
- package/templates/nuxt/presets/lara/avatargroup/index.js +5 -0
- package/templates/nuxt/presets/lara/badge/index.js +47 -0
- package/templates/nuxt/presets/lara/badgedirective/index.js +43 -0
- package/templates/nuxt/presets/lara/blockui/index.js +4 -0
- package/templates/nuxt/presets/lara/breadcrumb/index.js +64 -0
- package/templates/nuxt/presets/lara/button/index.js +238 -0
- package/templates/nuxt/presets/lara/buttongroup/index.js +12 -0
- package/templates/nuxt/presets/lara/card/index.js +37 -0
- package/templates/nuxt/presets/lara/carousel/index.js +103 -0
- package/templates/nuxt/presets/lara/cascadeselect/index.js +199 -0
- package/templates/nuxt/presets/lara/checkbox/index.js +104 -0
- package/templates/nuxt/presets/lara/chip/index.js +42 -0
- package/templates/nuxt/presets/lara/colorpicker/index.js +123 -0
- package/templates/nuxt/presets/lara/confirmdialog/index.js +3 -0
- package/templates/nuxt/presets/lara/confirmpopup/index.js +56 -0
- package/templates/nuxt/presets/lara/contextmenu/index.js +126 -0
- package/templates/nuxt/presets/lara/datatable/index.js +403 -0
- package/templates/nuxt/presets/lara/dataview/index.js +28 -0
- package/templates/nuxt/presets/lara/datepicker/index.js +435 -0
- package/templates/nuxt/presets/lara/deferred/index.js +3 -0
- package/templates/nuxt/presets/lara/dialog/index.js +148 -0
- package/templates/nuxt/presets/lara/divider/index.js +67 -0
- package/templates/nuxt/presets/lara/dock/index.js +86 -0
- package/templates/nuxt/presets/lara/drawer/index.js +149 -0
- package/templates/nuxt/presets/lara/fieldset/index.js +84 -0
- package/templates/nuxt/presets/lara/fileupload/index.js +95 -0
- package/templates/nuxt/presets/lara/floatlabel/index.js +26 -0
- package/templates/nuxt/presets/lara/galleria/index.js +308 -0
- package/templates/nuxt/presets/lara/global.js +90 -0
- package/templates/nuxt/presets/lara/iconfield/index.js +27 -0
- package/templates/nuxt/presets/lara/image/index.js +206 -0
- package/templates/nuxt/presets/lara/index.js +234 -0
- package/templates/nuxt/presets/lara/inplace/index.js +27 -0
- package/templates/nuxt/presets/lara/inputgroup/index.js +5 -0
- package/templates/nuxt/presets/lara/inputgroupaddon/index.js +28 -0
- package/templates/nuxt/presets/lara/inputmask/index.js +39 -0
- package/templates/nuxt/presets/lara/inputnumber/index.js +167 -0
- package/templates/nuxt/presets/lara/inputotp/index.js +10 -0
- package/templates/nuxt/presets/lara/inputswitch/index.js +80 -0
- package/templates/nuxt/presets/lara/inputtext/index.js +54 -0
- package/templates/nuxt/presets/lara/knob/index.js +44 -0
- package/templates/nuxt/presets/lara/listbox/index.js +117 -0
- package/templates/nuxt/presets/lara/megamenu/index.js +198 -0
- package/templates/nuxt/presets/lara/menu/index.js +96 -0
- package/templates/nuxt/presets/lara/menubar/index.js +176 -0
- package/templates/nuxt/presets/lara/message/index.js +92 -0
- package/templates/nuxt/presets/lara/metergroup/index.js +96 -0
- package/templates/nuxt/presets/lara/multiselect/index.js +201 -0
- package/templates/nuxt/presets/lara/orderlist/index.js +13 -0
- package/templates/nuxt/presets/lara/organizationchart/index.js +137 -0
- package/templates/nuxt/presets/lara/overlaybadge/index.js +18 -0
- package/templates/nuxt/presets/lara/paginator/index.js +178 -0
- package/templates/nuxt/presets/lara/panel/index.js +91 -0
- package/templates/nuxt/presets/lara/panelmenu/index.js +127 -0
- package/templates/nuxt/presets/lara/password/index.js +72 -0
- package/templates/nuxt/presets/lara/picklist/index.js +52 -0
- package/templates/nuxt/presets/lara/popover/index.js +31 -0
- package/templates/nuxt/presets/lara/progressbar/index.js +55 -0
- package/templates/nuxt/presets/lara/progressspinner/index.js +51 -0
- package/templates/nuxt/presets/lara/radiobutton/index.js +104 -0
- package/templates/nuxt/presets/lara/rating/index.js +63 -0
- package/templates/nuxt/presets/lara/ripple/index.js +6 -0
- package/templates/nuxt/presets/lara/scrollpanel/index.js +77 -0
- package/templates/nuxt/presets/lara/scrolltop/index.js +26 -0
- package/templates/nuxt/presets/lara/select/index.js +240 -0
- package/templates/nuxt/presets/lara/selectbutton/index.js +16 -0
- package/templates/nuxt/presets/lara/skeleton/index.js +16 -0
- package/templates/nuxt/presets/lara/slider/index.js +137 -0
- package/templates/nuxt/presets/lara/speeddial/index.js +57 -0
- package/templates/nuxt/presets/lara/splitbutton/index.js +19 -0
- package/templates/nuxt/presets/lara/splitter/index.js +61 -0
- package/templates/nuxt/presets/lara/splitterpanel/index.js +5 -0
- package/templates/nuxt/presets/lara/step/index.js +62 -0
- package/templates/nuxt/presets/lara/stepitem/index.js +11 -0
- package/templates/nuxt/presets/lara/steplist/index.js +3 -0
- package/templates/nuxt/presets/lara/steppanels/index.js +3 -0
- package/templates/nuxt/presets/lara/stepper/index.js +13 -0
- package/templates/nuxt/presets/lara/steps/index.js +111 -0
- package/templates/nuxt/presets/lara/tab/index.js +42 -0
- package/templates/nuxt/presets/lara/tablist/index.js +8 -0
- package/templates/nuxt/presets/lara/tabmenu/index.js +73 -0
- package/templates/nuxt/presets/lara/tabpanel/index.js +3 -0
- package/templates/nuxt/presets/lara/tabpanels/index.js +3 -0
- package/templates/nuxt/presets/lara/tabs/index.js +5 -0
- package/templates/nuxt/presets/lara/tabview/index.js +156 -0
- package/templates/nuxt/presets/lara/tag/index.js +38 -0
- package/templates/nuxt/presets/lara/terminal/index.js +60 -0
- package/templates/nuxt/presets/lara/textarea/index.js +39 -0
- package/templates/nuxt/presets/lara/tieredmenu/index.js +121 -0
- package/templates/nuxt/presets/lara/timeline/index.js +81 -0
- package/templates/nuxt/presets/lara/toast/index.js +102 -0
- package/templates/nuxt/presets/lara/togglebutton/index.js +45 -0
- package/templates/nuxt/presets/lara/toggleswitch/index.js +80 -0
- package/templates/nuxt/presets/lara/toolbar/index.js +28 -0
- package/templates/nuxt/presets/lara/tooltip/index.js +46 -0
- package/templates/nuxt/presets/lara/tree/index.js +101 -0
- package/templates/nuxt/presets/lara/treeselect/index.js +102 -0
- package/templates/nuxt/presets/lara/treetable/index.js +305 -0
- package/templates/nuxt/providers/my-provider.ts.eta +1 -1
- package/templates/nuxt/server/api/profile/[...].ts.eta +4 -3
- package/templates/nuxt/simpleapp/generate/clients/SimpleAppClient.ts.eta +10 -20
- package/templates/nuxt/tailwind.config.ts._eta +4 -15
- package/templates/nuxt/types/schema.ts.eta +1 -1
- package/templates/nuxt/types/user.ts.eta +6 -1
- package/templates/project/jsonschemas/appintegration.json_eta +227 -0
- package/templates/project/sharelibs/validate.ts.eta +23 -0
- package/templates/nuxt/components/image/ImageAvatar.vue.eta._vue +0 -57
package/templates/nuxt/components/overlay/{OverlaySideBarCrud.vue.eta → OverlaySideBarCrud.vue._eta}
RENAMED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<
|
|
2
|
+
<Drawer
|
|
3
3
|
position="right"
|
|
4
4
|
v-if="showDialog"
|
|
5
5
|
v-model:visible="showDialog"
|
|
@@ -16,12 +16,12 @@
|
|
|
16
16
|
<slot name="default"></slot>
|
|
17
17
|
</div>
|
|
18
18
|
</div>
|
|
19
|
-
</
|
|
19
|
+
</Drawer>
|
|
20
20
|
</template>
|
|
21
21
|
<script lang="ts" setup>
|
|
22
22
|
/**
|
|
23
|
-
* This file was automatically generated by simpleapp generator.
|
|
24
|
-
*
|
|
23
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
24
|
+
* --remove-this-line-to-prevent-override--
|
|
25
25
|
* last change 2023-10-28
|
|
26
26
|
* Author: Ks Tan
|
|
27
27
|
*/
|
|
@@ -24,8 +24,8 @@
|
|
|
24
24
|
</template>
|
|
25
25
|
<script lang="ts" setup>
|
|
26
26
|
/**
|
|
27
|
-
* This file was automatically generated by simpleapp generator.
|
|
28
|
-
*
|
|
27
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
28
|
+
* --remove-this-line-to-prevent-override--
|
|
29
29
|
* last change 2023-10-28
|
|
30
30
|
* Author: Ks Tan
|
|
31
31
|
*/
|
|
@@ -17,19 +17,19 @@
|
|
|
17
17
|
<ListDocument
|
|
18
18
|
v-if="recordlist"
|
|
19
19
|
@click="showDialogForm"
|
|
20
|
-
:recordlist="recordlist
|
|
20
|
+
:recordlist="recordlist"
|
|
21
21
|
:unique-key="uniqueKey"
|
|
22
22
|
:document-title="documentTitle"
|
|
23
23
|
>
|
|
24
24
|
<template #default="{ index, item }">
|
|
25
|
-
<slot name="mobileList" :index="index" :item="item
|
|
25
|
+
<slot name="mobileList" :index="index" :item="item"></slot>
|
|
26
26
|
</template>
|
|
27
27
|
</ListDocument>
|
|
28
28
|
</div>
|
|
29
29
|
<div v-else class="simpleapp-crudsimple">
|
|
30
30
|
<ListDocumentTable
|
|
31
31
|
v-if="recordlist"
|
|
32
|
-
:value="recordlist
|
|
32
|
+
:value="recordlist"
|
|
33
33
|
:title="doc.getDocName()"
|
|
34
34
|
:unique-key="<string>uniqueKey"
|
|
35
35
|
:document-title="<string>documentTitle"
|
|
@@ -142,8 +142,8 @@
|
|
|
142
142
|
|
|
143
143
|
<script setup lang="ts" generic="T extends { [key: string]: any }">
|
|
144
144
|
/**
|
|
145
|
-
* This file was automatically generated by simpleapp generator.
|
|
146
|
-
*
|
|
145
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
146
|
+
* --remove-this-line-to-prevent-override--
|
|
147
147
|
* last change 2023-10-28
|
|
148
148
|
* Author: Ks Tan
|
|
149
149
|
*/
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<span v-if="modelValue">
|
|
3
|
+
{{ getDayJs()().to(getDayJs()(modelValue)) }}
|
|
4
|
+
</span>
|
|
5
|
+
<span v-else-if="value">
|
|
6
|
+
{{ getDayJs()().to(getDayJs()(value)) }}
|
|
7
|
+
</span>
|
|
8
|
+
<span v-else>-</span>
|
|
9
|
+
</template>
|
|
10
|
+
<script lang="ts" setup>
|
|
11
|
+
/**
|
|
12
|
+
* This file was automatically generated by simpleapp generator during initialization.
|
|
13
|
+
* DONT CHANGE THIS FILE CAUSE IT OVERRIDE
|
|
14
|
+
* last change 2024-06-08
|
|
15
|
+
* author: Ks Tan
|
|
16
|
+
*/
|
|
17
|
+
const modelValue = defineModel<Date | string>();
|
|
18
|
+
const props = defineProps<{ value?: Date | string }>();
|
|
19
|
+
</script>
|
package/templates/nuxt/components/renderer/{RendererDateTime.vue.eta → RendererDateTime.vue._eta}
RENAMED
|
@@ -9,8 +9,8 @@
|
|
|
9
9
|
</template>
|
|
10
10
|
<script lang="ts" setup>
|
|
11
11
|
/**
|
|
12
|
-
* This file was automatically generated by simpleapp generator during initialization.
|
|
13
|
-
*
|
|
12
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
13
|
+
* --remove-this-line-to-prevent-override--
|
|
14
14
|
* last change 2024-03-10
|
|
15
15
|
* author: Ks Tan
|
|
16
16
|
*/
|
|
@@ -49,6 +49,12 @@
|
|
|
49
49
|
</div>
|
|
50
50
|
</template>
|
|
51
51
|
<script lang="ts" setup>
|
|
52
|
+
/**
|
|
53
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
54
|
+
* --remove-this-line-to-prevent-override--
|
|
55
|
+
* last change 2024-02-22
|
|
56
|
+
* author: Ks Tan
|
|
57
|
+
*/
|
|
52
58
|
import TextSubsubtitle from "../text/TextSubsubtitle.vue";
|
|
53
59
|
import RendererDateTime from "./RendererDateTime.vue";
|
|
54
60
|
import { Documentevent, User } from "~/simpleapp/generate/openapi";
|
|
@@ -12,8 +12,8 @@
|
|
|
12
12
|
</template>
|
|
13
13
|
<script setup lang="ts">
|
|
14
14
|
/**
|
|
15
|
-
* This file was automatically generated by simpleapp generator during initialization.
|
|
16
|
-
*
|
|
15
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
16
|
+
* --remove-this-line-to-prevent-override--
|
|
17
17
|
* last change 2024-04-14
|
|
18
18
|
* author: Ks Tan
|
|
19
19
|
*/
|
|
@@ -10,8 +10,8 @@
|
|
|
10
10
|
</template>
|
|
11
11
|
<script setup lang="ts">
|
|
12
12
|
/**
|
|
13
|
-
* This file was automatically generated by simpleapp generator during initialization.
|
|
14
|
-
*
|
|
13
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
14
|
+
* --remove-this-line-to-prevent-override--
|
|
15
15
|
* last change 2024-02-04
|
|
16
16
|
* author: Ks Tan
|
|
17
17
|
*/
|
|
@@ -9,8 +9,8 @@
|
|
|
9
9
|
</template>
|
|
10
10
|
<script lang="ts" setup>
|
|
11
11
|
/**
|
|
12
|
-
* This file was automatically generated by simpleapp generator during initialization.
|
|
13
|
-
*
|
|
12
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
13
|
+
* --remove-this-line-to-prevent-override--
|
|
14
14
|
* last change 2024-04-14
|
|
15
15
|
* author: Ks Tan
|
|
16
16
|
*/
|
package/templates/nuxt/components/renderer/{RendererViewer.vue.eta → RendererViewer.vue._eta}
RENAMED
|
@@ -15,8 +15,8 @@
|
|
|
15
15
|
</template>
|
|
16
16
|
<script setup lang="ts">
|
|
17
17
|
/**
|
|
18
|
-
* This file was automatically generated by simpleapp generator during initialization.
|
|
19
|
-
*
|
|
18
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
19
|
+
* --remove-this-line-to-prevent-override--
|
|
20
20
|
* last change 2024-02-04
|
|
21
21
|
* author: Ks Tan
|
|
22
22
|
*/
|
|
@@ -64,8 +64,8 @@
|
|
|
64
64
|
</template>
|
|
65
65
|
<script setup lang="ts">
|
|
66
66
|
/**
|
|
67
|
-
* This file was automatically generated by simpleapp generator.
|
|
68
|
-
*
|
|
67
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
68
|
+
* --remove-this-line-to-prevent-override--
|
|
69
69
|
* last change 2024-02-26
|
|
70
70
|
* Author: Ks Tan
|
|
71
71
|
*/
|
|
@@ -17,8 +17,8 @@
|
|
|
17
17
|
</template>
|
|
18
18
|
<script lang="ts" setup>
|
|
19
19
|
/**
|
|
20
|
-
* This file was automatically generated by simpleapp generator.
|
|
21
|
-
*
|
|
20
|
+
* This file was automatically generated by simpleapp generator during initialization. It is changable.
|
|
21
|
+
* --remove-this-line-to-prevent-override--
|
|
22
22
|
* last change 2023-10-28
|
|
23
23
|
* Author: Ks Tan
|
|
24
24
|
*/
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
3
|
v-if="readonly"
|
|
4
|
-
class="p-2 border rounded-lg border-gray-300
|
|
4
|
+
class="p-2 border rounded-lg border-gray-300 flex h-input items-center"
|
|
5
5
|
>
|
|
6
6
|
<button
|
|
7
7
|
type="button"
|
|
8
8
|
:readonly="readonly"
|
|
9
|
-
class="cursor-pointer text-primary-600
|
|
9
|
+
class="cursor-pointer text-primary-600"
|
|
10
10
|
tabindex="0"
|
|
11
11
|
@click="openViewer(true)"
|
|
12
12
|
>
|
|
@@ -15,70 +15,71 @@
|
|
|
15
15
|
</div>
|
|
16
16
|
<div
|
|
17
17
|
v-else-if="modelValue !== undefined"
|
|
18
|
-
class="
|
|
18
|
+
class="px-3 border rounded-lg border-gray-300 flex h-input items-center"
|
|
19
19
|
>
|
|
20
|
-
|
|
20
|
+
<!-- readonly -->
|
|
21
21
|
<button
|
|
22
|
+
:id="inputId"
|
|
22
23
|
ref="autocompleteinput"
|
|
23
24
|
type="button"
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
class="cursor-pointer text-primary-600 dark:text-primary-400"
|
|
27
|
-
@click="openViewer(true)"
|
|
25
|
+
class="cursor-pointer text-primary-600 flex-1 text-left"
|
|
26
|
+
@click="openViewer(false)"
|
|
28
27
|
>
|
|
29
28
|
{{ modelValue && modelValue.label ? modelValue.label : "-" }}
|
|
30
29
|
</button>
|
|
31
30
|
|
|
32
31
|
<div
|
|
33
|
-
class="
|
|
32
|
+
class="text-right text-white align-middle"
|
|
34
33
|
>
|
|
35
34
|
<button
|
|
36
|
-
|
|
35
|
+
type="button"
|
|
37
36
|
class="pi pi-times rounded-full bg-slate-500 p-1 cursor-pointer text-xs"
|
|
38
|
-
@click="clear"
|
|
39
37
|
tabindex="0"
|
|
40
|
-
|
|
38
|
+
@click="clear"
|
|
39
|
+
/>
|
|
41
40
|
</div>
|
|
42
41
|
</div>
|
|
43
42
|
<div v-else class="relative">
|
|
44
43
|
<div
|
|
45
|
-
class="absolute h-full top-0 right-10 text-right text-white z-10 align-middle p-3"
|
|
46
44
|
v-if="modelValue?._id"
|
|
45
|
+
class="absolute h-full top-0 right-10 text-right text-white z-10 align-middle py-2 px-3"
|
|
47
46
|
>
|
|
48
47
|
<span
|
|
49
48
|
class="pi pi-times rounded-full bg-slate-500 p-1 cursor-pointer text-xs"
|
|
50
49
|
@click="clear"
|
|
51
|
-
|
|
50
|
+
/>
|
|
52
51
|
</div>
|
|
53
52
|
|
|
54
53
|
<AutoComplete
|
|
55
54
|
v-if="!isMobile()"
|
|
56
|
-
class="w-full"
|
|
57
|
-
v-model="autocompleteitem"
|
|
58
55
|
ref="autocompleteinput"
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
56
|
+
v-model="autocompleteitem"
|
|
57
|
+
pt:root="w-full"
|
|
58
|
+
pt:pcInputText:root="w-full rounded-r-none"
|
|
59
|
+
pt:dropdown="min-w-10"
|
|
60
|
+
force-selection
|
|
61
|
+
option-label="label"
|
|
64
62
|
:placeholder="placeholdertxt"
|
|
65
63
|
:dropdown="true"
|
|
66
|
-
@clear="clear"
|
|
67
64
|
:dropdown-mode="'current'"
|
|
68
65
|
:readonly="readonly"
|
|
69
66
|
:pt="pt"
|
|
70
67
|
:delay="500"
|
|
71
68
|
:disabled="readonly"
|
|
72
|
-
@click="clickAutocomplete"
|
|
73
69
|
:suggestions="list"
|
|
74
|
-
|
|
75
|
-
:inputId="inputId"
|
|
70
|
+
:input-id="inputId"
|
|
76
71
|
:path="setting.instancepath"
|
|
72
|
+
@focus="setFocus"
|
|
73
|
+
@item-select="pickAutoComplete"
|
|
74
|
+
@complete="getListFromAutocompleteApi"
|
|
75
|
+
@clear="clear"
|
|
76
|
+
@click="clickAutocomplete"
|
|
77
|
+
@blur="onBlurAutocomplete"
|
|
77
78
|
>
|
|
78
79
|
<template #header>
|
|
79
80
|
<slot name="header">
|
|
80
81
|
<div
|
|
81
|
-
class="flex flex-row font font-semibold text-sm
|
|
82
|
+
class="flex flex-row font font-semibold text-sm gap-2 p-2"
|
|
82
83
|
>
|
|
83
84
|
<div class="w w-1/3 line-clamp-1">
|
|
84
85
|
{{ t(codefield) ?? t("code") }}
|
|
@@ -94,7 +95,7 @@
|
|
|
94
95
|
</template>
|
|
95
96
|
<template #option="{ index, option }">
|
|
96
97
|
<slot name="option" :index="index" :option="option">
|
|
97
|
-
<div class="flex flex-row
|
|
98
|
+
<div class="flex flex-row text-sm gap-2">
|
|
98
99
|
<div class="w w-1/3 line-clamp-1">{{ option.code }}</div>
|
|
99
100
|
<div class="w w-2/3 line-clamp-1">{{ option.label }}</div>
|
|
100
101
|
</div>
|
|
@@ -106,35 +107,35 @@
|
|
|
106
107
|
<InputGroup class="w-full flex flex-row">
|
|
107
108
|
<InputText
|
|
108
109
|
:value="modelValue?.label"
|
|
109
|
-
@focus="showAutocompleteDialog(false)"
|
|
110
110
|
:placeholder="placeholdertxt"
|
|
111
111
|
class="rounded-r-none"
|
|
112
|
-
|
|
112
|
+
@focus="showAutocompleteDialog(false)"
|
|
113
|
+
/>
|
|
113
114
|
<InputGroupAddon
|
|
114
|
-
@click="showAutocompleteDialog(true)"
|
|
115
115
|
v-ripple
|
|
116
|
-
class="bg bg-primary-600
|
|
116
|
+
class="bg bg-primary-600 text-white rounded-r-lg p-3"
|
|
117
|
+
@click="showAutocompleteDialog(true)"
|
|
117
118
|
>
|
|
118
|
-
<i :class="`pi ${modelValue ? 'pi-link' : 'pi-angle-down'}`"
|
|
119
|
+
<i :class="`pi ${modelValue ? 'pi-link' : 'pi-angle-down'}`" />
|
|
119
120
|
</InputGroupAddon>
|
|
120
121
|
</InputGroup>
|
|
121
122
|
|
|
122
123
|
<OverlaySideBarCrud
|
|
123
124
|
v-model="mobileVisible"
|
|
124
|
-
|
|
125
|
+
close-event-name="autocompleteoverlay"
|
|
125
126
|
>
|
|
126
127
|
<template v-if="mobileListMode == 'list'">
|
|
127
128
|
<mobile-toolbar>
|
|
128
129
|
<template #start>
|
|
129
130
|
<ButtonText @click="mobileVisible = false">
|
|
130
|
-
<i class="pi pi-times"
|
|
131
|
+
<i class="pi pi-times"/>
|
|
131
132
|
</ButtonText>
|
|
132
133
|
</template>
|
|
133
134
|
<template #center>
|
|
134
135
|
<TextTitle class="text-white">{{ t(docname) }}</TextTitle>
|
|
135
136
|
</template>
|
|
136
137
|
<template #end>
|
|
137
|
-
<div
|
|
138
|
+
<div/>
|
|
138
139
|
<!-- <ButtonText @click="openViewer(false)">
|
|
139
140
|
<i class="pi pi-plus"></i>
|
|
140
141
|
</ButtonText> -->
|
|
@@ -142,12 +143,12 @@
|
|
|
142
143
|
</mobile-toolbar>
|
|
143
144
|
<ListView
|
|
144
145
|
:list="list"
|
|
145
|
-
:
|
|
146
|
-
:
|
|
147
|
-
|
|
148
|
-
titleField="code"
|
|
149
|
-
subTitleField="label"
|
|
146
|
+
:with-filter="true"
|
|
147
|
+
:default-filter-value="defaultFilterValue"
|
|
148
|
+
id-field="_id"
|
|
150
149
|
#default="{ item, index }"
|
|
150
|
+
title-field="code"
|
|
151
|
+
sub-title-field="label"
|
|
151
152
|
@click="onClickInMobile"
|
|
152
153
|
>
|
|
153
154
|
<div class="flex flex-row justify-end">
|
|
@@ -242,13 +243,12 @@ if (modelValue.value && modelValue.value._id) {
|
|
|
242
243
|
const clear = () => {
|
|
243
244
|
autocompleteitem.value = undefined;
|
|
244
245
|
modelValue.value = undefined;
|
|
245
|
-
if(!isMobile()){
|
|
246
|
-
setTimeout(()=>{
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
246
|
+
if (!isMobile()) {
|
|
247
|
+
setTimeout(() => {
|
|
248
|
+
const autoel = autocompleteinput.value.$el;
|
|
249
|
+
autoel?.firstElementChild?.focus();
|
|
250
|
+
}, 100);
|
|
250
251
|
}
|
|
251
|
-
|
|
252
252
|
};
|
|
253
253
|
|
|
254
254
|
//if record picked, click button show record info instead
|
|
@@ -294,7 +294,7 @@ const getListFromAutocompleteApi = (event: any) => {
|
|
|
294
294
|
getDocumentApi(targetDocument)
|
|
295
295
|
.autoComplete(keyword, morefilter)
|
|
296
296
|
.then((res: any) => {
|
|
297
|
-
console.log("Run autocomplete?");
|
|
297
|
+
// console.log("Run autocomplete?");
|
|
298
298
|
list.value = res.data;
|
|
299
299
|
|
|
300
300
|
if (
|
|
@@ -338,12 +338,12 @@ watch(modelValue, (newvalue: any) => {
|
|
|
338
338
|
});
|
|
339
339
|
const emitChanges = () => {
|
|
340
340
|
emits("change", modelValue.value);
|
|
341
|
-
if(!isMobile()){
|
|
342
|
-
setTimeout(()=>{
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
341
|
+
if (!isMobile()) {
|
|
342
|
+
setTimeout(() => {
|
|
343
|
+
const autoel = autocompleteinput.value;
|
|
344
|
+
autoel?.firstElementChild?.focus();
|
|
345
|
+
}, 100);
|
|
346
|
+
}
|
|
347
347
|
};
|
|
348
348
|
|
|
349
349
|
const setFocus = (ev: any) => {
|
|
@@ -399,7 +399,7 @@ const afterRenderMobileForm = async (
|
|
|
399
399
|
data: any,
|
|
400
400
|
result: any,
|
|
401
401
|
) => {
|
|
402
|
-
console.log("afterRenderMobileForm", eventType);
|
|
402
|
+
// console.log("afterRenderMobileForm", eventType);
|
|
403
403
|
if (eventType == FormCrudEvent.create || eventType == FormCrudEvent.update) {
|
|
404
404
|
autocompleteitem.value = {
|
|
405
405
|
_id: data._id,
|
|
@@ -423,7 +423,7 @@ const afterRenderMobileForm = async (
|
|
|
423
423
|
};
|
|
424
424
|
|
|
425
425
|
const clickAutocomplete = (a, b) => {
|
|
426
|
-
console.log("clickAutocomplete", a, b);
|
|
426
|
+
// console.log("clickAutocomplete", a, b);
|
|
427
427
|
return false;
|
|
428
428
|
};
|
|
429
429
|
</script>
|
|
@@ -1,23 +1,25 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<
|
|
2
|
+
<DatePicker
|
|
3
|
+
v-model="datetimevalue"
|
|
3
4
|
:pt="pt"
|
|
4
|
-
:
|
|
5
|
-
:
|
|
5
|
+
:date-format="getPrimevueCalendarDateFormat()"
|
|
6
|
+
:input-id="uuid"
|
|
6
7
|
:path="setting.instancepath"
|
|
7
|
-
|
|
8
|
-
@update:modelValue="updateDateTime"
|
|
9
|
-
showButtonBar
|
|
8
|
+
show-button-bar
|
|
10
9
|
:readonly="readonly"
|
|
11
10
|
:placeholder="placeholder"
|
|
12
|
-
:
|
|
13
|
-
:
|
|
14
|
-
|
|
15
|
-
v-bind="componentProps
|
|
11
|
+
:show-time="showtime"
|
|
12
|
+
:time-only="timeOnly"
|
|
13
|
+
hour-format="12"
|
|
14
|
+
v-bind="<CalendarProps>componentProps"
|
|
15
|
+
:select-other-months="true"
|
|
16
|
+
pt:pcInputText:root="w-full"
|
|
17
|
+
@update:model-value="updateDateTime"
|
|
16
18
|
/>
|
|
17
19
|
</template>
|
|
18
20
|
<script setup lang="ts">
|
|
19
21
|
// :date-format="getDateFormat()"
|
|
20
|
-
import { CalendarProps } from "primevue/calendar";
|
|
22
|
+
import type { CalendarProps } from "primevue/calendar";
|
|
21
23
|
const props = defineProps<{
|
|
22
24
|
pt: any;
|
|
23
25
|
uuid: string;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div class="flex flex-col">
|
|
3
|
-
<div class="flex flex-row gap-2">
|
|
3
|
+
<div class="flex flex-row gap-2 mt-3">
|
|
4
4
|
<TextTitle v-if="title" class="flex-1">{{ title }}</TextTitle>
|
|
5
5
|
|
|
6
6
|
<div class="flex flex-row"><slot name="buttons"></slot></div>
|
|
@@ -11,10 +11,12 @@
|
|
|
11
11
|
</ButtonDefault>
|
|
12
12
|
</div>
|
|
13
13
|
</div>
|
|
14
|
+
<div class="text-xs italic text-gray-400" v-if="inputDescription">{{ inputDescription }}</div>
|
|
15
|
+
|
|
14
16
|
<ListContainer
|
|
15
|
-
class="p-2
|
|
17
|
+
class="p-2 bg-slate-200 rounded-lg mt-3"
|
|
16
18
|
:list="list"
|
|
17
|
-
#default="{item,index }"
|
|
19
|
+
#default="{ item, index }"
|
|
18
20
|
@click="showRow"
|
|
19
21
|
>
|
|
20
22
|
<slot name="listbody" :item="item" :index="index">
|
|
@@ -61,6 +63,7 @@ const props = defineProps<{
|
|
|
61
63
|
addNew?: boolean;
|
|
62
64
|
readonly?: boolean;
|
|
63
65
|
doc: SimpleAppClient<any, any>;
|
|
66
|
+
inputDescription: string
|
|
64
67
|
}>();
|
|
65
68
|
const readonly = computed(() => {
|
|
66
69
|
if (props.readonly) return true;
|
|
@@ -1,43 +1,48 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<
|
|
2
|
+
<InputGroup class="flex flex-row w-full">
|
|
3
3
|
<InputText
|
|
4
|
-
@focus="setFocus"
|
|
5
|
-
:readonly="readonly"
|
|
6
4
|
v-model="modelValue"
|
|
5
|
+
:readonly="readonly"
|
|
7
6
|
:placeholder="placeholder"
|
|
8
7
|
:pt="pt"
|
|
9
8
|
:class="
|
|
10
9
|
!pt
|
|
11
10
|
? 'flex-1 w-full rounded-lg ' +
|
|
12
|
-
(props.readonly || !props.setting.document.isNew()
|
|
11
|
+
(props.readonly || !props.setting.document.isNew()
|
|
12
|
+
? ''
|
|
13
|
+
: 'rounded-tr-none rounded-br-none')
|
|
13
14
|
: ''
|
|
14
15
|
"
|
|
16
|
+
@focus="setFocus"
|
|
15
17
|
/>
|
|
16
|
-
<span class=""
|
|
17
|
-
<
|
|
18
|
-
v-
|
|
19
|
-
type="button"
|
|
20
|
-
@click="toggle"
|
|
18
|
+
<!-- <span class=""> -->
|
|
19
|
+
<Button
|
|
20
|
+
v-if="!readonly && props.setting.document.isNew()"
|
|
21
21
|
tabindex="-1"
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
22
|
+
icon="pi pi-angle-down"
|
|
23
|
+
@click="toggle"
|
|
24
|
+
/>
|
|
25
|
+
|
|
26
|
+
<!-- </span> -->
|
|
27
|
+
<Popover ref="op">
|
|
28
|
+
<ul>
|
|
29
|
+
<li
|
|
30
|
+
v-for="(docno, index) in docFormatlist"
|
|
31
|
+
:key="index"
|
|
32
|
+
class="hover-list-primary p-2"
|
|
33
|
+
>
|
|
34
|
+
<div
|
|
35
|
+
class="flex flex-row gap-2 cursor-pointer"
|
|
36
|
+
@click="chooseFormat(docno)"
|
|
37
|
+
>
|
|
38
|
+
<span class="">{{ docno.docNoFormatName }}</span>
|
|
39
|
+
<span class="text text-green-600">{{ docno.sample }}</span>
|
|
40
|
+
</div>
|
|
41
|
+
</li>
|
|
42
|
+
</ul>
|
|
43
|
+
</Popover>
|
|
39
44
|
<!-- {{ Object.getOwnPropertyNames(setting) }} -->
|
|
40
|
-
</
|
|
45
|
+
</InputGroup>
|
|
41
46
|
</template>
|
|
42
47
|
<script lang="ts" setup>
|
|
43
48
|
/**
|
|
@@ -47,7 +52,7 @@
|
|
|
47
52
|
* Author: Ks Tan
|
|
48
53
|
*/
|
|
49
54
|
import { ForeignKey } from "~/types";
|
|
50
|
-
import
|
|
55
|
+
import Popover from "primevue/popover";
|
|
51
56
|
import InputText from "primevue/inputtext";
|
|
52
57
|
import { DocNoFormat } from "~/types";
|
|
53
58
|
const props = defineProps<{
|