@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.
Files changed (239) hide show
  1. package/ReleaseNote.md +7 -0
  2. package/dist/buildinschemas/docnoformat.js +6 -6
  3. package/dist/buildinschemas/docnoformat.js.map +1 -1
  4. package/dist/buildinschemas/documentevent.js +1 -1
  5. package/dist/buildinschemas/documentevent.js.map +1 -1
  6. package/dist/buildinschemas/organization.js +1 -1
  7. package/dist/buildinschemas/organization.js.map +1 -1
  8. package/dist/buildinschemas/tenant.js +1 -1
  9. package/dist/buildinschemas/tenant.js.map +1 -1
  10. package/dist/buildinschemas/user.js +2 -2
  11. package/dist/buildinschemas/user.js.map +1 -1
  12. package/dist/buildinschemas/webhook.d.ts.map +1 -1
  13. package/dist/buildinschemas/webhook.js +1 -0
  14. package/dist/buildinschemas/webhook.js.map +1 -1
  15. package/dist/framework.d.ts.map +1 -1
  16. package/dist/framework.js +30 -3
  17. package/dist/framework.js.map +1 -1
  18. package/dist/generate.d.ts.map +1 -1
  19. package/dist/generate.js +21 -20
  20. package/dist/generate.js.map +1 -1
  21. package/dist/index.js +0 -0
  22. package/dist/processors/jrxmlbuilder.js +3 -3
  23. package/dist/processors/jrxmlbuilder.js.map +1 -1
  24. package/dist/processors/jsonschemabuilder.d.ts.map +1 -1
  25. package/dist/processors/jsonschemabuilder.js +17 -10
  26. package/dist/processors/jsonschemabuilder.js.map +1 -1
  27. package/dist/type.d.ts +1 -1
  28. package/dist/type.d.ts.map +1 -1
  29. package/package.json +2 -3
  30. package/reset-install.sh +3 -0
  31. package/src/buildinschemas/docnoformat.ts +6 -6
  32. package/src/buildinschemas/documentevent.ts +1 -1
  33. package/src/buildinschemas/organization.ts +1 -1
  34. package/src/buildinschemas/tenant.ts +1 -1
  35. package/src/buildinschemas/user.ts +2 -2
  36. package/src/buildinschemas/webhook.ts +1 -0
  37. package/src/framework.ts +33 -5
  38. package/src/generate.ts +22 -20
  39. package/src/processors/jrxmlbuilder.ts +3 -3
  40. package/src/processors/jsonschemabuilder.ts +27 -14
  41. package/src/type.ts +1 -1
  42. package/templates/basic/nest/controller.ts.eta +6 -5
  43. package/templates/basic/nest/resolver.ts.eta +4 -2
  44. package/templates/basic/nest/service.ts.eta +5 -2
  45. package/templates/basic/nuxt/simpleapp.generate.client.ts.eta +3 -3
  46. package/templates/nest/.gitignore.eta +4 -5
  47. package/templates/nest/src/{app.module.ts.eta → app.module.ts._eta} +2 -2
  48. package/templates/nest/src/{main.ts.eta → main.ts._eta} +2 -2
  49. package/templates/nest/src/printapi/printapi.service.ts.eta +7 -8
  50. package/templates/nest/src/simpleapp/.gitignore.eta +1 -1
  51. package/templates/nest/src/simpleapp/generate/commons/audittrail.service.ts.eta +2 -2
  52. package/templates/nest/src/simpleapp/generate/commons/customkeycloa.guard.ts.eta +14 -12
  53. package/templates/nest/src/simpleapp/generate/commons/customkeycloak.guard.ts.eta +36 -42
  54. package/templates/nest/src/simpleapp/generate/commons/docnogenerator.service.ts.eta +6 -3
  55. package/templates/nest/src/simpleapp/generate/commons/encryption.static.ts.eta +56 -61
  56. package/templates/nest/src/simpleapp/generate/commons/middlewares/tenant.middleware.ts.eta +65 -88
  57. package/templates/nest/src/simpleapp/generate/commons/robotuser.service.ts.eta +10 -9
  58. package/templates/nest/src/simpleapp/generate/commons/roles/roles.guard.ts.eta +10 -3
  59. package/templates/nest/src/simpleapp/generate/commons/runwebhook.service.ts.eta +71 -77
  60. package/templates/nest/src/simpleapp/generate/commons/user.context.ts.eta +439 -293
  61. package/templates/nest/src/simpleapp/generate/processors/autoinc.processor.ts.eta +20 -5
  62. package/templates/nest/src/simpleapp/generate/processors/simpleapp.processor.ts.eta +423 -38
  63. package/templates/nest/src/simpleapp/profile/{profile.controller.ts.eta → profile.controller.ts._eta} +2 -2
  64. package/templates/nest/src/simpleapp/profile/{profile.service.ts.eta → profile.service.ts._eta} +2 -2
  65. package/templates/nest/src/simpleapp/simpleapp.module.ts.eta +15 -4
  66. package/templates/nuxt/assets/css/style.css._eta +74 -28
  67. package/templates/nuxt/components/button/ButtonMultiple.vue._eta +1 -1
  68. package/templates/nuxt/components/calendar/{CalendarByResource.vue.eta → CalendarByResource.vue._eta} +2 -2
  69. package/templates/nuxt/components/calendar/{CalendarInput.vue.eta → CalendarInput.vue._eta} +3 -3
  70. package/templates/nuxt/components/calendar/{CalendarSmall.vue.eta → CalendarSmall.vue._eta} +13 -7
  71. package/templates/nuxt/components/debug/{DebugDocumentData.vue.eta → DebugDocumentData.vue._eta} +4 -5
  72. package/templates/nuxt/components/form/{FormDocnoformat.vue.eta → FormDocnoformat.vue._eta} +2 -1
  73. package/templates/nuxt/components/form/user/{FormUserPermission.vue.eta → FormUserPermission.vue._eta} +6 -0
  74. package/templates/nuxt/components/header/{HeaderBreadcrumb.vue.eta → HeaderBreadcrumb.vue._eta} +5 -5
  75. package/templates/nuxt/components/header/button/{HeaderButtonProfile.vue.eta → HeaderButtonProfile.vue._eta} +2 -2
  76. package/templates/nuxt/components/header/button/task/{HeaderButtonTaskList.vue.eta → HeaderButtonTaskList.vue._eta} +4 -4
  77. package/templates/nuxt/components/image/ImageAvatar.vue.eta +56 -0
  78. package/templates/nuxt/components/image/{ImageOrganization.vue.eta.vue → ImageOrganization.vue.eta} +15 -9
  79. package/templates/nuxt/components/image/{ImageToBase64Uploader.vue.eta.vue → ImageToBase64Uploader.vue.eta} +28 -18
  80. package/templates/nuxt/components/list/{ListDocumentTable.vue.eta → ListDocumentTable.vue._eta} +3 -3
  81. package/templates/nuxt/components/list/{ListItem.vue.eta → ListItem.vue._eta} +2 -2
  82. package/templates/nuxt/components/list/{ListMessages.vue.eta → ListMessages.vue._eta} +8 -2
  83. package/templates/nuxt/components/list/{ListView.vue.eta → ListView.vue._eta} +2 -2
  84. package/templates/nuxt/components/overlay/{OverlayPanelWithToolBar.vue.eta → OverlayPanelWithToolBar.vue._eta} +5 -5
  85. package/templates/nuxt/components/overlay/{OverlaySideBarCrud.vue.eta → OverlaySideBarCrud.vue._eta} +4 -4
  86. package/templates/nuxt/components/overlay/{OverlayViewer.vue.eta → OverlayViewer.vue._eta} +2 -2
  87. package/templates/nuxt/components/page/{PageDocList.vue.eta → PageDocList.vue._eta} +5 -5
  88. package/templates/nuxt/components/renderer/RendererDateAge.vue.eta +19 -0
  89. package/templates/nuxt/components/renderer/{RendererDateTime.vue.eta → RendererDateTime.vue._eta} +2 -2
  90. package/templates/nuxt/components/renderer/{RendererDocHistories.vue.eta → RendererDocHistories.vue._eta} +6 -0
  91. package/templates/nuxt/components/renderer/{RendererForeignKey.vue.eta → RendererForeignKey.vue._eta} +2 -2
  92. package/templates/nuxt/components/renderer/{RendererLink.vue.eta → RendererLink.vue._eta} +2 -2
  93. package/templates/nuxt/components/renderer/{RendererTime.vue.eta → RendererTime.vue._eta} +2 -2
  94. package/templates/nuxt/components/renderer/{RendererViewer.vue.eta → RendererViewer.vue._eta} +2 -2
  95. package/templates/nuxt/components/select/{SelectTemplate.vue.eta → SelectTemplate.vue._eta} +2 -2
  96. package/templates/nuxt/components/session/{SessionBlock.vue.eta → SessionBlock.vue._eta} +2 -2
  97. package/templates/nuxt/components/simpleApp/SimpleAppAutocomplete.vue.eta +55 -55
  98. package/templates/nuxt/components/simpleApp/SimpleAppCalendarInput.vue.eta +13 -11
  99. package/templates/nuxt/components/simpleApp/SimpleAppChildrenList.vue.eta +6 -3
  100. package/templates/nuxt/components/simpleApp/SimpleAppDocumentNo.vue.eta +33 -28
  101. package/templates/nuxt/components/simpleApp/SimpleAppFieldContainer.vue.eta +19 -28
  102. package/templates/nuxt/components/simpleApp/SimpleAppInput.vue.eta +113 -105
  103. package/templates/nuxt/components/simpleApp/SimpleAppInputTable.vue.eta +3 -3
  104. package/templates/nuxt/components/simpleApp/SimpleAppJsonSchemaForm.vue.eta +3 -16
  105. package/templates/nuxt/components/simpleApp/SimpleAppUserPicker.vue.eta +10 -12
  106. package/templates/nuxt/components/table/{TableDocuments.vue.eta → TableDocuments.vue._eta} +2 -2
  107. package/templates/nuxt/components/user/{UserButtonPermissionInfo.vue.eta → UserButtonPermissionInfo.vue._eta} +4 -4
  108. package/templates/nuxt/components/user/{UserInvitation.vue.eta → UserInvitation.vue._eta} +2 -2
  109. package/templates/nuxt/components/user/{UserProfileListItem.vue.eta → UserProfileListItem.vue._eta} +2 -2
  110. package/templates/nuxt/components/user/{UserTenantPicker.vue.eta → UserTenantPicker.vue._eta} +2 -2
  111. package/templates/nuxt/composables/getOpenApi.generate.ts.eta +11 -3
  112. package/templates/nuxt/composables/getUserStore.generate.ts.eta +1 -1
  113. package/templates/nuxt/composables/graphquery.generate.ts.eta +1 -1
  114. package/templates/nuxt/composables/recently.generate.ts.eta +0 -1
  115. package/templates/nuxt/composables/stringHelper.generate.ts.eta +5 -2
  116. package/templates/nuxt/nuxt.config.ts._eta +6 -5
  117. package/templates/nuxt/pages/[xorg]/docnoformat/[id].vue.eta +0 -1
  118. package/templates/nuxt/pages/[xorg]/{docnoformat.vue.eta → docnoformat.vue._eta} +1 -0
  119. package/templates/nuxt/pages/[xorg]/organization/[id].vue.eta +13 -9
  120. package/templates/nuxt/pages/[xorg]/organization/new.vue.eta +10 -12
  121. package/templates/nuxt/pages/[xorg]/{user.vue.eta → user.vue._eta} +2 -2
  122. package/templates/nuxt/pages/index.vue._eta +1 -1
  123. package/templates/nuxt/pages/{profile.vue.eta → profile.vue._eta} +2 -2
  124. package/templates/nuxt/plugins/10.simpleapp-event.ts.eta +6 -0
  125. package/templates/nuxt/plugins/20.simpleapp-userstore.ts.eta +89 -12
  126. package/templates/nuxt/plugins/40.pusher.ts.eta +8 -5
  127. package/templates/nuxt/presets/lara/accordion/index.js +79 -0
  128. package/templates/nuxt/presets/lara/accordioncontent/index.js +3 -0
  129. package/templates/nuxt/presets/lara/accordionheader/index.js +11 -0
  130. package/templates/nuxt/presets/lara/accordionpanel/index.js +18 -0
  131. package/templates/nuxt/presets/lara/autocomplete/index.js +208 -0
  132. package/templates/nuxt/presets/lara/avatar/index.js +43 -0
  133. package/templates/nuxt/presets/lara/avatargroup/index.js +5 -0
  134. package/templates/nuxt/presets/lara/badge/index.js +47 -0
  135. package/templates/nuxt/presets/lara/badgedirective/index.js +43 -0
  136. package/templates/nuxt/presets/lara/blockui/index.js +4 -0
  137. package/templates/nuxt/presets/lara/breadcrumb/index.js +64 -0
  138. package/templates/nuxt/presets/lara/button/index.js +238 -0
  139. package/templates/nuxt/presets/lara/buttongroup/index.js +12 -0
  140. package/templates/nuxt/presets/lara/card/index.js +37 -0
  141. package/templates/nuxt/presets/lara/carousel/index.js +103 -0
  142. package/templates/nuxt/presets/lara/cascadeselect/index.js +199 -0
  143. package/templates/nuxt/presets/lara/checkbox/index.js +104 -0
  144. package/templates/nuxt/presets/lara/chip/index.js +42 -0
  145. package/templates/nuxt/presets/lara/colorpicker/index.js +123 -0
  146. package/templates/nuxt/presets/lara/confirmdialog/index.js +3 -0
  147. package/templates/nuxt/presets/lara/confirmpopup/index.js +56 -0
  148. package/templates/nuxt/presets/lara/contextmenu/index.js +126 -0
  149. package/templates/nuxt/presets/lara/datatable/index.js +403 -0
  150. package/templates/nuxt/presets/lara/dataview/index.js +28 -0
  151. package/templates/nuxt/presets/lara/datepicker/index.js +435 -0
  152. package/templates/nuxt/presets/lara/deferred/index.js +3 -0
  153. package/templates/nuxt/presets/lara/dialog/index.js +148 -0
  154. package/templates/nuxt/presets/lara/divider/index.js +67 -0
  155. package/templates/nuxt/presets/lara/dock/index.js +86 -0
  156. package/templates/nuxt/presets/lara/drawer/index.js +149 -0
  157. package/templates/nuxt/presets/lara/fieldset/index.js +84 -0
  158. package/templates/nuxt/presets/lara/fileupload/index.js +95 -0
  159. package/templates/nuxt/presets/lara/floatlabel/index.js +26 -0
  160. package/templates/nuxt/presets/lara/galleria/index.js +308 -0
  161. package/templates/nuxt/presets/lara/global.js +90 -0
  162. package/templates/nuxt/presets/lara/iconfield/index.js +27 -0
  163. package/templates/nuxt/presets/lara/image/index.js +206 -0
  164. package/templates/nuxt/presets/lara/index.js +234 -0
  165. package/templates/nuxt/presets/lara/inplace/index.js +27 -0
  166. package/templates/nuxt/presets/lara/inputgroup/index.js +5 -0
  167. package/templates/nuxt/presets/lara/inputgroupaddon/index.js +28 -0
  168. package/templates/nuxt/presets/lara/inputmask/index.js +39 -0
  169. package/templates/nuxt/presets/lara/inputnumber/index.js +167 -0
  170. package/templates/nuxt/presets/lara/inputotp/index.js +10 -0
  171. package/templates/nuxt/presets/lara/inputswitch/index.js +80 -0
  172. package/templates/nuxt/presets/lara/inputtext/index.js +54 -0
  173. package/templates/nuxt/presets/lara/knob/index.js +44 -0
  174. package/templates/nuxt/presets/lara/listbox/index.js +117 -0
  175. package/templates/nuxt/presets/lara/megamenu/index.js +198 -0
  176. package/templates/nuxt/presets/lara/menu/index.js +96 -0
  177. package/templates/nuxt/presets/lara/menubar/index.js +176 -0
  178. package/templates/nuxt/presets/lara/message/index.js +92 -0
  179. package/templates/nuxt/presets/lara/metergroup/index.js +96 -0
  180. package/templates/nuxt/presets/lara/multiselect/index.js +201 -0
  181. package/templates/nuxt/presets/lara/orderlist/index.js +13 -0
  182. package/templates/nuxt/presets/lara/organizationchart/index.js +137 -0
  183. package/templates/nuxt/presets/lara/overlaybadge/index.js +18 -0
  184. package/templates/nuxt/presets/lara/paginator/index.js +178 -0
  185. package/templates/nuxt/presets/lara/panel/index.js +91 -0
  186. package/templates/nuxt/presets/lara/panelmenu/index.js +127 -0
  187. package/templates/nuxt/presets/lara/password/index.js +72 -0
  188. package/templates/nuxt/presets/lara/picklist/index.js +52 -0
  189. package/templates/nuxt/presets/lara/popover/index.js +31 -0
  190. package/templates/nuxt/presets/lara/progressbar/index.js +55 -0
  191. package/templates/nuxt/presets/lara/progressspinner/index.js +51 -0
  192. package/templates/nuxt/presets/lara/radiobutton/index.js +104 -0
  193. package/templates/nuxt/presets/lara/rating/index.js +63 -0
  194. package/templates/nuxt/presets/lara/ripple/index.js +6 -0
  195. package/templates/nuxt/presets/lara/scrollpanel/index.js +77 -0
  196. package/templates/nuxt/presets/lara/scrolltop/index.js +26 -0
  197. package/templates/nuxt/presets/lara/select/index.js +240 -0
  198. package/templates/nuxt/presets/lara/selectbutton/index.js +16 -0
  199. package/templates/nuxt/presets/lara/skeleton/index.js +16 -0
  200. package/templates/nuxt/presets/lara/slider/index.js +137 -0
  201. package/templates/nuxt/presets/lara/speeddial/index.js +57 -0
  202. package/templates/nuxt/presets/lara/splitbutton/index.js +19 -0
  203. package/templates/nuxt/presets/lara/splitter/index.js +61 -0
  204. package/templates/nuxt/presets/lara/splitterpanel/index.js +5 -0
  205. package/templates/nuxt/presets/lara/step/index.js +62 -0
  206. package/templates/nuxt/presets/lara/stepitem/index.js +11 -0
  207. package/templates/nuxt/presets/lara/steplist/index.js +3 -0
  208. package/templates/nuxt/presets/lara/steppanels/index.js +3 -0
  209. package/templates/nuxt/presets/lara/stepper/index.js +13 -0
  210. package/templates/nuxt/presets/lara/steps/index.js +111 -0
  211. package/templates/nuxt/presets/lara/tab/index.js +42 -0
  212. package/templates/nuxt/presets/lara/tablist/index.js +8 -0
  213. package/templates/nuxt/presets/lara/tabmenu/index.js +73 -0
  214. package/templates/nuxt/presets/lara/tabpanel/index.js +3 -0
  215. package/templates/nuxt/presets/lara/tabpanels/index.js +3 -0
  216. package/templates/nuxt/presets/lara/tabs/index.js +5 -0
  217. package/templates/nuxt/presets/lara/tabview/index.js +156 -0
  218. package/templates/nuxt/presets/lara/tag/index.js +38 -0
  219. package/templates/nuxt/presets/lara/terminal/index.js +60 -0
  220. package/templates/nuxt/presets/lara/textarea/index.js +39 -0
  221. package/templates/nuxt/presets/lara/tieredmenu/index.js +121 -0
  222. package/templates/nuxt/presets/lara/timeline/index.js +81 -0
  223. package/templates/nuxt/presets/lara/toast/index.js +102 -0
  224. package/templates/nuxt/presets/lara/togglebutton/index.js +45 -0
  225. package/templates/nuxt/presets/lara/toggleswitch/index.js +80 -0
  226. package/templates/nuxt/presets/lara/toolbar/index.js +28 -0
  227. package/templates/nuxt/presets/lara/tooltip/index.js +46 -0
  228. package/templates/nuxt/presets/lara/tree/index.js +101 -0
  229. package/templates/nuxt/presets/lara/treeselect/index.js +102 -0
  230. package/templates/nuxt/presets/lara/treetable/index.js +305 -0
  231. package/templates/nuxt/providers/my-provider.ts.eta +1 -1
  232. package/templates/nuxt/server/api/profile/[...].ts.eta +4 -3
  233. package/templates/nuxt/simpleapp/generate/clients/SimpleAppClient.ts.eta +10 -20
  234. package/templates/nuxt/tailwind.config.ts._eta +4 -15
  235. package/templates/nuxt/types/schema.ts.eta +1 -1
  236. package/templates/nuxt/types/user.ts.eta +6 -1
  237. package/templates/project/jsonschemas/appintegration.json_eta +227 -0
  238. package/templates/project/sharelibs/validate.ts.eta +23 -0
  239. package/templates/nuxt/components/image/ImageAvatar.vue.eta._vue +0 -57
@@ -1,5 +1,5 @@
1
1
  <template>
2
- <Sidebar
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
- </Sidebar>
19
+ </Drawer>
20
20
  </template>
21
21
  <script lang="ts" setup>
22
22
  /**
23
- * This file was automatically generated by simpleapp generator. Every
24
- * MODIFICATION OVERRIDE BY GENERATEOR
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. Every
28
- * MODIFICATION OVERRIDE BY GENERATEOR
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 as T[]"
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 as T"></slot>
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 as T[]"
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. Every
146
- * MODIFICATION OVERRIDE BY GENERATEOR
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>
@@ -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
- * DONT CHANGE THIS FILE CAUSE IT OVERRIDE
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
- * DONT CHANGE THIS FILE CAUSE IT OVERRIDE
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
- * DONT CHANGE THIS FILE CAUSE IT OVERRIDE
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
- * DONT CHANGE THIS FILE CAUSE IT OVERRIDE
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
  */
@@ -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
- * DONT CHANGE THIS FILE CAUSE IT OVERRIDE
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. Every
68
- * MODIFICATION OVERRIDE BY GENERATEOR
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. Every
21
- * MODIFICATION OVERRIDE BY GENERATEOR
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 dark:border-blue-900/40"
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 dark:text-primary-400"
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="p-2 border rounded-lg border-gray-300 dark:border-blue-900/40 relative"
18
+ class="px-3 border rounded-lg border-gray-300 flex h-input items-center"
19
19
  >
20
- <!-- readonly -->
20
+ <!-- readonly -->
21
21
  <button
22
+ :id="inputId"
22
23
  ref="autocompleteinput"
23
24
  type="button"
24
- :id="inputId"
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="absolute h-full top-0 right-0 text-right text-white z-10 align-middle p-3"
32
+ class="text-right text-white align-middle"
34
33
  >
35
34
  <button
36
- type="button"
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
- ></button>
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
- ></span>
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
- forceSelection
60
- optionLabel="label"
61
- @focus="setFocus"
62
- @item-select="pickAutoComplete"
63
- @complete="getListFromAutocompleteApi"
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
- @blur="onBlurAutocomplete"
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 dark:text-white gap-2 p-2"
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 dark:text-white text-sm gap-2">
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
- ></InputText>
112
+ @focus="showAutocompleteDialog(false)"
113
+ />
113
114
  <InputGroupAddon
114
- @click="showAutocompleteDialog(true)"
115
115
  v-ripple
116
- class="bg bg-primary-600 dark:bg-primary-700 text-white rounded-r-lg p-3"
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'}`"></i>
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
- closeEventName="autocompleteoverlay"
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"></i>
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></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
- :withFilter="true"
146
- :defaultFilterValue="defaultFilterValue"
147
- idField="_id"
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
- const autoel = autocompleteinput.value.$el
248
- autoel?.firstElementChild?.focus()
249
- },100)
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
- const autoel = autocompleteinput.value
344
- autoel?.focus()
345
- },100)}
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
- <Calendar
2
+ <DatePicker
3
+ v-model="datetimevalue"
3
4
  :pt="pt"
4
- :dateFormat="getPrimevueCalendarDateFormat()"
5
- :inputId="uuid"
5
+ :date-format="getPrimevueCalendarDateFormat()"
6
+ :input-id="uuid"
6
7
  :path="setting.instancepath"
7
- v-model="datetimevalue"
8
- @update:modelValue="updateDateTime"
9
- showButtonBar
8
+ show-button-bar
10
9
  :readonly="readonly"
11
10
  :placeholder="placeholder"
12
- :showTime="showtime"
13
- :timeOnly="timeOnly"
14
- hourFormat="12"
15
- v-bind="componentProps as CalendarProps"
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 dark:bg-slate-900 bg-slate-200 rounded-lg"
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
- <div class="flex flex-row w-full">
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() ? '' : 'rounded-tr-none rounded-br-none')
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="" v-if="!readonly && props.setting.document.isNew()">
17
- <button
18
- v-ripple
19
- type="button"
20
- @click="toggle"
18
+ <!-- <span class=""> -->
19
+ <Button
20
+ v-if="!readonly && props.setting.document.isNew()"
21
21
  tabindex="-1"
22
- class="'btn bg-primary-500 dark:text-black text-white p-3 dark:border-blue-900/40 rounded-lg rounded-tl-none rounded-bl-none"
23
- >
24
- <i class="pi pi-angle-down"></i>
25
- </button>
26
- <OverlayPanel ref="op">
27
- <div class="m-4">
28
- <ul>
29
- <li v-for="docno in docFormatlist" class="hover-list-primary p-2">
30
- <div class="flex flex-row gap-2 cursor-pointer" @click="chooseFormat(docno)">
31
- <span class="">{{ docno.docNoFormatName }}</span>
32
- <span class="text text-green-600">{{ docno.sample }}</span>
33
- </div>
34
- </li>
35
- </ul>
36
- </div>
37
- </OverlayPanel>
38
- </span>
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
- </div>
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 OverlayPanel from "primevue/overlaypanel";
55
+ import Popover from "primevue/popover";
51
56
  import InputText from "primevue/inputtext";
52
57
  import { DocNoFormat } from "~/types";
53
58
  const props = defineProps<{