n20-common-lib 1.2.1 → 1.2.4

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 (186) hide show
  1. package/README.md +3 -27
  2. package/package.json +87 -87
  3. package/src/_qiankun/index.js +113 -113
  4. package/src/_qiankun/postMessage.js +48 -48
  5. package/src/assets/css/_coreLib.scss +35 -35
  6. package/src/assets/css/cl-anchor.scss +23 -23
  7. package/src/assets/css/cl-approve-card.scss +58 -58
  8. package/src/assets/css/cl-dialog.scss +99 -99
  9. package/src/assets/css/cl-drag-list.scss +22 -22
  10. package/src/assets/css/cl-empty.scss +10 -10
  11. package/src/assets/css/cl-expandable-pane.scss +26 -25
  12. package/src/assets/css/cl-expandable.scss +24 -23
  13. package/src/assets/css/cl-file-upload-table.scss +11 -11
  14. package/src/assets/css/cl-filter.scss +4 -4
  15. package/src/assets/css/cl-flow-step.scss +185 -185
  16. package/src/assets/css/cl-footer-box.scss +10 -10
  17. package/src/assets/css/cl-form-item.scss +331 -322
  18. package/src/assets/css/cl-general-card.scss +11 -11
  19. package/src/assets/css/cl-layout-aside.scss +88 -96
  20. package/src/assets/css/cl-layout-content.scss +16 -16
  21. package/src/assets/css/cl-layout-header.scss +73 -73
  22. package/src/assets/css/cl-layout-tabs.scss +87 -87
  23. package/src/assets/css/cl-layout.scss +97 -97
  24. package/src/assets/css/cl-login-temporary.scss +37 -37
  25. package/src/assets/css/cl-message.scss +75 -75
  26. package/src/assets/css/cl-more-tab.scss +98 -98
  27. package/src/assets/css/cl-nav-menu.scss +5 -5
  28. package/src/assets/css/cl-pagination.scss +65 -65
  29. package/src/assets/css/cl-secondary-tab.scss +39 -39
  30. package/src/assets/css/cl-showcolumn.scss +23 -23
  31. package/src/assets/css/cl-sifting.scss +51 -51
  32. package/src/assets/css/cl-statis.scss +42 -42
  33. package/src/assets/css/cl-step.scss +73 -73
  34. package/src/assets/css/cl-suspend.scss +19 -19
  35. package/src/assets/css/cl-tertiary-tab.scss +9 -9
  36. package/src/assets/css/cl-upload.scss +41 -41
  37. package/src/assets/css/cl-worn-pagination.scss +50 -50
  38. package/src/assets/css/el-button.scss +173 -169
  39. package/src/assets/css/el-table.scss +79 -79
  40. package/src/assets/css/element-variables.scss +1061 -1061
  41. package/src/assets/css/element.dev.scss +21 -21
  42. package/src/assets/css/font-icon.scss +26 -26
  43. package/src/assets/css/index.dev.scss +4 -4
  44. package/src/assets/css/index.scss +11 -11
  45. package/src/assets/css/normalize.scss +726 -723
  46. package/src/assets/css/rootvar.scss +139 -139
  47. package/src/assets/css/select.scss +25 -25
  48. package/src/assets/css/title-pop.scss +4 -4
  49. package/src/assets/getJsonc.js +50 -50
  50. package/src/assets/realUrl.js +12 -12
  51. package/src/components/Anchor/AnchorItem.vue +29 -29
  52. package/src/components/Anchor/index.vue +185 -185
  53. package/src/components/ApprovalButtons/index.vue +232 -232
  54. package/src/components/ApprovalCard/index.vue +128 -128
  55. package/src/components/ApprovalRecord/approvalImg.vue +39 -39
  56. package/src/components/ApprovalRecord/index.vue +59 -59
  57. package/src/components/Button/button-group.vue +150 -150
  58. package/src/components/Button/icon-group-button.vue +61 -61
  59. package/src/components/Button/index.vue +56 -56
  60. package/src/components/CascaderArea/index.vue +81 -0
  61. package/src/components/ContentLoading/index.vue +41 -41
  62. package/src/components/ContentNull/index.vue +19 -19
  63. package/src/components/DatePicker/index.vue +27 -27
  64. package/src/components/DatePicker/por.vue +169 -169
  65. package/src/components/Dialog/index.vue +26 -26
  66. package/src/components/Dialog/indexO.vue +116 -116
  67. package/src/components/DragList/index.vue +68 -68
  68. package/src/components/Empty/img/abnormal.svg +108 -108
  69. package/src/components/Empty/img/dispose.svg +71 -71
  70. package/src/components/Empty/img/empty.svg +57 -57
  71. package/src/components/Empty/img/general.svg +58 -58
  72. package/src/components/Empty/img/lock.svg +57 -57
  73. package/src/components/Empty/img/network.svg +59 -59
  74. package/src/components/Empty/img/relevant.svg +68 -68
  75. package/src/components/Empty/img/search.svg +72 -72
  76. package/src/components/Empty/index.vue +92 -92
  77. package/src/components/Expandable/index.vue +49 -49
  78. package/src/components/Expandable/main.vue +52 -52
  79. package/src/components/FileUploadTable/index.vue +484 -484
  80. package/src/components/Filters/index.vue +363 -358
  81. package/src/components/Filters/indexO.vue +104 -104
  82. package/src/components/FlowStep/index.vue +68 -68
  83. package/src/components/FooterBox/index.vue +21 -21
  84. package/src/components/GeneralCard/index.vue +15 -15
  85. package/src/components/InputNumber/index.vue +153 -153
  86. package/src/components/InputNumber/numberRange.vue +47 -47
  87. package/src/components/InputSearch/index.vue +75 -75
  88. package/src/components/Layout/AsideNav/index.vue +144 -144
  89. package/src/components/Layout/HeaderWrap/changePwd.vue +215 -215
  90. package/src/components/Layout/HeaderWrap/index.vue +333 -336
  91. package/src/components/Layout/HeaderWrap/noticePop.vue +300 -300
  92. package/src/components/Layout/SubContent/index.vue +131 -131
  93. package/src/components/Layout/TabsNav/index.vue +170 -170
  94. package/src/components/Layout/index.vue +529 -529
  95. package/src/components/Layout/utils.js +12 -12
  96. package/src/components/LoginTemporary/form.vue +537 -511
  97. package/src/components/LoginTemporary/index.vue +122 -122
  98. package/src/components/LoginTemporary/qrcode.vue +90 -90
  99. package/src/components/LoginTemporary/retrievePw.vue +28 -28
  100. package/src/components/LoginTemporary/utils.js +73 -73
  101. package/src/components/MicroApp/index.js +67 -67
  102. package/src/components/MicroFrame/index.vue +95 -95
  103. package/src/components/MoreTab/index.vue +232 -232
  104. package/src/components/NavMenu/index.vue +60 -60
  105. package/src/components/NstcG6Components/NstcDialog/NstcDialog.vue +184 -184
  106. package/src/components/PageLayout/page.vue +15 -15
  107. package/src/components/Pagination/index.vue +96 -96
  108. package/src/components/SecondaryTab/index.vue +58 -58
  109. package/src/components/SelectLazy/index.vue +75 -75
  110. package/src/components/SelectTree/SelectTreeLazy.vue +241 -241
  111. package/src/components/SelectTree/index.vue +205 -208
  112. package/src/components/ShowColumn/index.vue +204 -188
  113. package/src/components/Sifting/index.vue +99 -99
  114. package/src/components/Statis/index.vue +97 -97
  115. package/src/components/Statis/statisItem.vue +54 -54
  116. package/src/components/Statis/statisPopover.vue +55 -55
  117. package/src/components/Step/index.vue +38 -38
  118. package/src/components/Suspend/index.vue +72 -72
  119. package/src/components/Table/index.vue +170 -131
  120. package/src/components/Table/indexO.vue +149 -149
  121. package/src/components/Task/index.vue +26 -26
  122. package/src/components/TertiaryTab/index.vue +53 -53
  123. package/src/components/TimePicker/index.vue +28 -28
  124. package/src/components/Upload/index.vue +242 -242
  125. package/src/components/WornPagination/index.vue +73 -73
  126. package/src/directives/VClickOutside/index.js +19 -19
  127. package/src/directives/VHas/index.js +32 -27
  128. package/src/directives/VMove/index.js +42 -42
  129. package/src/directives/VTitle/index.js +56 -56
  130. package/src/directives/VTitle/tooltip.vue +21 -21
  131. package/src/index.js +218 -225
  132. package/src/plugins/CompatibleOld/index.js +57 -57
  133. package/src/plugins/Print/index.js +4 -4
  134. package/src/plugins/Print/print-js/.babelrc +12 -12
  135. package/src/plugins/Print/print-js/LICENSE +21 -21
  136. package/src/plugins/Print/print-js/README.md +98 -98
  137. package/src/plugins/Print/print-js/dist/print.css +96 -96
  138. package/src/plugins/Print/print-js/dist/print.js +990 -990
  139. package/src/plugins/Print/print-js/package.json +60 -60
  140. package/src/plugins/Print/print-js/src/index.d.ts +45 -45
  141. package/src/plugins/Print/print-js/src/index.js +10 -10
  142. package/src/plugins/Print/print-js/src/js/browser.js +33 -33
  143. package/src/plugins/Print/print-js/src/js/functions.js +103 -103
  144. package/src/plugins/Print/print-js/src/js/html.js +70 -70
  145. package/src/plugins/Print/print-js/src/js/image.js +48 -48
  146. package/src/plugins/Print/print-js/src/js/init.js +168 -168
  147. package/src/plugins/Print/print-js/src/js/json.js +109 -109
  148. package/src/plugins/Print/print-js/src/js/modal.js +62 -62
  149. package/src/plugins/Print/print-js/src/js/pdf.js +62 -62
  150. package/src/plugins/Print/print-js/src/js/print.js +102 -102
  151. package/src/plugins/Print/print-js/src/js/raw-html.js +15 -15
  152. package/src/plugins/Print/print-js/src/sass/index.scss +13 -13
  153. package/src/plugins/Print/print-js/src/sass/modules/_colors.scss +9 -9
  154. package/src/plugins/Print/print-js/src/sass/partials/_modal.scss +40 -40
  155. package/src/plugins/Print/print-js/src/sass/partials/_spinner.scss +45 -45
  156. package/src/plugins/Print/print.js +2 -2
  157. package/src/plugins/Print/print.scss +1 -1
  158. package/src/plugins/SetMenuTree/index.vue +41 -41
  159. package/src/plugins/SetMenuTree/logoIcon.vue +37 -37
  160. package/src/plugins/SetMenuTree/setmenutree.vue +427 -427
  161. package/src/plugins/SetMenuTree/utils.js +74 -74
  162. package/src/plugins/Sign/InfosecNetSignCNGAgent.min.js +2000 -2000
  163. package/src/plugins/Sign/index.js +65 -65
  164. package/src/plugins/Sign/sign.js +1 -1
  165. package/src/plugins/setTabsForSub.js +2 -2
  166. package/src/utils/auth.js +53 -53
  167. package/src/utils/axios.js +203 -203
  168. package/src/utils/downloadBlob.js +19 -19
  169. package/src/utils/forEachs.js +16 -16
  170. package/src/utils/getScrollContainer.js +43 -43
  171. package/src/utils/i18n/cn2hk.json +1270 -1270
  172. package/src/utils/i18n/index.js +54 -54
  173. package/src/utils/list2tree.js +36 -36
  174. package/src/utils/msgboxPor.js +26 -26
  175. package/src/utils/print.js +161 -161
  176. package/src/utils/relaNo.js +69 -35
  177. package/src/utils/repairElementUI.js +66 -66
  178. package/src/utils/urlToGo.js +82 -82
  179. package/style/css/normalize.scss +726 -723
  180. package/style/index.css +1 -1
  181. package/style/index.css.map +1 -1
  182. package/style/pageDemo/demo-1.vue +131 -130
  183. package/style/pageDemo/demo-2.vue +35 -35
  184. package/style/pageDemo/demo-3.vue +22 -22
  185. package/style/pageDemo/seeCode.js +20 -20
  186. package/style/server-config.jsonc +596 -663
@@ -1,48 +1,48 @@
1
- import { addHeader } from './functions'
2
- import Print from './print'
3
- import Browser from './browser'
4
-
5
- export default {
6
- print: (params, printFrame) => {
7
- // Check if we are printing one image or multiple images
8
- if (params.printable.constructor !== Array) {
9
- // Create array with one image
10
- params.printable = [params.printable]
11
- }
12
-
13
- // Create printable element (container)
14
- params.printableElement = document.createElement('div')
15
-
16
- // Create all image elements and append them to the printable container
17
- params.printable.forEach(src => {
18
- // Create the image element
19
- const img = document.createElement('img')
20
- img.setAttribute('style', params.imageStyle)
21
-
22
- // Set image src with the file url
23
- img.src = src
24
-
25
- // The following block is for Firefox, which for some reason requires the image's src to be fully qualified in
26
- // order to print it
27
- if (Browser.isFirefox()) {
28
- const fullyQualifiedSrc = img.src
29
- img.src = fullyQualifiedSrc
30
- }
31
-
32
- // Create the image wrapper
33
- const imageWrapper = document.createElement('div')
34
-
35
- // Append image to the wrapper element
36
- imageWrapper.appendChild(img)
37
-
38
- // Append wrapper to the printable element
39
- params.printableElement.appendChild(imageWrapper)
40
- })
41
-
42
- // Check if we are adding a print header
43
- if (params.header) addHeader(params.printableElement, params)
44
-
45
- // Print image
46
- Print.send(params, printFrame)
47
- }
48
- }
1
+ import { addHeader } from './functions'
2
+ import Print from './print'
3
+ import Browser from './browser'
4
+
5
+ export default {
6
+ print: (params, printFrame) => {
7
+ // Check if we are printing one image or multiple images
8
+ if (params.printable.constructor !== Array) {
9
+ // Create array with one image
10
+ params.printable = [params.printable]
11
+ }
12
+
13
+ // Create printable element (container)
14
+ params.printableElement = document.createElement('div')
15
+
16
+ // Create all image elements and append them to the printable container
17
+ params.printable.forEach(src => {
18
+ // Create the image element
19
+ const img = document.createElement('img')
20
+ img.setAttribute('style', params.imageStyle)
21
+
22
+ // Set image src with the file url
23
+ img.src = src
24
+
25
+ // The following block is for Firefox, which for some reason requires the image's src to be fully qualified in
26
+ // order to print it
27
+ if (Browser.isFirefox()) {
28
+ const fullyQualifiedSrc = img.src
29
+ img.src = fullyQualifiedSrc
30
+ }
31
+
32
+ // Create the image wrapper
33
+ const imageWrapper = document.createElement('div')
34
+
35
+ // Append image to the wrapper element
36
+ imageWrapper.appendChild(img)
37
+
38
+ // Append wrapper to the printable element
39
+ params.printableElement.appendChild(imageWrapper)
40
+ })
41
+
42
+ // Check if we are adding a print header
43
+ if (params.header) addHeader(params.printableElement, params)
44
+
45
+ // Print image
46
+ Print.send(params, printFrame)
47
+ }
48
+ }
@@ -1,168 +1,168 @@
1
- 'use strict'
2
-
3
- import Browser from './browser'
4
- import Modal from './modal'
5
- import Pdf from './pdf'
6
- import Html from './html'
7
- import RawHtml from './raw-html'
8
- import Image from './image'
9
- import Json from './json'
10
-
11
- const printTypes = ['pdf', 'html', 'image', 'json', 'raw-html']
12
-
13
- export default {
14
- init () {
15
- const params = {
16
- printable: null,
17
- fallbackPrintable: null,
18
- type: 'pdf',
19
- header: null,
20
- headerStyle: 'font-weight: 300;',
21
- maxWidth: 800,
22
- properties: null,
23
- gridHeaderStyle: 'font-weight: bold; padding: 5px; border: 1px solid #dddddd;',
24
- gridStyle: 'border: 1px solid lightgray; margin-bottom: -1px;',
25
- showModal: false,
26
- onError: (error) => { throw error },
27
- onLoadingStart: null,
28
- onLoadingEnd: null,
29
- onPrintDialogClose: () => {},
30
- onIncompatibleBrowser: () => {},
31
- modalMessage: '打印中...',
32
- frameId: 'printJS',
33
- printableElement: null,
34
- documentTitle: 'Document',
35
- targetStyle: ['clear', 'display', 'width', 'min-width', 'height', 'min-height', 'max-height'],
36
- targetStyles: ['border', 'box', 'break', 'text-decoration'],
37
- ignoreElements: [],
38
- repeatTableHeader: true,
39
- css: null,
40
- style: null,
41
- scanStyles: true,
42
- base64: false,
43
-
44
- // Deprecated
45
- onPdfOpen: null,
46
- font: 'TimesNewRoman',
47
- font_size: '12pt',
48
- honorMarginPadding: true,
49
- honorColor: false,
50
- imageStyle: 'max-width: 100%;'
51
- }
52
-
53
- // Check if a printable document or object was supplied
54
- const args = arguments[0]
55
- if (args === undefined) {
56
- throw new Error('printJS expects at least 1 attribute.')
57
- }
58
-
59
- // Process parameters
60
- switch (typeof args) {
61
- case 'string':
62
- params.printable = encodeURI(args)
63
- params.fallbackPrintable = params.printable
64
- params.type = arguments[1] || params.type
65
- break
66
- case 'object':
67
- params.printable = args.printable
68
- params.fallbackPrintable = typeof args.fallbackPrintable !== 'undefined' ? args.fallbackPrintable : params.printable
69
- params.fallbackPrintable = params.base64 ? `data:application/pdf;base64,${params.fallbackPrintable}` : params.fallbackPrintable
70
- for (var k in params) {
71
- if (k === 'printable' || k === 'fallbackPrintable') continue
72
-
73
- params[k] = typeof args[k] !== 'undefined' ? args[k] : params[k]
74
- }
75
- break
76
- default:
77
- throw new Error('Unexpected argument type! Expected "string" or "object", got ' + typeof args)
78
- }
79
-
80
- // Validate printable
81
- if (!params.printable) throw new Error('Missing printable information.')
82
-
83
- // Validate type
84
- if (!params.type || typeof params.type !== 'string' || printTypes.indexOf(params.type.toLowerCase()) === -1) {
85
- throw new Error('Invalid print type. Available types are: pdf, html, image and json.')
86
- }
87
-
88
- // Check if we are showing a feedback message to the user (useful for large files)
89
- if (params.showModal) Modal.show(params)
90
-
91
- // Check for a print start hook function
92
- if (params.onLoadingStart) params.onLoadingStart()
93
-
94
- // To prevent duplication and issues, remove any used printFrame from the DOM
95
- const usedFrame = document.getElementById(params.frameId)
96
-
97
- if (usedFrame) usedFrame.parentNode.removeChild(usedFrame)
98
-
99
- // Create a new iframe for the print job
100
- const printFrame = document.createElement('iframe')
101
-
102
- if (Browser.isFirefox()) {
103
- // Set the iframe to be is visible on the page (guaranteed by fixed position) but hidden using opacity 0, because
104
- // this works in Firefox. The height needs to be sufficient for some part of the document other than the PDF
105
- // viewer's toolbar to be visible in the page
106
- printFrame.setAttribute('style', 'width: 1px; height: 100px; position: fixed; left: 0; top: 0; opacity: 0; border-width: 0; margin: 0; padding: 0')
107
- } else {
108
- // Hide the iframe in other browsers
109
- printFrame.setAttribute('style', 'visibility: hidden; height: 0; width: 0; position: absolute; border: 0')
110
- }
111
-
112
- // Set iframe element id
113
- printFrame.setAttribute('id', params.frameId)
114
-
115
- // For non pdf printing, pass an html document string to srcdoc (force onload callback)
116
- if (params.type !== 'pdf') {
117
- printFrame.srcdoc = '<html><head><title>' + params.documentTitle + '</title>'
118
-
119
- // Attach css files
120
- if (params.css) {
121
- // Add support for single file
122
- if (!Array.isArray(params.css)) params.css = [params.css]
123
-
124
- // Create link tags for each css file
125
- params.css.forEach(file => {
126
- printFrame.srcdoc += '<link rel="stylesheet" href="' + file + '">'
127
- })
128
- }
129
-
130
- printFrame.srcdoc += '</head><body></body></html>'
131
- }
132
-
133
- // Check printable type
134
- switch (params.type) {
135
- case 'pdf':
136
- // Check browser support for pdf and if not supported we will just open the pdf file instead
137
- if (Browser.isIE()) {
138
- try {
139
- console.info('Print.js doesn\'t support PDF printing in Internet Explorer.')
140
- const win = window.open(params.fallbackPrintable, '_blank')
141
- win.focus()
142
- params.onIncompatibleBrowser()
143
- } catch (error) {
144
- params.onError(error)
145
- } finally {
146
- // Make sure there is no loading modal opened
147
- if (params.showModal) Modal.close()
148
- if (params.onLoadingEnd) params.onLoadingEnd()
149
- }
150
- } else {
151
- Pdf.print(params, printFrame)
152
- }
153
- break
154
- case 'image':
155
- Image.print(params, printFrame)
156
- break
157
- case 'html':
158
- Html.print(params, printFrame)
159
- break
160
- case 'raw-html':
161
- RawHtml.print(params, printFrame)
162
- break
163
- case 'json':
164
- Json.print(params, printFrame)
165
- break
166
- }
167
- }
168
- }
1
+ 'use strict'
2
+
3
+ import Browser from './browser'
4
+ import Modal from './modal'
5
+ import Pdf from './pdf'
6
+ import Html from './html'
7
+ import RawHtml from './raw-html'
8
+ import Image from './image'
9
+ import Json from './json'
10
+
11
+ const printTypes = ['pdf', 'html', 'image', 'json', 'raw-html']
12
+
13
+ export default {
14
+ init () {
15
+ const params = {
16
+ printable: null,
17
+ fallbackPrintable: null,
18
+ type: 'pdf',
19
+ header: null,
20
+ headerStyle: 'font-weight: 300;',
21
+ maxWidth: 800,
22
+ properties: null,
23
+ gridHeaderStyle: 'font-weight: bold; padding: 5px; border: 1px solid #dddddd;',
24
+ gridStyle: 'border: 1px solid lightgray; margin-bottom: -1px;',
25
+ showModal: false,
26
+ onError: (error) => { throw error },
27
+ onLoadingStart: null,
28
+ onLoadingEnd: null,
29
+ onPrintDialogClose: () => {},
30
+ onIncompatibleBrowser: () => {},
31
+ modalMessage: '打印中...',
32
+ frameId: 'printJS',
33
+ printableElement: null,
34
+ documentTitle: 'Document',
35
+ targetStyle: ['clear', 'display', 'width', 'min-width', 'height', 'min-height', 'max-height'],
36
+ targetStyles: ['border', 'box', 'break', 'text-decoration'],
37
+ ignoreElements: [],
38
+ repeatTableHeader: true,
39
+ css: null,
40
+ style: null,
41
+ scanStyles: true,
42
+ base64: false,
43
+
44
+ // Deprecated
45
+ onPdfOpen: null,
46
+ font: 'TimesNewRoman',
47
+ font_size: '12pt',
48
+ honorMarginPadding: true,
49
+ honorColor: false,
50
+ imageStyle: 'max-width: 100%;'
51
+ }
52
+
53
+ // Check if a printable document or object was supplied
54
+ const args = arguments[0]
55
+ if (args === undefined) {
56
+ throw new Error('printJS expects at least 1 attribute.')
57
+ }
58
+
59
+ // Process parameters
60
+ switch (typeof args) {
61
+ case 'string':
62
+ params.printable = encodeURI(args)
63
+ params.fallbackPrintable = params.printable
64
+ params.type = arguments[1] || params.type
65
+ break
66
+ case 'object':
67
+ params.printable = args.printable
68
+ params.fallbackPrintable = typeof args.fallbackPrintable !== 'undefined' ? args.fallbackPrintable : params.printable
69
+ params.fallbackPrintable = params.base64 ? `data:application/pdf;base64,${params.fallbackPrintable}` : params.fallbackPrintable
70
+ for (var k in params) {
71
+ if (k === 'printable' || k === 'fallbackPrintable') continue
72
+
73
+ params[k] = typeof args[k] !== 'undefined' ? args[k] : params[k]
74
+ }
75
+ break
76
+ default:
77
+ throw new Error('Unexpected argument type! Expected "string" or "object", got ' + typeof args)
78
+ }
79
+
80
+ // Validate printable
81
+ if (!params.printable) throw new Error('Missing printable information.')
82
+
83
+ // Validate type
84
+ if (!params.type || typeof params.type !== 'string' || printTypes.indexOf(params.type.toLowerCase()) === -1) {
85
+ throw new Error('Invalid print type. Available types are: pdf, html, image and json.')
86
+ }
87
+
88
+ // Check if we are showing a feedback message to the user (useful for large files)
89
+ if (params.showModal) Modal.show(params)
90
+
91
+ // Check for a print start hook function
92
+ if (params.onLoadingStart) params.onLoadingStart()
93
+
94
+ // To prevent duplication and issues, remove any used printFrame from the DOM
95
+ const usedFrame = document.getElementById(params.frameId)
96
+
97
+ if (usedFrame) usedFrame.parentNode.removeChild(usedFrame)
98
+
99
+ // Create a new iframe for the print job
100
+ const printFrame = document.createElement('iframe')
101
+
102
+ if (Browser.isFirefox()) {
103
+ // Set the iframe to be is visible on the page (guaranteed by fixed position) but hidden using opacity 0, because
104
+ // this works in Firefox. The height needs to be sufficient for some part of the document other than the PDF
105
+ // viewer's toolbar to be visible in the page
106
+ printFrame.setAttribute('style', 'width: 1px; height: 100px; position: fixed; left: 0; top: 0; opacity: 0; border-width: 0; margin: 0; padding: 0')
107
+ } else {
108
+ // Hide the iframe in other browsers
109
+ printFrame.setAttribute('style', 'visibility: hidden; height: 0; width: 0; position: absolute; border: 0')
110
+ }
111
+
112
+ // Set iframe element id
113
+ printFrame.setAttribute('id', params.frameId)
114
+
115
+ // For non pdf printing, pass an html document string to srcdoc (force onload callback)
116
+ if (params.type !== 'pdf') {
117
+ printFrame.srcdoc = '<html><head><title>' + params.documentTitle + '</title>'
118
+
119
+ // Attach css files
120
+ if (params.css) {
121
+ // Add support for single file
122
+ if (!Array.isArray(params.css)) params.css = [params.css]
123
+
124
+ // Create link tags for each css file
125
+ params.css.forEach(file => {
126
+ printFrame.srcdoc += '<link rel="stylesheet" href="' + file + '">'
127
+ })
128
+ }
129
+
130
+ printFrame.srcdoc += '</head><body></body></html>'
131
+ }
132
+
133
+ // Check printable type
134
+ switch (params.type) {
135
+ case 'pdf':
136
+ // Check browser support for pdf and if not supported we will just open the pdf file instead
137
+ if (Browser.isIE()) {
138
+ try {
139
+ console.info('Print.js doesn\'t support PDF printing in Internet Explorer.')
140
+ const win = window.open(params.fallbackPrintable, '_blank')
141
+ win.focus()
142
+ params.onIncompatibleBrowser()
143
+ } catch (error) {
144
+ params.onError(error)
145
+ } finally {
146
+ // Make sure there is no loading modal opened
147
+ if (params.showModal) Modal.close()
148
+ if (params.onLoadingEnd) params.onLoadingEnd()
149
+ }
150
+ } else {
151
+ Pdf.print(params, printFrame)
152
+ }
153
+ break
154
+ case 'image':
155
+ Image.print(params, printFrame)
156
+ break
157
+ case 'html':
158
+ Html.print(params, printFrame)
159
+ break
160
+ case 'raw-html':
161
+ RawHtml.print(params, printFrame)
162
+ break
163
+ case 'json':
164
+ Json.print(params, printFrame)
165
+ break
166
+ }
167
+ }
168
+ }
@@ -1,109 +1,109 @@
1
- import { capitalizePrint, addHeader } from './functions'
2
- import Print from './print'
3
-
4
- export default {
5
- print: (params, printFrame) => {
6
- // Check if we received proper data
7
- if (typeof params.printable !== 'object') {
8
- throw new Error('Invalid javascript data object (JSON).')
9
- }
10
-
11
- // Validate repeatTableHeader
12
- if (typeof params.repeatTableHeader !== 'boolean') {
13
- throw new Error('Invalid value for repeatTableHeader attribute (JSON).')
14
- }
15
-
16
- // Validate properties
17
- if (!params.properties || !Array.isArray(params.properties)) {
18
- throw new Error('Invalid properties array for your JSON data.')
19
- }
20
-
21
- // We will format the property objects to keep the JSON api compatible with older releases
22
- params.properties = params.properties.map(property => {
23
- return {
24
- field: typeof property === 'object' ? property.field : property,
25
- displayName: typeof property === 'object' ? property.displayName : property,
26
- columnSize: typeof property === 'object' && property.columnSize ? property.columnSize + ';' : 100 / params.properties.length + '%;'
27
- }
28
- })
29
-
30
- // Create a print container element
31
- params.printableElement = document.createElement('div')
32
-
33
- // Check if we are adding a print header
34
- if (params.header) {
35
- addHeader(params.printableElement, params)
36
- }
37
-
38
- // Build the printable html data
39
- params.printableElement.innerHTML += jsonToHTML(params)
40
-
41
- // Print the json data
42
- Print.send(params, printFrame)
43
- }
44
- }
45
-
46
- function jsonToHTML (params) {
47
- // Get the row and column data
48
- const data = params.printable
49
- const properties = params.properties
50
-
51
- // Create a html table
52
- let htmlData = '<table style="border-collapse: collapse; width: 100%;">'
53
-
54
- // Check if the header should be repeated
55
- if (params.repeatTableHeader) {
56
- htmlData += '<thead>'
57
- }
58
-
59
- // Add the table header row
60
- htmlData += '<tr>'
61
-
62
- // Add the table header columns
63
- for (let a = 0; a < properties.length; a++) {
64
- htmlData += '<th style="width:' + properties[a].columnSize + ';' + params.gridHeaderStyle + '">' + capitalizePrint(properties[a].displayName) + '</th>'
65
- }
66
-
67
- // Add the closing tag for the table header row
68
- htmlData += '</tr>'
69
-
70
- // If the table header is marked as repeated, add the closing tag
71
- if (params.repeatTableHeader) {
72
- htmlData += '</thead>'
73
- }
74
-
75
- // Create the table body
76
- htmlData += '<tbody>'
77
-
78
- // Add the table data rows
79
- for (let i = 0; i < data.length; i++) {
80
- // Add the row starting tag
81
- htmlData += '<tr>'
82
-
83
- // Print selected properties only
84
- for (let n = 0; n < properties.length; n++) {
85
- let stringData = data[i]
86
-
87
- // Support nested objects
88
- const property = properties[n].field.split('.')
89
- if (property.length > 1) {
90
- for (let p = 0; p < property.length; p++) {
91
- stringData = stringData[property[p]]
92
- }
93
- } else {
94
- stringData = stringData[properties[n].field]
95
- }
96
-
97
- // Add the row contents and styles
98
- htmlData += '<td style="width:' + properties[n].columnSize + params.gridStyle + '">' + stringData + '</td>'
99
- }
100
-
101
- // Add the row closing tag
102
- htmlData += '</tr>'
103
- }
104
-
105
- // Add the table and body closing tags
106
- htmlData += '</tbody></table>'
107
-
108
- return htmlData
109
- }
1
+ import { capitalizePrint, addHeader } from './functions'
2
+ import Print from './print'
3
+
4
+ export default {
5
+ print: (params, printFrame) => {
6
+ // Check if we received proper data
7
+ if (typeof params.printable !== 'object') {
8
+ throw new Error('Invalid javascript data object (JSON).')
9
+ }
10
+
11
+ // Validate repeatTableHeader
12
+ if (typeof params.repeatTableHeader !== 'boolean') {
13
+ throw new Error('Invalid value for repeatTableHeader attribute (JSON).')
14
+ }
15
+
16
+ // Validate properties
17
+ if (!params.properties || !Array.isArray(params.properties)) {
18
+ throw new Error('Invalid properties array for your JSON data.')
19
+ }
20
+
21
+ // We will format the property objects to keep the JSON api compatible with older releases
22
+ params.properties = params.properties.map(property => {
23
+ return {
24
+ field: typeof property === 'object' ? property.field : property,
25
+ displayName: typeof property === 'object' ? property.displayName : property,
26
+ columnSize: typeof property === 'object' && property.columnSize ? property.columnSize + ';' : 100 / params.properties.length + '%;'
27
+ }
28
+ })
29
+
30
+ // Create a print container element
31
+ params.printableElement = document.createElement('div')
32
+
33
+ // Check if we are adding a print header
34
+ if (params.header) {
35
+ addHeader(params.printableElement, params)
36
+ }
37
+
38
+ // Build the printable html data
39
+ params.printableElement.innerHTML += jsonToHTML(params)
40
+
41
+ // Print the json data
42
+ Print.send(params, printFrame)
43
+ }
44
+ }
45
+
46
+ function jsonToHTML (params) {
47
+ // Get the row and column data
48
+ const data = params.printable
49
+ const properties = params.properties
50
+
51
+ // Create a html table
52
+ let htmlData = '<table style="border-collapse: collapse; width: 100%;">'
53
+
54
+ // Check if the header should be repeated
55
+ if (params.repeatTableHeader) {
56
+ htmlData += '<thead>'
57
+ }
58
+
59
+ // Add the table header row
60
+ htmlData += '<tr>'
61
+
62
+ // Add the table header columns
63
+ for (let a = 0; a < properties.length; a++) {
64
+ htmlData += '<th style="width:' + properties[a].columnSize + ';' + params.gridHeaderStyle + '">' + capitalizePrint(properties[a].displayName) + '</th>'
65
+ }
66
+
67
+ // Add the closing tag for the table header row
68
+ htmlData += '</tr>'
69
+
70
+ // If the table header is marked as repeated, add the closing tag
71
+ if (params.repeatTableHeader) {
72
+ htmlData += '</thead>'
73
+ }
74
+
75
+ // Create the table body
76
+ htmlData += '<tbody>'
77
+
78
+ // Add the table data rows
79
+ for (let i = 0; i < data.length; i++) {
80
+ // Add the row starting tag
81
+ htmlData += '<tr>'
82
+
83
+ // Print selected properties only
84
+ for (let n = 0; n < properties.length; n++) {
85
+ let stringData = data[i]
86
+
87
+ // Support nested objects
88
+ const property = properties[n].field.split('.')
89
+ if (property.length > 1) {
90
+ for (let p = 0; p < property.length; p++) {
91
+ stringData = stringData[property[p]]
92
+ }
93
+ } else {
94
+ stringData = stringData[properties[n].field]
95
+ }
96
+
97
+ // Add the row contents and styles
98
+ htmlData += '<td style="width:' + properties[n].columnSize + params.gridStyle + '">' + stringData + '</td>'
99
+ }
100
+
101
+ // Add the row closing tag
102
+ htmlData += '</tr>'
103
+ }
104
+
105
+ // Add the table and body closing tags
106
+ htmlData += '</tbody></table>'
107
+
108
+ return htmlData
109
+ }