sk-front-lib 0.14.8 → 0.15.3

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 (327) hide show
  1. package/api/package.json +5 -6
  2. package/api/sk-api.module.d.ts +7 -0
  3. package/api/sk-api.service.d.ts +3 -0
  4. package/api/sk-front-lib-api.d.ts +1 -0
  5. package/article/package.json +5 -6
  6. package/article/sk-article-editor-server.component.d.ts +3 -0
  7. package/article/sk-article-editor.component.d.ts +3 -0
  8. package/article/sk-article-server.module.d.ts +6 -0
  9. package/article/sk-article.module.d.ts +7 -0
  10. package/article/sk-article.service.d.ts +3 -0
  11. package/article/sk-froala-editor.directive.d.ts +3 -0
  12. package/article/sk-front-lib-article.d.ts +1 -0
  13. package/crud/package.json +5 -6
  14. package/crud/sk-account.service.d.ts +3 -0
  15. package/crud/sk-auth-admin.guard.d.ts +3 -0
  16. package/crud/sk-auth.guard.d.ts +3 -0
  17. package/crud/sk-auth.service.d.ts +3 -0
  18. package/crud/sk-board.service.d.ts +3 -0
  19. package/crud/sk-brand.service.d.ts +3 -0
  20. package/crud/sk-cart.service.d.ts +7 -0
  21. package/crud/sk-category.service.d.ts +3 -0
  22. package/crud/sk-comment.service.d.ts +3 -0
  23. package/crud/sk-config.service.d.ts +3 -0
  24. package/crud/sk-contact.service.d.ts +3 -0
  25. package/crud/sk-coupon.service.d.ts +3 -0
  26. package/crud/sk-document.service.d.ts +3 -0
  27. package/crud/sk-etc.service.d.ts +3 -0
  28. package/crud/sk-file.service.d.ts +3 -0
  29. package/crud/sk-front-lib-crud.d.ts +1 -1
  30. package/crud/sk-keyword.service.d.ts +3 -0
  31. package/crud/sk-order.service.d.ts +3 -0
  32. package/crud/sk-point.service.d.ts +3 -0
  33. package/crud/sk-product.service.d.ts +4 -0
  34. package/crud/sk-promotion.service.d.ts +3 -0
  35. package/crud/sk-search.service.d.ts +3 -0
  36. package/crud/sk-store.service.d.ts +3 -0
  37. package/crud/sk-user.service.d.ts +3 -0
  38. package/{esm2015/api/model/api-config.js → esm2020/api/model/api-config.mjs} +0 -0
  39. package/{esm2015/api/model/api-pageable-param.js → esm2020/api/model/api-pageable-param.mjs} +0 -0
  40. package/{esm2015/api/model/api-pageable.js → esm2020/api/model/api-pageable.mjs} +0 -0
  41. package/{esm2015/api/model/api-response.js → esm2020/api/model/api-response.mjs} +0 -0
  42. package/{esm2015/api/model/index.js → esm2020/api/model/index.mjs} +0 -0
  43. package/{esm2015/api/public_api.js → esm2020/api/public_api.mjs} +0 -0
  44. package/esm2020/api/sk-api.module.mjs +35 -0
  45. package/esm2020/api/sk-api.service.mjs +145 -0
  46. package/{esm2015/api/sk-front-lib-api.js → esm2020/api/sk-front-lib-api.mjs} +0 -0
  47. package/{esm2015/article/public_api.js → esm2020/article/public_api.mjs} +0 -0
  48. package/esm2020/article/sk-article-editor-server.component.mjs +51 -0
  49. package/esm2020/article/sk-article-editor.component.mjs +93 -0
  50. package/esm2020/article/sk-article-server.module.mjs +33 -0
  51. package/esm2020/article/sk-article.module.mjs +32 -0
  52. package/esm2020/article/sk-article.service.mjs +248 -0
  53. package/esm2020/article/sk-froala-editor.directive.mjs +325 -0
  54. package/{esm2015/article/sk-front-lib-article.js → esm2020/article/sk-front-lib-article.mjs} +0 -0
  55. package/{esm2015/crud/public_api.js → esm2020/crud/public_api.mjs} +0 -0
  56. package/esm2020/crud/sk-account.service.mjs +36 -0
  57. package/esm2020/crud/sk-auth-admin.guard.mjs +31 -0
  58. package/esm2020/crud/sk-auth.guard.mjs +31 -0
  59. package/esm2020/crud/sk-auth.service.mjs +67 -0
  60. package/esm2020/crud/sk-board.service.mjs +54 -0
  61. package/esm2020/crud/sk-brand.service.mjs +46 -0
  62. package/esm2020/crud/sk-cart.service.mjs +255 -0
  63. package/esm2020/crud/sk-category.service.mjs +63 -0
  64. package/esm2020/crud/sk-comment.service.mjs +43 -0
  65. package/esm2020/crud/sk-config.service.mjs +31 -0
  66. package/esm2020/crud/sk-contact.service.mjs +39 -0
  67. package/esm2020/crud/sk-coupon.service.mjs +62 -0
  68. package/esm2020/crud/sk-document.service.mjs +95 -0
  69. package/esm2020/crud/sk-etc.service.mjs +25 -0
  70. package/esm2020/crud/sk-file.service.mjs +37 -0
  71. package/esm2020/crud/sk-front-lib-crud.mjs +5 -0
  72. package/esm2020/crud/sk-keyword.service.mjs +46 -0
  73. package/esm2020/crud/sk-order.service.mjs +133 -0
  74. package/esm2020/crud/sk-point.service.mjs +45 -0
  75. package/esm2020/crud/sk-product.service.mjs +156 -0
  76. package/esm2020/crud/sk-promotion.service.mjs +81 -0
  77. package/esm2020/crud/sk-search.service.mjs +25 -0
  78. package/esm2020/crud/sk-store.service.mjs +47 -0
  79. package/esm2020/crud/sk-user.service.mjs +69 -0
  80. package/esm2020/google-analytics/google-analytics-router.module.mjs +30 -0
  81. package/esm2020/google-analytics/google-analytics.module.mjs +40 -0
  82. package/esm2020/google-analytics/initializers/google-analytics-router.initializer.mjs +24 -0
  83. package/esm2020/google-analytics/initializers/google-analytics.initializer.mjs +46 -0
  84. package/{esm2015/google-analytics/interfaces/google-analytics-command.js → esm2020/google-analytics/interfaces/google-analytics-command.mjs} +0 -0
  85. package/{esm2015/google-analytics/interfaces/google-analytics-settings.js → esm2020/google-analytics/interfaces/google-analytics-settings.mjs} +0 -0
  86. package/{esm2015/google-analytics/public_api.js → esm2020/google-analytics/public_api.mjs} +0 -0
  87. package/esm2020/google-analytics/services/google-analytics.service.mjs +200 -0
  88. package/{esm2015/google-analytics/sk-front-lib-google-analytics.js → esm2020/google-analytics/sk-front-lib-google-analytics.mjs} +0 -0
  89. package/{esm2015/google-analytics/tokens/google-analytics-settings-token.js → esm2020/google-analytics/tokens/google-analytics-settings-token.mjs} +0 -0
  90. package/{esm2015/google-analytics/types/ga-action.type.js → esm2020/google-analytics/types/ga-action.type.mjs} +0 -0
  91. package/{esm2015/google-analytics/types/ga-bind.type.js → esm2020/google-analytics/types/ga-bind.type.mjs} +0 -0
  92. package/esm2020/image/public_api.mjs +3 -0
  93. package/esm2020/image/sk-front-lib-image.mjs +5 -0
  94. package/esm2020/image/sk-image.component.mjs +262 -0
  95. package/esm2020/image/sk-image.module.mjs +43 -0
  96. package/{esm2015/lib/sk-animations.js → esm2020/lib/sk-animations.mjs} +0 -0
  97. package/esm2020/lib/sk-byte.pipe.mjs +18 -0
  98. package/esm2020/lib/sk-date-time.pipe.mjs +16 -0
  99. package/esm2020/lib/sk-date.pipe.mjs +16 -0
  100. package/esm2020/lib/sk-front-lib.module.mjs +42 -0
  101. package/esm2020/lib/sk-keys.pipe.mjs +23 -0
  102. package/esm2020/lib/sk-time.pipe.mjs +16 -0
  103. package/{esm2015/lib/sk-utils.js → esm2020/lib/sk-utils.mjs} +0 -0
  104. package/{esm2015/model/lib/article.js → esm2020/model/lib/article.mjs} +0 -0
  105. package/{esm2015/model/lib/audit.js → esm2020/model/lib/audit.mjs} +0 -0
  106. package/{esm2015/model/lib/auth.js → esm2020/model/lib/auth.mjs} +0 -0
  107. package/{esm2015/model/lib/board.js → esm2020/model/lib/board.mjs} +0 -0
  108. package/{esm2015/model/lib/cart.js → esm2020/model/lib/cart.mjs} +0 -0
  109. package/{esm2015/model/lib/comment.js → esm2020/model/lib/comment.mjs} +0 -0
  110. package/{esm2015/model/lib/contact.js → esm2020/model/lib/contact.mjs} +0 -0
  111. package/{esm2015/model/lib/coupon.js → esm2020/model/lib/coupon.mjs} +0 -0
  112. package/{esm2015/model/lib/document.js → esm2020/model/lib/document.mjs} +0 -0
  113. package/{esm2015/model/lib/etc.js → esm2020/model/lib/etc.mjs} +0 -0
  114. package/{esm2015/model/lib/file.js → esm2020/model/lib/file.mjs} +0 -0
  115. package/{esm2015/model/lib/filetype.js → esm2020/model/lib/filetype.mjs} +0 -0
  116. package/{esm2015/model/lib/grid.js → esm2020/model/lib/grid.mjs} +0 -0
  117. package/{esm2015/model/lib/nicepay.js → esm2020/model/lib/nicepay.mjs} +0 -0
  118. package/{esm2015/model/lib/order.js → esm2020/model/lib/order.mjs} +0 -0
  119. package/{esm2015/model/lib/payment.js → esm2020/model/lib/payment.mjs} +0 -0
  120. package/{esm2015/model/lib/point.js → esm2020/model/lib/point.mjs} +0 -0
  121. package/{esm2015/model/lib/product-series.js → esm2020/model/lib/product-series.mjs} +0 -0
  122. package/{esm2015/model/lib/product.js → esm2020/model/lib/product.mjs} +1 -1
  123. package/esm2020/model/lib/promotion.mjs +79 -0
  124. package/{esm2015/model/lib/shipping.js → esm2020/model/lib/shipping.mjs} +0 -0
  125. package/{esm2015/model/lib/user.js → esm2020/model/lib/user.mjs} +0 -0
  126. package/{esm2015/model/public_api.js → esm2020/model/public_api.mjs} +0 -0
  127. package/{esm2015/model/sk-front-lib-model.js → esm2020/model/sk-front-lib-model.mjs} +0 -0
  128. package/{esm2015/public-api.js → esm2020/public-api.mjs} +2 -1
  129. package/esm2020/search-address/dialog/dialog.component.mjs +27 -0
  130. package/{esm2015/search-address/public_api.js → esm2020/search-address/public_api.mjs} +0 -0
  131. package/esm2020/search-address/sk-front-lib-search-address.mjs +5 -0
  132. package/esm2020/search-address/sk-search-address.directive.mjs +41 -0
  133. package/{esm2015/search-address/sk-search-address.model.js → esm2020/search-address/sk-search-address.model.mjs} +0 -0
  134. package/esm2020/search-address/sk-search-address.module.mjs +52 -0
  135. package/{esm2015/search-address/sk-search-address.service.js → esm2020/search-address/sk-search-address.service.mjs} +10 -8
  136. package/esm2020/sk-front-lib.mjs +5 -0
  137. package/{esm2015/uploader/public_api.js → esm2020/uploader/public_api.mjs} +0 -0
  138. package/esm2020/uploader/sk-front-lib-uploader.mjs +5 -0
  139. package/{esm2015/uploader/sk-uploader-file-item.model.js → esm2020/uploader/sk-uploader-file-item.model.mjs} +0 -0
  140. package/{esm2015/uploader/sk-uploader.animation.js → esm2020/uploader/sk-uploader.animation.mjs} +0 -0
  141. package/{esm2015/uploader/sk-uploader.class.js → esm2020/uploader/sk-uploader.class.mjs} +0 -0
  142. package/esm2020/uploader/sk-uploader.component.mjs +120 -0
  143. package/esm2020/uploader/sk-uploader.directive.mjs +44 -0
  144. package/esm2020/uploader/sk-uploader.module.mjs +62 -0
  145. package/fesm2015/sk-front-lib-api.mjs +218 -0
  146. package/fesm2015/sk-front-lib-api.mjs.map +1 -0
  147. package/fesm2015/{sk-front-lib-article.js → sk-front-lib-article.mjs} +183 -158
  148. package/fesm2015/sk-front-lib-article.mjs.map +1 -0
  149. package/fesm2015/sk-front-lib-crud.mjs +1403 -0
  150. package/fesm2015/sk-front-lib-crud.mjs.map +1 -0
  151. package/fesm2015/{sk-front-lib-google-analytics.js → sk-front-lib-google-analytics.mjs} +54 -33
  152. package/fesm2015/sk-front-lib-google-analytics.mjs.map +1 -0
  153. package/fesm2015/{sk-front-lib-image.js → sk-front-lib-image.mjs} +64 -48
  154. package/fesm2015/sk-front-lib-image.mjs.map +1 -0
  155. package/fesm2015/{sk-front-lib-model.js → sk-front-lib-model.mjs} +9 -2
  156. package/fesm2015/sk-front-lib-model.mjs.map +1 -0
  157. package/fesm2015/sk-front-lib-search-address.mjs +188 -0
  158. package/fesm2015/sk-front-lib-search-address.mjs.map +1 -0
  159. package/fesm2015/sk-front-lib-uploader.mjs +551 -0
  160. package/fesm2015/sk-front-lib-uploader.mjs.map +1 -0
  161. package/fesm2015/{sk-front-lib.js → sk-front-lib.mjs} +69 -41
  162. package/fesm2015/sk-front-lib.mjs.map +1 -0
  163. package/{fesm2015/sk-front-lib-api.js → fesm2020/sk-front-lib-api.mjs} +41 -26
  164. package/fesm2020/sk-front-lib-api.mjs.map +1 -0
  165. package/fesm2020/sk-front-lib-article.mjs +771 -0
  166. package/fesm2020/sk-front-lib-article.mjs.map +1 -0
  167. package/{fesm2015/sk-front-lib-crud.js → fesm2020/sk-front-lib-crud.mjs} +213 -236
  168. package/fesm2020/sk-front-lib-crud.mjs.map +1 -0
  169. package/fesm2020/sk-front-lib-google-analytics.mjs +336 -0
  170. package/fesm2020/sk-front-lib-google-analytics.mjs.map +1 -0
  171. package/fesm2020/sk-front-lib-image.mjs +309 -0
  172. package/fesm2020/sk-front-lib-image.mjs.map +1 -0
  173. package/fesm2020/sk-front-lib-model.mjs +1052 -0
  174. package/fesm2020/sk-front-lib-model.mjs.map +1 -0
  175. package/fesm2020/sk-front-lib-search-address.mjs +186 -0
  176. package/fesm2020/sk-front-lib-search-address.mjs.map +1 -0
  177. package/fesm2020/sk-front-lib-uploader.mjs +549 -0
  178. package/fesm2020/sk-front-lib-uploader.mjs.map +1 -0
  179. package/fesm2020/sk-front-lib.mjs +539 -0
  180. package/fesm2020/sk-front-lib.mjs.map +1 -0
  181. package/google-analytics/google-analytics-router.module.d.ts +6 -0
  182. package/google-analytics/google-analytics.module.d.ts +5 -0
  183. package/google-analytics/package.json +5 -6
  184. package/google-analytics/services/google-analytics.service.d.ts +3 -0
  185. package/google-analytics/sk-front-lib-google-analytics.d.ts +1 -0
  186. package/image/package.json +5 -6
  187. package/image/public_api.d.ts +1 -0
  188. package/image/sk-front-lib-image.d.ts +1 -1
  189. package/image/sk-image.component.d.ts +6 -3
  190. package/image/sk-image.module.d.ts +10 -0
  191. package/lib/sk-byte.pipe.d.ts +3 -0
  192. package/lib/sk-date-time.pipe.d.ts +3 -0
  193. package/lib/sk-date.pipe.d.ts +3 -0
  194. package/lib/sk-front-lib.module.d.ts +9 -0
  195. package/lib/sk-keys.pipe.d.ts +3 -0
  196. package/lib/sk-time.pipe.d.ts +3 -0
  197. package/model/lib/product.d.ts +1 -0
  198. package/model/lib/promotion.d.ts +12 -1
  199. package/model/package.json +5 -6
  200. package/model/sk-front-lib-model.d.ts +1 -0
  201. package/package.json +96 -20
  202. package/public-api.d.ts +1 -0
  203. package/search-address/dialog/dialog.component.d.ts +3 -0
  204. package/search-address/package.json +5 -6
  205. package/search-address/sk-front-lib-search-address.d.ts +1 -2
  206. package/search-address/sk-search-address.directive.d.ts +3 -0
  207. package/search-address/sk-search-address.module.d.ts +12 -0
  208. package/search-address/sk-search-address.service.d.ts +3 -0
  209. package/sk-front-lib.d.ts +1 -1
  210. package/uploader/package.json +5 -6
  211. package/uploader/sk-front-lib-uploader.d.ts +1 -1
  212. package/uploader/sk-uploader.component.d.ts +3 -0
  213. package/uploader/sk-uploader.directive.d.ts +3 -0
  214. package/uploader/sk-uploader.module.d.ts +14 -0
  215. package/api/sk-front-lib-api.metadata.json +0 -1
  216. package/article/sk-front-lib-article.metadata.json +0 -1
  217. package/bundles/sk-front-lib-api.umd.js +0 -230
  218. package/bundles/sk-front-lib-api.umd.js.map +0 -1
  219. package/bundles/sk-front-lib-api.umd.min.js +0 -2
  220. package/bundles/sk-front-lib-api.umd.min.js.map +0 -1
  221. package/bundles/sk-front-lib-article.umd.js +0 -772
  222. package/bundles/sk-front-lib-article.umd.js.map +0 -1
  223. package/bundles/sk-front-lib-article.umd.min.js +0 -2
  224. package/bundles/sk-front-lib-article.umd.min.js.map +0 -1
  225. package/bundles/sk-front-lib-crud.umd.js +0 -1846
  226. package/bundles/sk-front-lib-crud.umd.js.map +0 -1
  227. package/bundles/sk-front-lib-crud.umd.min.js +0 -2
  228. package/bundles/sk-front-lib-crud.umd.min.js.map +0 -1
  229. package/bundles/sk-front-lib-google-analytics.umd.js +0 -673
  230. package/bundles/sk-front-lib-google-analytics.umd.js.map +0 -1
  231. package/bundles/sk-front-lib-google-analytics.umd.min.js +0 -16
  232. package/bundles/sk-front-lib-google-analytics.umd.min.js.map +0 -1
  233. package/bundles/sk-front-lib-image.umd.js +0 -312
  234. package/bundles/sk-front-lib-image.umd.js.map +0 -1
  235. package/bundles/sk-front-lib-image.umd.min.js +0 -2
  236. package/bundles/sk-front-lib-image.umd.min.js.map +0 -1
  237. package/bundles/sk-front-lib-model.umd.js +0 -1464
  238. package/bundles/sk-front-lib-model.umd.js.map +0 -1
  239. package/bundles/sk-front-lib-model.umd.min.js +0 -16
  240. package/bundles/sk-front-lib-model.umd.min.js.map +0 -1
  241. package/bundles/sk-front-lib-search-address.umd.js +0 -182
  242. package/bundles/sk-front-lib-search-address.umd.js.map +0 -1
  243. package/bundles/sk-front-lib-search-address.umd.min.js +0 -2
  244. package/bundles/sk-front-lib-search-address.umd.min.js.map +0 -1
  245. package/bundles/sk-front-lib-uploader.umd.js +0 -534
  246. package/bundles/sk-front-lib-uploader.umd.js.map +0 -1
  247. package/bundles/sk-front-lib-uploader.umd.min.js +0 -2
  248. package/bundles/sk-front-lib-uploader.umd.min.js.map +0 -1
  249. package/bundles/sk-front-lib.umd.js +0 -546
  250. package/bundles/sk-front-lib.umd.js.map +0 -1
  251. package/bundles/sk-front-lib.umd.min.js +0 -2
  252. package/bundles/sk-front-lib.umd.min.js.map +0 -1
  253. package/crud/sk-front-lib-crud.metadata.json +0 -1
  254. package/esm2015/api/sk-api.module.js +0 -24
  255. package/esm2015/api/sk-api.service.js +0 -144
  256. package/esm2015/article/sk-article-editor-server.component.js +0 -54
  257. package/esm2015/article/sk-article-editor.component.js +0 -85
  258. package/esm2015/article/sk-article-server.module.js +0 -26
  259. package/esm2015/article/sk-article.module.js +0 -23
  260. package/esm2015/article/sk-article.service.js +0 -235
  261. package/esm2015/article/sk-froala-editor.directive.js +0 -320
  262. package/esm2015/crud/sk-account.service.js +0 -38
  263. package/esm2015/crud/sk-auth-admin.guard.js +0 -35
  264. package/esm2015/crud/sk-auth.guard.js +0 -35
  265. package/esm2015/crud/sk-auth.service.js +0 -71
  266. package/esm2015/crud/sk-board.service.js +0 -55
  267. package/esm2015/crud/sk-brand.service.js +0 -47
  268. package/esm2015/crud/sk-cart.service.js +0 -260
  269. package/esm2015/crud/sk-category.service.js +0 -64
  270. package/esm2015/crud/sk-comment.service.js +0 -44
  271. package/esm2015/crud/sk-config.service.js +0 -33
  272. package/esm2015/crud/sk-contact.service.js +0 -40
  273. package/esm2015/crud/sk-coupon.service.js +0 -63
  274. package/esm2015/crud/sk-document.service.js +0 -96
  275. package/esm2015/crud/sk-etc.service.js +0 -27
  276. package/esm2015/crud/sk-file.service.js +0 -38
  277. package/esm2015/crud/sk-front-lib-crud.js +0 -6
  278. package/esm2015/crud/sk-keyword.service.js +0 -47
  279. package/esm2015/crud/sk-order.service.js +0 -134
  280. package/esm2015/crud/sk-point.service.js +0 -46
  281. package/esm2015/crud/sk-product.service.js +0 -154
  282. package/esm2015/crud/sk-promotion.service.js +0 -82
  283. package/esm2015/crud/sk-search.service.js +0 -26
  284. package/esm2015/crud/sk-store.service.js +0 -48
  285. package/esm2015/crud/sk-user.service.js +0 -70
  286. package/esm2015/google-analytics/google-analytics-router.module.js +0 -19
  287. package/esm2015/google-analytics/google-analytics.module.js +0 -33
  288. package/esm2015/google-analytics/initializers/google-analytics-router.initializer.js +0 -25
  289. package/esm2015/google-analytics/initializers/google-analytics.initializer.js +0 -47
  290. package/esm2015/google-analytics/services/google-analytics.service.js +0 -199
  291. package/esm2015/image/public_api.js +0 -2
  292. package/esm2015/image/sk-front-lib-image.js +0 -6
  293. package/esm2015/image/sk-image.component.js +0 -258
  294. package/esm2015/image/sk-image.module.js +0 -28
  295. package/esm2015/lib/sk-byte.pipe.js +0 -14
  296. package/esm2015/lib/sk-date-time.pipe.js +0 -12
  297. package/esm2015/lib/sk-date.pipe.js +0 -12
  298. package/esm2015/lib/sk-front-lib.module.js +0 -29
  299. package/esm2015/lib/sk-keys.pipe.js +0 -19
  300. package/esm2015/lib/sk-time.pipe.js +0 -12
  301. package/esm2015/model/lib/promotion.js +0 -72
  302. package/esm2015/search-address/dialog/dialog.component.js +0 -28
  303. package/esm2015/search-address/sk-front-lib-search-address.js +0 -7
  304. package/esm2015/search-address/sk-search-address.directive.js +0 -39
  305. package/esm2015/search-address/sk-search-address.module.js +0 -34
  306. package/esm2015/sk-front-lib.js +0 -6
  307. package/esm2015/uploader/sk-front-lib-uploader.js +0 -6
  308. package/esm2015/uploader/sk-uploader.component.js +0 -106
  309. package/esm2015/uploader/sk-uploader.directive.js +0 -40
  310. package/esm2015/uploader/sk-uploader.module.js +0 -39
  311. package/fesm2015/sk-front-lib-api.js.map +0 -1
  312. package/fesm2015/sk-front-lib-article.js.map +0 -1
  313. package/fesm2015/sk-front-lib-crud.js.map +0 -1
  314. package/fesm2015/sk-front-lib-google-analytics.js.map +0 -1
  315. package/fesm2015/sk-front-lib-image.js.map +0 -1
  316. package/fesm2015/sk-front-lib-model.js.map +0 -1
  317. package/fesm2015/sk-front-lib-search-address.js +0 -166
  318. package/fesm2015/sk-front-lib-search-address.js.map +0 -1
  319. package/fesm2015/sk-front-lib-uploader.js +0 -510
  320. package/fesm2015/sk-front-lib-uploader.js.map +0 -1
  321. package/fesm2015/sk-front-lib.js.map +0 -1
  322. package/google-analytics/sk-front-lib-google-analytics.metadata.json +0 -1
  323. package/image/sk-front-lib-image.metadata.json +0 -1
  324. package/model/sk-front-lib-model.metadata.json +0 -1
  325. package/search-address/sk-front-lib-search-address.metadata.json +0 -1
  326. package/sk-front-lib.metadata.json +0 -1
  327. package/uploader/sk-front-lib-uploader.metadata.json +0 -1
@@ -1,510 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component, ViewEncapsulation, Inject, ViewChild, HostListener, EventEmitter, Directive, Input, Output, NgModule } from '@angular/core';
3
- import { MatButtonModule } from '@angular/material/button';
4
- import { MAT_DIALOG_DATA, MatDialogRef, MatDialog, MatDialogModule } from '@angular/material/dialog';
5
- import { MatIconModule } from '@angular/material/icon';
6
- import { MatListModule } from '@angular/material/list';
7
- import { MatProgressBarModule } from '@angular/material/progress-bar';
8
- import { MatToolbarModule } from '@angular/material/toolbar';
9
- import { SkFrontLibModule } from 'sk-front-lib';
10
- import { SkApiService } from 'sk-front-lib/api';
11
- import { FileType, SkFile } from 'sk-front-lib/model';
12
- import { animation, style, animate, trigger, transition, useAnimation, query, stagger, animateChild } from '@angular/animations';
13
- import { HttpRequest, HttpHeaders, HttpEventType } from '@angular/common/http';
14
- import { of } from 'rxjs';
15
- import { tap, last, map, catchError } from 'rxjs/operators';
16
- import { isArray } from 'lodash';
17
-
18
- var SkUploaderFileItemType;
19
- (function (SkUploaderFileItemType) {
20
- SkUploaderFileItemType[SkUploaderFileItemType["Local"] = 0] = "Local";
21
- SkUploaderFileItemType[SkUploaderFileItemType["API"] = 1] = "API";
22
- SkUploaderFileItemType[SkUploaderFileItemType["Unidentified"] = 2] = "Unidentified";
23
- })(SkUploaderFileItemType || (SkUploaderFileItemType = {}));
24
- var SkUploaderFileItemStatus;
25
- (function (SkUploaderFileItemStatus) {
26
- SkUploaderFileItemStatus[SkUploaderFileItemStatus["WAIT"] = 0] = "WAIT";
27
- SkUploaderFileItemStatus[SkUploaderFileItemStatus["READY"] = 1] = "READY";
28
- SkUploaderFileItemStatus[SkUploaderFileItemStatus["UPLOADING"] = 2] = "UPLOADING";
29
- SkUploaderFileItemStatus[SkUploaderFileItemStatus["PROCESS"] = 3] = "PROCESS";
30
- SkUploaderFileItemStatus[SkUploaderFileItemStatus["DONE"] = 4] = "DONE";
31
- SkUploaderFileItemStatus[SkUploaderFileItemStatus["ERROR"] = 5] = "ERROR";
32
- })(SkUploaderFileItemStatus || (SkUploaderFileItemStatus = {}));
33
- class SkUploaderFileItem {
34
- constructor(localFile, skFile) {
35
- this.localFile = localFile;
36
- this.skFile = skFile;
37
- this.state = SkUploaderFileItemStatus.WAIT;
38
- this.progress = 0;
39
- if (this.localFile && !this.skFile) {
40
- this.itemType = SkUploaderFileItemType.Local;
41
- }
42
- else if (!this.localFile && this.skFile) {
43
- this.itemType = SkUploaderFileItemType.API;
44
- this.state = SkUploaderFileItemStatus.DONE;
45
- this.progress = 100;
46
- }
47
- else {
48
- this.itemType = SkUploaderFileItemType.Unidentified;
49
- }
50
- }
51
- get filename() {
52
- if (this.itemType === SkUploaderFileItemType.Local) {
53
- return this.localFile.name;
54
- }
55
- else if (this.itemType === SkUploaderFileItemType.API) {
56
- return this.skFile.sourceFilename;
57
- }
58
- else {
59
- return 'Unknown File';
60
- }
61
- }
62
- get size() {
63
- if (this.itemType === SkUploaderFileItemType.Local) {
64
- return this.localFile.size;
65
- }
66
- else if (this.itemType === SkUploaderFileItemType.API) {
67
- return this.skFile.fileSize;
68
- }
69
- else {
70
- return -1;
71
- }
72
- }
73
- get mime() {
74
- if (this.itemType === SkUploaderFileItemType.Local) {
75
- return this.localFile.type;
76
- }
77
- else if (this.itemType === SkUploaderFileItemType.API) {
78
- return this.skFile.mime;
79
- }
80
- else {
81
- return '';
82
- }
83
- }
84
- get icon() {
85
- if (this.itemType === SkUploaderFileItemType.Local) {
86
- return FileType.getMimeClass(this.localFile);
87
- }
88
- else if (this.itemType === SkUploaderFileItemType.API) {
89
- return FileType.getMimeClass(this.skFile);
90
- }
91
- else {
92
- return 'application';
93
- }
94
- }
95
- // -----------------------------------------------------------------------------------------------------
96
- // @ Static Builder
97
- // -----------------------------------------------------------------------------------------------------
98
- static fromLocalFile(localFile) {
99
- return new SkUploaderFileItem(localFile);
100
- }
101
- static fromApi(skFile) {
102
- return new SkUploaderFileItem(null, skFile);
103
- }
104
- // -----------------------------------------------------------------------------------------------------
105
- // @ State Method
106
- // -----------------------------------------------------------------------------------------------------
107
- prepareUpload() {
108
- this.state = SkUploaderFileItemStatus.READY;
109
- }
110
- }
111
-
112
- const customAnimation = animation([
113
- style({
114
- opacity: '{{opacity}}',
115
- transform: 'scale({{scale}}) translate3d({{x}}, {{y}}, {{z}})'
116
- }),
117
- animate('{{duration}} {{delay}} cubic-bezier(0.0, 0.0, 0.2, 1)', style('*'))
118
- ], {
119
- params: {
120
- duration: '200ms',
121
- delay: '0ms',
122
- opacity: '0',
123
- scale: '1',
124
- x: '0',
125
- y: '0',
126
- z: '0'
127
- }
128
- });
129
- const customOutAnimation = animation([
130
- style('*'),
131
- animate('{{duration}} {{delay}} cubic-bezier(0.0, 0.0, 0.2, 1)', style({
132
- opacity: '{{opacity}}',
133
- transform: 'scale({{scale}}) translate3d({{x}}, {{y}}, {{z}})'
134
- }))
135
- ], {
136
- params: {
137
- duration: '200ms',
138
- delay: '0ms',
139
- opacity: '0',
140
- scale: '1',
141
- x: '0',
142
- y: '0',
143
- z: '0'
144
- }
145
- });
146
- const uploaderAnimations = [
147
- trigger('animate', [transition('void => *', [useAnimation(customAnimation)])]),
148
- trigger('animateOut', [transition('* => void', [useAnimation(customOutAnimation)])]),
149
- trigger('animateStagger', [
150
- transition('* => *', query('@*', [
151
- stagger('100ms', [
152
- animateChild()
153
- ])
154
- ], { optional: true })),
155
- ]),
156
- ];
157
-
158
- class SkFileUploader {
159
- constructor(apiService, options, selectedFiles = []) {
160
- this.apiService = apiService;
161
- this.queue = [];
162
- this.progress = 0;
163
- this.options = {
164
- autoUpload: false,
165
- filters: [],
166
- maxFileSize: 2 * 1024 * 1024 * 1024,
167
- queueLimit: 1,
168
- asyncLimit: 2,
169
- };
170
- this.setOptions(options);
171
- this.setSelectedFiles(selectedFiles);
172
- }
173
- // -----------------------------------------------------------------------------------------------------
174
- // @ Data Accessor
175
- // -----------------------------------------------------------------------------------------------------
176
- // -----------------------------------------------------------------------------------------------------
177
- // @ Uploader - Public methods
178
- // -----------------------------------------------------------------------------------------------------
179
- setOptions(options) {
180
- this.options = Object.assign(this.options, options);
181
- this.options.filters.unshift({ name: 'queueLimit', fn: this._queueLimitFilter });
182
- if (this.options.maxFileSize) {
183
- this.options.filters.unshift({ name: 'fileSize', fn: this._fileSizeFilter });
184
- }
185
- if (this.options.allowedFileType) {
186
- this.options.filters.unshift({ name: 'fileType', fn: this._fileTypeFilter });
187
- }
188
- if (this.options.allowedMimeType) {
189
- this.options.filters.unshift({ name: 'mimeType', fn: this._mimeTypeFilter });
190
- }
191
- }
192
- setSelectedFiles(files) {
193
- const items = files.map(file => SkUploaderFileItem.fromApi(file));
194
- this.addToQueue(items);
195
- }
196
- addToQueue(files, filters) {
197
- const arrayOfFilters = this._getFilters(filters);
198
- files.forEach(item => {
199
- if (this._isValidFile(item, arrayOfFilters, this.options) && !this._findByFilenameInQueue(item.filename)) {
200
- this.queue.push(item);
201
- }
202
- });
203
- this.updateProgress();
204
- }
205
- removeFromQueue(file) {
206
- const index = this.queue.findIndex(value => value.filename === file.filename);
207
- this.queue.splice(index, 1);
208
- this.updateProgress();
209
- }
210
- clearQueue() {
211
- while (this.queue.length) {
212
- this.removeFromQueue(this.queue[0]);
213
- }
214
- this.progress = 0;
215
- }
216
- upload(item) {
217
- this._processUpload(item);
218
- }
219
- uploadAll() {
220
- const targetItems = this.getNotUploadedItems();
221
- targetItems.forEach(item => {
222
- item.prepareUpload();
223
- });
224
- if (targetItems.length > 0) {
225
- const max = Math.min(targetItems.length, this.options.asyncLimit);
226
- for (let i = 0; i < max; i++) {
227
- this.upload(targetItems[i]);
228
- }
229
- }
230
- }
231
- // -----------------------------------------------------------------------------------------------------
232
- // @ Private methods.
233
- // -----------------------------------------------------------------------------------------------------
234
- updateProgress() {
235
- const uploaded = this.getDoneItems().length;
236
- const current = uploaded / this.queue.length * 100;
237
- this.progress = Math.ceil(current);
238
- }
239
- // -----------------------------------------------------------------------------------------------------
240
- // @ Uploader - Filters
241
- // -----------------------------------------------------------------------------------------------------
242
- _isValidFile(file, filters, options) {
243
- this._failFilterIndex = -1;
244
- return !filters.length ? true : filters.every((filter) => {
245
- this._failFilterIndex++;
246
- return filter.fn.call(this, file, options);
247
- });
248
- }
249
- _getFilters(filters) {
250
- if (!filters) {
251
- return this.options.filters;
252
- }
253
- if (Array.isArray(filters)) {
254
- return filters;
255
- }
256
- if (typeof filters === 'string') {
257
- const names = filters.match(/[^\s,]+/g);
258
- return this.options.filters
259
- .filter((filter) => names.indexOf(filter.name) !== -1);
260
- }
261
- return this.options.filters;
262
- }
263
- _queueLimitFilter() {
264
- return this.options.queueLimit === undefined || this.queue.length < this.options.queueLimit;
265
- }
266
- _mimeTypeFilter(item) {
267
- return !(this.options.allowedMimeType && this.options.allowedMimeType.indexOf(item.mime) === -1);
268
- }
269
- _fileSizeFilter(item) {
270
- return !(this.options.maxFileSize && item.size > this.options.maxFileSize);
271
- }
272
- _fileTypeFilter(item) {
273
- return !(this.options.allowedFileType &&
274
- this.options.allowedFileType.indexOf(FileType.getMimeClass(item.localFile ? item.localFile : item.skFile)) === -1);
275
- }
276
- // -----------------------------------------------------------------------------------------------------
277
- // @ Uploader - Upload biz logic
278
- // -----------------------------------------------------------------------------------------------------
279
- _processUpload(item) {
280
- if (item.state !== SkUploaderFileItemStatus.READY) {
281
- return;
282
- }
283
- const formData = new FormData();
284
- formData.append('file', item.localFile, item.filename);
285
- const request = new HttpRequest('POST', this.apiService.apiServer + '/api/public/files/upload', formData, {
286
- reportProgress: true,
287
- headers: new HttpHeaders().set('Authorization', 'Bearer ' + this.apiService.getToken()).set('ngsw-bypass', 'true')
288
- });
289
- this.apiService.rawRequest(request).pipe(tap(event => {
290
- switch (event.type) {
291
- case HttpEventType.UploadProgress:
292
- // Compute and show the % done:
293
- const percentDone = Math.ceil(100 * event.loaded / event.total);
294
- item.progress = percentDone;
295
- if (item.progress >= 99) {
296
- item.state = SkUploaderFileItemStatus.PROCESS;
297
- }
298
- else {
299
- item.state = SkUploaderFileItemStatus.UPLOADING;
300
- }
301
- return;
302
- case HttpEventType.Response:
303
- item.state = SkUploaderFileItemStatus.DONE;
304
- return;
305
- default:
306
- return;
307
- }
308
- }), last(), // return last (completed) message to caller
309
- map((result) => result.body.data ? new SkFile(result.body.data) : null), catchError(err => {
310
- console.log(err);
311
- item.state = SkUploaderFileItemStatus.ERROR;
312
- return of(null);
313
- })).subscribe(result => {
314
- if (result instanceof SkFile) {
315
- item.skFile = result;
316
- }
317
- this.updateProgress();
318
- const nextItems = this.getReadyItems();
319
- if (nextItems.length > 0) {
320
- this.upload(nextItems[0]);
321
- }
322
- });
323
- }
324
- // -----------------------------------------------------------------------------------------------------
325
- // @ Data Handlers
326
- // -----------------------------------------------------------------------------------------------------
327
- _findByFilenameInQueue(name) {
328
- return this.queue.findIndex(value => value.filename === name) > -1;
329
- }
330
- getNotUploadedItems() {
331
- return this.queue.filter((item) => item.state === SkUploaderFileItemStatus.WAIT);
332
- }
333
- getReadyItems() {
334
- return this.queue.filter((item) => item.state === SkUploaderFileItemStatus.READY);
335
- }
336
- getDoneItems() {
337
- return this.queue.filter((item) => item.state === SkUploaderFileItemStatus.DONE);
338
- }
339
- }
340
-
341
- class SkUploaderComponent {
342
- constructor(data, dialogRef, _apiService) {
343
- this.data = data;
344
- this.dialogRef = dialogRef;
345
- this._apiService = _apiService;
346
- this.dragClassActive = false;
347
- this.uploader = new SkFileUploader(this._apiService, data.options, data.selectedFile);
348
- }
349
- static _getTransfer(event) {
350
- return event.dataTransfer ? event.dataTransfer : event.originalEvent.dataTransfer;
351
- }
352
- static _haveFiles(types) {
353
- if (!types) {
354
- return false;
355
- }
356
- if (types.indexOf) {
357
- return types.indexOf('Files') !== -1;
358
- }
359
- else if (types.contains) {
360
- return types.contains('Files');
361
- }
362
- else {
363
- return false;
364
- }
365
- }
366
- ngOnInit() {
367
- }
368
- save() {
369
- this.dialogRef.close(this.uploader.getDoneItems());
370
- }
371
- onDrop(event) {
372
- const transfer = SkUploaderComponent._getTransfer(event);
373
- if (!transfer) {
374
- return;
375
- }
376
- this.preventAndStop(event);
377
- this.fileAdd(transfer.files);
378
- this.dragClassActive = false;
379
- }
380
- onDragOver(event) {
381
- const transfer = SkUploaderComponent._getTransfer(event);
382
- if (!SkUploaderComponent._haveFiles(transfer.types)) {
383
- return;
384
- }
385
- this.preventAndStop(event);
386
- this.dragClassActive = true;
387
- }
388
- onDragLeave(event) {
389
- if (event.relatedTarget === this.dragEl.nativeElement) {
390
- return;
391
- }
392
- this.preventAndStop(event);
393
- this.dragClassActive = false;
394
- }
395
- // File methods
396
- // onFile
397
- fileAdd(files) {
398
- if (!(files instanceof FileList)) {
399
- return;
400
- }
401
- const list = [];
402
- for (let i = 0; i < files.length; i++) {
403
- list.push(SkUploaderFileItem.fromLocalFile(files.item(i)));
404
- }
405
- this.uploader.addToQueue(list);
406
- }
407
- onBrowseFileComplete() {
408
- const files = this.fileEl.nativeElement.files;
409
- this.fileAdd(files);
410
- }
411
- onDragComponentClick() {
412
- this.fileEl.nativeElement.click();
413
- }
414
- preventAndStop(event) {
415
- event.preventDefault();
416
- event.stopPropagation();
417
- }
418
- }
419
- SkUploaderComponent.decorators = [
420
- { type: Component, args: [{
421
- selector: 'sk-uploader',
422
- template: "<mat-toolbar class=\"dialog-title\" color=\"primary\">\n <span class=\"title dialog-title\">File Uploader</span>\n <div class=\"space-fill\"></div>\n <button mat-icon-button mat-dialog-close aria-label=\"Close dialog\">\n <mat-icon>close</mat-icon>\n </button>\n</mat-toolbar>\n<div class=\"dialog-content\">\n <input type=\"file\" style=\"display: none\" #file (change)=\"onBrowseFileComplete()\" multiple />\n <div class=\"drag-section\" #drag (click)=\"onDragComponentClick()\" [class.active]=\"dragClassActive\">\n <mat-icon>cloud_upload</mat-icon>\n <p>Drag and drop or <strong>click to browse</strong></p>\n </div>\n <mat-list [@animateStagger]=\"{value:uploader.queue.length}\">\n <h3 mat-subheader>Selected Files ({{uploader.queue.length}})</h3>\n <mat-list-item class=\"selected-file\" *ngFor=\"let file of uploader.queue\"\n [@animate]=\"{value:'*',params:{x:'-25px', opacity:'0',duration:'200ms'}}\"\n [@animateOut]=\"{value:'*',params:{delay:'100ms',x:'-25px', opacity:'0',duration:'200ms'}}\"\n dense>\n <mat-icon class=\"type-icon\" [ngClass]=\"file.icon\" matListIcon></mat-icon>\n <div mat-line>\n <span class=\"file-name\">{{ file.filename }}</span>\n <span>{{ file.size | skByte }}</span>\n </div>\n <mat-progress-bar mat-line [mode]=\"file.state == 3 ? 'query' : 'determinate'\" [value]=\"file.progress\" color=\"accent\"></mat-progress-bar>\n <div mat-line>\n <ng-container [ngSwitch]=\"file.state\">\n <div *ngSwitchCase=\"0\">\n Selected\n </div>\n <div *ngSwitchCase=\"1\">\n Wait for upload\n </div>\n <div *ngSwitchCase=\"2\">\n Uploading\n </div>\n <div *ngSwitchCase=\"3\">\n Processing..\n </div>\n <div *ngSwitchCase=\"4\">\n Done.\n </div>\n <div *ngSwitchCase=\"5\">\n Failed\n </div>\n </ng-container>\n </div>\n <button mat-icon-button (click)=\"uploader.removeFromQueue(file)\">\n <mat-icon>delete</mat-icon>\n </button>\n </mat-list-item>\n <mat-divider *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\"></mat-divider>\n <mat-list-item class=\"empty\" *ngIf=\"uploader.queue.length === 0\"\n [@animate]=\"{value:'*',params:{delay: '300ms', opacity:'0',duration:'200ms'}}\">\n <h2 mat-line>No file selected..</h2>\n </mat-list-item>\n </mat-list>\n</div>\n<mat-progress-bar mat-line mode=\"determinate\" [value]=\"uploader.progress\"></mat-progress-bar>\n<div class=\"dialog-actions\">\n <div>\n <button mat-flat-button color=\"warn\" (click)=\"uploader.clearQueue()\" [disabled]=\"uploader.queue.length === 0\">Clear all</button>\n </div>\n <div>\n <button mat-flat-button color=\"primary\"\n *ngIf=\"uploader.getNotUploadedItems().length > 0\"\n (click)=\"uploader.uploadAll()\">Start Upload</button>\n <button mat-flat-button color=\"accent\"\n *ngIf=\"uploader.getDoneItems().length === uploader.queue.length && uploader.getDoneItems().length > 0 \"\n style=\"margin-left: 8px\" (click)=\"save()\">Save</button>\n </div>\n</div>\n",
423
- encapsulation: ViewEncapsulation.None,
424
- animations: uploaderAnimations,
425
- styles: ["sk-uploader{display:flex;flex-direction:column;min-width:50vw;position:relative}sk-uploader .dialog-title{flex-shrink:0}sk-uploader .dialog-title .space-fill{flex:1 0 auto}sk-uploader .dialog-content{padding:16px;margin:0;overflow:scroll;overflow-x:hidden;flex:0 0 500px;max-height:500px}sk-uploader .dialog-content .drag-section{border:3px dashed #ccc;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}sk-uploader .dialog-content .drag-section .mat-icon{width:64px;height:64px;line-height:64px;font-size:64px}sk-uploader .dialog-content .drag-section p{cursor:pointer;font-size:14px}sk-uploader .dialog-content .drag-section .mat-icon,sk-uploader .dialog-content .drag-section p{color:#ccc}sk-uploader .dialog-content .drag-section.active{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;z-index:10;background-color:#2c393f}sk-uploader .dialog-content mat-list mat-list-item.selected-file{box-shadow:0 2px 1px -1px rgba(0,0,0,.2),0 1px 1px 0 rgba(0,0,0,.14),0 1px 3px 0 rgba(0,0,0,.12);margin-bottom:8px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-list-icon,sk-uploader .dialog-content mat-list mat-list-item.selected-file mat-icon{width:32px!important;height:32px!important;line-height:32px!important;font-size:32px!important}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-icon-button{margin-left:16px}sk-uploader .dialog-content mat-list mat-list-item.selected-file .mat-line{display:flex;flex-direction:row;align-items:center;justify-content:space-between}sk-uploader .dialog-content mat-list mat-list-item.selected-file .file-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}sk-uploader .dialog-actions{padding:16px;flex-shrink:0;border-top:1px solid rgba(0,0,0,.12);display:flex;justify-content:space-between}"]
426
- },] }
427
- ];
428
- SkUploaderComponent.ctorParameters = () => [
429
- { type: undefined, decorators: [{ type: Inject, args: [MAT_DIALOG_DATA,] }] },
430
- { type: MatDialogRef },
431
- { type: SkApiService }
432
- ];
433
- SkUploaderComponent.propDecorators = {
434
- fileEl: [{ type: ViewChild, args: ['file', { static: false },] }],
435
- dragEl: [{ type: ViewChild, args: ['drag', { static: false },] }],
436
- onDrop: [{ type: HostListener, args: ['drop', ['$event'],] }],
437
- onDragOver: [{ type: HostListener, args: ['dragover', ['$event'],] }],
438
- onDragLeave: [{ type: HostListener, args: ['dragleave', ['$event'],] }]
439
- };
440
-
441
- class SkUploaderDirective {
442
- constructor(_dialog) {
443
- this._dialog = _dialog;
444
- this.skUploaderFileSelected = new EventEmitter();
445
- }
446
- onClick() {
447
- this._dialog.open(SkUploaderComponent, {
448
- panelClass: 'mat-dialog-no-padding',
449
- closeOnNavigation: true,
450
- autoFocus: false,
451
- data: {
452
- options: this.skUploaderOptions,
453
- selectedFile: !this.skSelected ? [] : (isArray(this.skSelected) ? this.skSelected : [this.skSelected])
454
- }
455
- }).afterClosed().subscribe((result) => {
456
- if (result) {
457
- this.skUploaderFileSelected.emit(result.map(item => item.skFile));
458
- }
459
- });
460
- }
461
- }
462
- SkUploaderDirective.decorators = [
463
- { type: Directive, args: [{
464
- selector: '[skUploader]'
465
- },] }
466
- ];
467
- SkUploaderDirective.ctorParameters = () => [
468
- { type: MatDialog }
469
- ];
470
- SkUploaderDirective.propDecorators = {
471
- skUploaderOptions: [{ type: Input }],
472
- skSelected: [{ type: Input }],
473
- skUploaderFileSelected: [{ type: Output }],
474
- onClick: [{ type: HostListener, args: ['click',] }]
475
- };
476
-
477
- class SkUploaderModule {
478
- }
479
- SkUploaderModule.decorators = [
480
- { type: NgModule, args: [{
481
- imports: [
482
- CommonModule,
483
- MatDialogModule,
484
- MatToolbarModule,
485
- MatButtonModule,
486
- MatIconModule,
487
- MatListModule,
488
- MatProgressBarModule,
489
- SkFrontLibModule
490
- ],
491
- declarations: [
492
- SkUploaderComponent,
493
- SkUploaderDirective
494
- ],
495
- exports: [
496
- SkUploaderComponent,
497
- SkUploaderDirective
498
- ],
499
- entryComponents: [
500
- SkUploaderComponent
501
- ]
502
- },] }
503
- ];
504
-
505
- /**
506
- * Generated bundle index. Do not edit.
507
- */
508
-
509
- export { SkUploaderComponent, SkUploaderDirective, SkUploaderModule, uploaderAnimations as ɵa };
510
- //# sourceMappingURL=sk-front-lib-uploader.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sk-front-lib-uploader.js","sources":["../../../projects/sk-front-lib/uploader/src/sk-uploader-file-item.model.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.animation.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.class.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.component.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.directive.ts","../../../projects/sk-front-lib/uploader/src/sk-uploader.module.ts","../../../projects/sk-front-lib/uploader/src/sk-front-lib-uploader.ts"],"sourcesContent":["import {FileType, SkFile} from 'sk-front-lib/model';\n\nexport enum SkUploaderFileItemType {\n Local,\n API,\n Unidentified\n}\n\nexport enum SkUploaderFileItemStatus {\n WAIT,\n READY,\n UPLOADING,\n PROCESS,\n DONE,\n ERROR\n}\n\nexport class SkUploaderFileItem {\n\n private constructor(localFile?: File, skFile?: SkFile) {\n this.localFile = localFile;\n this.skFile = skFile;\n\n this.state = SkUploaderFileItemStatus.WAIT;\n this.progress = 0;\n\n if (this.localFile && !this.skFile) {\n this.itemType = SkUploaderFileItemType.Local;\n } else if (!this.localFile && this.skFile) {\n this.itemType = SkUploaderFileItemType.API;\n this.state = SkUploaderFileItemStatus.DONE;\n this.progress = 100;\n } else {\n this.itemType = SkUploaderFileItemType.Unidentified;\n }\n }\n\n get filename(): string {\n if (this.itemType === SkUploaderFileItemType.Local) {\n return this.localFile.name;\n } else if (this.itemType === SkUploaderFileItemType.API) {\n return this.skFile.sourceFilename;\n } else {\n return 'Unknown File';\n }\n }\n\n get size(): number {\n if (this.itemType === SkUploaderFileItemType.Local) {\n return this.localFile.size;\n } else if (this.itemType === SkUploaderFileItemType.API) {\n return this.skFile.fileSize;\n } else {\n return -1;\n }\n }\n\n get mime(): string {\n if (this.itemType === SkUploaderFileItemType.Local) {\n return this.localFile.type;\n } else if (this.itemType === SkUploaderFileItemType.API) {\n return this.skFile.mime;\n } else {\n return '';\n }\n }\n\n get icon(): string {\n if (this.itemType === SkUploaderFileItemType.Local) {\n return FileType.getMimeClass(this.localFile);\n } else if (this.itemType === SkUploaderFileItemType.API) {\n return FileType.getMimeClass(this.skFile);\n } else {\n return 'application';\n }\n }\n\n public localFile: File;\n public skFile: SkFile;\n public itemType: SkUploaderFileItemType;\n\n public state: SkUploaderFileItemStatus;\n public progress: number;\n\n\n\n // -----------------------------------------------------------------------------------------------------\n // @ Static Builder\n // -----------------------------------------------------------------------------------------------------\n\n static fromLocalFile(localFile: File): SkUploaderFileItem {\n return new SkUploaderFileItem(localFile);\n }\n\n static fromApi(skFile: SkFile): SkUploaderFileItem {\n return new SkUploaderFileItem(null, skFile);\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ State Method\n // -----------------------------------------------------------------------------------------------------\n\n public prepareUpload(): void {\n this.state = SkUploaderFileItemStatus.READY;\n }\n}\n","import {animate, animateChild, animation, query, stagger, style, transition, trigger, useAnimation} from '@angular/animations';\n\nconst customAnimation = animation([\n style({\n opacity : '{{opacity}}',\n transform: 'scale({{scale}}) translate3d({{x}}, {{y}}, {{z}})'\n }),\n animate('{{duration}} {{delay}} cubic-bezier(0.0, 0.0, 0.2, 1)', style('*'))\n], {\n params: {\n duration: '200ms',\n delay : '0ms',\n opacity : '0',\n scale : '1',\n x : '0',\n y : '0',\n z : '0'\n }\n});\n\nconst customOutAnimation = animation([\n style('*'),\n animate('{{duration}} {{delay}} cubic-bezier(0.0, 0.0, 0.2, 1)', style({\n opacity : '{{opacity}}',\n transform: 'scale({{scale}}) translate3d({{x}}, {{y}}, {{z}})'\n }))\n], {\n params: {\n duration: '200ms',\n delay : '0ms',\n opacity : '0',\n scale : '1',\n x : '0',\n y : '0',\n z : '0'\n }\n});\n\nexport const uploaderAnimations = [\n trigger('animate', [transition('void => *', [useAnimation(customAnimation)])]),\n trigger('animateOut', [transition('* => void', [useAnimation(customOutAnimation)])]),\n\n trigger('animateStagger', [\n transition('* => *',\n query('@*',\n [\n stagger('100ms', [\n animateChild()\n ])\n ], {optional: true})),\n ]),\n];\n","import {HttpEventType, HttpHeaders, HttpRequest, HttpResponse} from '@angular/common/http';\nimport {of} from 'rxjs';\nimport {catchError, last, map, tap} from 'rxjs/operators';\n\nimport {SkApiService} from 'sk-front-lib/api';\nimport {FileType, SkFile} from 'sk-front-lib/model';\nimport {SkUploaderFileItem, SkUploaderFileItemStatus} from './sk-uploader-file-item.model';\n\nexport interface FilterFunction {\n name: string;\n fn: (item?: SkUploaderFileItem, options?: SkFileUploaderOptions) => boolean;\n}\n\nexport interface SkFileUploaderOptions {\n allowedMimeType?: string[];\n allowedFileType?: string[];\n autoUpload?: boolean;\n filters?: FilterFunction[];\n maxFileSize?: number;\n queueLimit?: number;\n asyncLimit?: number;\n additionalParameter?: { [key: string]: any };\n parametersBeforeFiles?: boolean;\n}\n\nexport class SkFileUploader {\n\n public queue: SkUploaderFileItem[] = [];\n public progress = 0;\n\n private _failFilterIndex: number;\n\n public options: SkFileUploaderOptions = {\n autoUpload: false,\n filters: [],\n maxFileSize: 2 * 1024 * 1024 * 1024, // 2GB\n queueLimit: 1,\n asyncLimit: 2,\n };\n\n constructor(private apiService: SkApiService, options?: SkFileUploaderOptions, selectedFiles: SkFile[] = []) {\n this.setOptions(options);\n this.setSelectedFiles(selectedFiles);\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ Data Accessor\n // -----------------------------------------------------------------------------------------------------\n\n\n // -----------------------------------------------------------------------------------------------------\n // @ Uploader - Public methods\n // -----------------------------------------------------------------------------------------------------\n\n public setOptions(options: SkFileUploaderOptions): void {\n this.options = Object.assign(this.options, options);\n\n this.options.filters.unshift({ name: 'queueLimit', fn: this._queueLimitFilter });\n\n if (this.options.maxFileSize) {\n this.options.filters.unshift({ name: 'fileSize', fn: this._fileSizeFilter });\n }\n\n if (this.options.allowedFileType) {\n this.options.filters.unshift({ name: 'fileType', fn: this._fileTypeFilter });\n }\n\n if (this.options.allowedMimeType) {\n this.options.filters.unshift({ name: 'mimeType', fn: this._mimeTypeFilter });\n }\n }\n\n public setSelectedFiles(files: SkFile[]): void {\n const items: SkUploaderFileItem[] = files.map(file => SkUploaderFileItem.fromApi(file));\n this.addToQueue(items);\n }\n\n public addToQueue(files: SkUploaderFileItem[], filters?: FilterFunction[] | string): void {\n const arrayOfFilters = this._getFilters(filters);\n\n files.forEach(item => {\n if (this._isValidFile(item, arrayOfFilters, this.options) && !this._findByFilenameInQueue(item.filename)) {\n this.queue.push(item);\n }\n });\n\n this.updateProgress();\n }\n\n public removeFromQueue(file: SkUploaderFileItem): void {\n const index = this.queue.findIndex(value => value.filename === file.filename);\n\n this.queue.splice(index, 1);\n this.updateProgress();\n }\n\n public clearQueue(): void {\n while (this.queue.length) {\n this.removeFromQueue(this.queue[0]);\n }\n this.progress = 0;\n }\n\n public upload(item: SkUploaderFileItem) {\n this._processUpload(item);\n }\n\n public uploadAll(): void {\n const targetItems = this.getNotUploadedItems();\n targetItems.forEach(item => {\n item.prepareUpload();\n });\n\n if (targetItems.length > 0) {\n const max = Math.min(targetItems.length, this.options.asyncLimit);\n for (let i = 0; i < max; i++) {\n this.upload(targetItems[i]);\n }\n }\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ Private methods.\n // -----------------------------------------------------------------------------------------------------\n\n private updateProgress() {\n const uploaded = this.getDoneItems().length;\n const current = uploaded / this.queue.length * 100;\n this.progress = Math.ceil(current);\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ Uploader - Filters\n // -----------------------------------------------------------------------------------------------------\n\n protected _isValidFile(file: SkUploaderFileItem, filters: FilterFunction[], options: SkFileUploaderOptions): boolean {\n this._failFilterIndex = -1;\n return !filters.length ? true : filters.every((filter: FilterFunction) => {\n this._failFilterIndex++;\n return filter.fn.call(this, file, options);\n });\n }\n\n protected _getFilters(filters: FilterFunction[] | string): FilterFunction[] {\n if (!filters) {\n return this.options.filters;\n }\n if (Array.isArray(filters)) {\n return filters;\n }\n if (typeof filters === 'string') {\n const names = filters.match(/[^\\s,]+/g);\n return this.options.filters\n .filter((filter: any) => names.indexOf(filter.name) !== -1);\n }\n return this.options.filters;\n }\n\n protected _queueLimitFilter(): boolean {\n return this.options.queueLimit === undefined || this.queue.length < this.options.queueLimit;\n }\n\n public _mimeTypeFilter(item: SkUploaderFileItem): boolean {\n return !(this.options.allowedMimeType && this.options.allowedMimeType.indexOf(item.mime) === -1);\n }\n\n public _fileSizeFilter(item: SkUploaderFileItem): boolean {\n return !(this.options.maxFileSize && item.size > this.options.maxFileSize);\n }\n\n public _fileTypeFilter(item: SkUploaderFileItem): boolean {\n return !(this.options.allowedFileType &&\n this.options.allowedFileType.indexOf(FileType.getMimeClass(item.localFile ? item.localFile : item.skFile)) === -1);\n }\n\n // -----------------------------------------------------------------------------------------------------\n // @ Uploader - Upload biz logic\n // -----------------------------------------------------------------------------------------------------\n\n private _processUpload(item: SkUploaderFileItem) {\n if (item.state !== SkUploaderFileItemStatus.READY) {\n return;\n }\n\n const formData = new FormData();\n formData.append('file', item.localFile, item.filename);\n\n const request = new HttpRequest<any>('POST', this.apiService.apiServer + '/api/public/files/upload', formData, {\n reportProgress: true,\n headers: new HttpHeaders().set('Authorization', 'Bearer ' + this.apiService.getToken()).set('ngsw-bypass', 'true')\n });\n\n this.apiService.rawRequest<SkFile>(request).pipe(\n tap(event => {\n switch (event.type) {\n case HttpEventType.UploadProgress:\n // Compute and show the % done:\n const percentDone = Math.ceil(100 * event.loaded / event.total);\n item.progress = percentDone;\n\n if (item.progress >= 99) {\n item.state = SkUploaderFileItemStatus.PROCESS;\n } else {\n item.state = SkUploaderFileItemStatus.UPLOADING;\n }\n return;\n case HttpEventType.Response:\n item.state = SkUploaderFileItemStatus.DONE;\n return;\n default:\n return;\n }\n }),\n last(), // return last (completed) message to caller\n map((result: HttpResponse<any>) => result.body.data ? new SkFile(result.body.data) : null),\n catchError(err => {\n console.log(err);\n item.state = SkUploaderFileItemStatus.ERROR;\n return of(null);\n })\n ).subscribe(result => {\n if (result instanceof SkFile) {\n item.skFile = result;\n }\n\n this.updateProgress();\n const nextItems = this.getReadyItems();\n if (nextItems.length > 0) {\n this.upload(nextItems[0]);\n }\n });\n }\n\n\n\n\n\n\n\n\n // -----------------------------------------------------------------------------------------------------\n // @ Data Handlers\n // -----------------------------------------------------------------------------------------------------\n\n private _findByFilenameInQueue(name: string): boolean {\n return this.queue.findIndex(value => value.filename === name) > -1;\n }\n\n public getNotUploadedItems(): SkUploaderFileItem[] {\n return this.queue.filter((item: SkUploaderFileItem) => item.state === SkUploaderFileItemStatus.WAIT);\n }\n\n public getReadyItems(): SkUploaderFileItem[] {\n return this.queue.filter((item: SkUploaderFileItem) => item.state === SkUploaderFileItemStatus.READY);\n }\n\n public getDoneItems(): SkUploaderFileItem[] {\n return this.queue.filter((item: SkUploaderFileItem) => item.state === SkUploaderFileItemStatus.DONE);\n }\n\n}\n","import {Component, ElementRef, HostListener, Inject, OnInit, ViewChild, ViewEncapsulation} from '@angular/core';\nimport {MAT_DIALOG_DATA, MatDialogRef} from '@angular/material/dialog';\nimport {SkApiService} from 'sk-front-lib/api';\nimport {SkUploaderFileItem} from './sk-uploader-file-item.model';\nimport {uploaderAnimations} from './sk-uploader.animation';\nimport {SkFileUploader} from './sk-uploader.class';\n\n@Component({\n selector: 'sk-uploader',\n templateUrl: './sk-uploader.component.html',\n styleUrls: ['./sk-uploader.component.scss'],\n encapsulation: ViewEncapsulation.None,\n animations: uploaderAnimations\n})\nexport class SkUploaderComponent implements OnInit {\n\n constructor(@Inject(MAT_DIALOG_DATA) public data: any,\n public dialogRef: MatDialogRef<SkUploaderComponent>,\n private _apiService: SkApiService) {\n this.uploader = new SkFileUploader(this._apiService, data.options, data.selectedFile);\n }\n uploader: SkFileUploader;\n\n @ViewChild('file', {static: false})\n fileEl: ElementRef;\n\n @ViewChild('drag', {static: false})\n dragEl: ElementRef;\n\n\n dragClassActive = false;\n\n private static _getTransfer(event: any) {\n return event.dataTransfer ? event.dataTransfer : event.originalEvent.dataTransfer;\n }\n\n private static _haveFiles(types: any): any {\n if (!types) {\n return false;\n }\n\n if (types.indexOf) {\n return types.indexOf('Files') !== -1;\n } else if (types.contains) {\n return types.contains('Files');\n } else {\n return false;\n }\n }\n\n ngOnInit(): void {\n\n }\n\n save() {\n this.dialogRef.close(this.uploader.getDoneItems());\n }\n\n @HostListener('drop', ['$event'])\n public onDrop(event: any): void {\n const transfer = SkUploaderComponent._getTransfer(event);\n if (!transfer) {\n return;\n }\n this.preventAndStop(event);\n this.fileAdd(transfer.files);\n this.dragClassActive = false;\n }\n\n @HostListener('dragover', ['$event'])\n public onDragOver(event: any): void {\n const transfer = SkUploaderComponent._getTransfer(event);\n if (!SkUploaderComponent._haveFiles(transfer.types)) {\n return;\n }\n this.preventAndStop(event);\n this.dragClassActive = true;\n }\n\n @HostListener('dragleave', ['$event'])\n public onDragLeave(event: any): any {\n if (event.relatedTarget === this.dragEl.nativeElement) {\n return;\n }\n\n this.preventAndStop(event);\n this.dragClassActive = false;\n }\n\n\n // File methods\n // onFile\n\n public fileAdd(files: any) {\n if (!(files instanceof FileList)) {\n return;\n }\n\n const list: SkUploaderFileItem[] = [];\n for (let i = 0; i < files.length; i++) {\n list.push(SkUploaderFileItem.fromLocalFile(files.item(i)));\n }\n\n this.uploader.addToQueue(list);\n }\n\n public onBrowseFileComplete(): any {\n const files = this.fileEl.nativeElement.files;\n this.fileAdd(files);\n }\n\n public onDragComponentClick(): any {\n this.fileEl.nativeElement.click();\n }\n\n public preventAndStop(event: any): any {\n event.preventDefault();\n event.stopPropagation();\n }\n\n\n}\n","import {Directive, EventEmitter, HostListener, Input, Output} from '@angular/core';\nimport {MatDialog} from '@angular/material/dialog';\nimport * as _ from 'lodash';\nimport {SkFile} from 'sk-front-lib/model';\nimport {SkUploaderFileItem} from './sk-uploader-file-item.model';\nimport {SkFileUploaderOptions} from './sk-uploader.class';\nimport {SkUploaderComponent} from './sk-uploader.component';\n\n@Directive({\n selector: '[skUploader]'\n})\nexport class SkUploaderDirective {\n\n @Input() skUploaderOptions: SkFileUploaderOptions;\n @Input() skSelected: SkFile[] | SkFile;\n\n @Output() skUploaderFileSelected: EventEmitter<any> = new EventEmitter<any>();\n\n @HostListener('click') onClick() {\n this._dialog.open(SkUploaderComponent, {\n panelClass: 'mat-dialog-no-padding',\n closeOnNavigation: true,\n autoFocus: false,\n data: {\n options: this.skUploaderOptions,\n selectedFile: !this.skSelected ? [] : (_.isArray(this.skSelected) ? this.skSelected : [<SkFile>this.skSelected])\n }\n }).afterClosed().subscribe((result: SkUploaderFileItem[]) => {\n if (result) {\n this.skUploaderFileSelected.emit(result.map(item => item.skFile));\n }\n });\n }\n\n constructor(private _dialog: MatDialog) { }\n}\n","import {CommonModule} from '@angular/common';\nimport {NgModule} from '@angular/core';\nimport {MatButtonModule} from '@angular/material/button';\nimport {MatDialogModule} from '@angular/material/dialog';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatListModule} from '@angular/material/list';\nimport {MatProgressBarModule} from '@angular/material/progress-bar';\nimport {MatToolbarModule} from '@angular/material/toolbar';\n\nimport {SkFrontLibModule} from 'sk-front-lib';\n\nimport {SkUploaderComponent} from './sk-uploader.component';\nimport {SkUploaderDirective} from './sk-uploader.directive';\n\n\n@NgModule({\n imports: [\n CommonModule,\n MatDialogModule,\n MatToolbarModule,\n MatButtonModule,\n MatIconModule,\n MatListModule,\n MatProgressBarModule,\n\n SkFrontLibModule\n ],\n declarations: [\n SkUploaderComponent,\n SkUploaderDirective\n ],\n exports: [\n SkUploaderComponent,\n SkUploaderDirective\n ],\n entryComponents: [\n SkUploaderComponent\n ]\n})\nexport class SkUploaderModule {\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public_api';\n\nexport {uploaderAnimations as ɵa} from './sk-uploader.animation';"],"names":["_.isArray"],"mappings":"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"}