n20-common-lib 1.2.39 → 1.2.42

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 (188) hide show
  1. package/README.md +2 -2
  2. package/package.json +88 -88
  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 -26
  12. package/src/assets/css/cl-expandable.scss +24 -24
  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 +612 -612
  18. package/src/assets/css/cl-general-card.scss +11 -11
  19. package/src/assets/css/cl-layout-aside.scss +92 -92
  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 +128 -128
  29. package/src/assets/css/cl-secondary-tab.scss +53 -53
  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 +54 -54
  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 -173
  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 +27 -27
  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 -726
  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 +233 -233
  54. package/src/components/ApprovalCard/index.vue +128 -128
  55. package/src/components/ApprovalRecord/approvalImg.vue +44 -44
  56. package/src/components/ApprovalRecord/flowDialog.vue +45 -45
  57. package/src/components/ApprovalRecord/index.vue +59 -59
  58. package/src/components/Button/button-group.vue +150 -150
  59. package/src/components/Button/icon-group-button.vue +61 -61
  60. package/src/components/Button/index.vue +56 -56
  61. package/src/components/CascaderArea/index.vue +103 -103
  62. package/src/components/ContentLoading/index.vue +41 -41
  63. package/src/components/ContentNull/index.vue +19 -19
  64. package/src/components/DatePicker/index.vue +27 -27
  65. package/src/components/DatePicker/por.vue +169 -169
  66. package/src/components/Dialog/index.vue +26 -26
  67. package/src/components/Dialog/indexO.vue +116 -116
  68. package/src/components/DragList/index.vue +75 -75
  69. package/src/components/Empty/img/abnormal.svg +108 -108
  70. package/src/components/Empty/img/dispose.svg +71 -71
  71. package/src/components/Empty/img/empty.svg +57 -57
  72. package/src/components/Empty/img/general.svg +58 -58
  73. package/src/components/Empty/img/lock.svg +57 -57
  74. package/src/components/Empty/img/network.svg +59 -59
  75. package/src/components/Empty/img/relevant.svg +68 -68
  76. package/src/components/Empty/img/search.svg +72 -72
  77. package/src/components/Empty/index.vue +92 -92
  78. package/src/components/Expandable/index.vue +49 -49
  79. package/src/components/Expandable/main.vue +52 -52
  80. package/src/components/FileExportAsync/index.vue +178 -178
  81. package/src/components/FileUploadTable/index.vue +484 -484
  82. package/src/components/Filters/index.vue +371 -371
  83. package/src/components/Filters/indexO.vue +104 -104
  84. package/src/components/FlowStep/index.vue +68 -68
  85. package/src/components/FooterBox/index.vue +21 -21
  86. package/src/components/GeneralCard/index.vue +15 -15
  87. package/src/components/InputNumber/index.vue +169 -169
  88. package/src/components/InputNumber/numberRange.vue +47 -47
  89. package/src/components/InputSearch/index.vue +75 -75
  90. package/src/components/Layout/AsideNav/index.vue +120 -119
  91. package/src/components/Layout/AsideNav/menuItem.vue +34 -34
  92. package/src/components/Layout/AsideNav/submenuTitle.vue +26 -26
  93. package/src/components/Layout/HeaderWrap/changePwd.vue +215 -215
  94. package/src/components/Layout/HeaderWrap/index.vue +371 -371
  95. package/src/components/Layout/HeaderWrap/noticePop.vue +316 -316
  96. package/src/components/Layout/SubContent/index.vue +127 -127
  97. package/src/components/Layout/TabsNav/index.vue +170 -170
  98. package/src/components/Layout/index.vue +518 -518
  99. package/src/components/Layout/utils.js +12 -12
  100. package/src/components/LoginTemporary/form.vue +570 -570
  101. package/src/components/LoginTemporary/index.vue +139 -139
  102. package/src/components/LoginTemporary/retrievePw.vue +372 -372
  103. package/src/components/MicroApp/index.js +67 -67
  104. package/src/components/MicroFrame/index.vue +95 -95
  105. package/src/components/MoreTab/index.vue +232 -232
  106. package/src/components/NavMenu/index.vue +60 -60
  107. package/src/components/PageLayout/page.vue +15 -15
  108. package/src/components/Pagination/index.vue +165 -165
  109. package/src/components/SecondaryTab/index.vue +58 -58
  110. package/src/components/SelectLazy/index.vue +75 -75
  111. package/src/components/SelectTree/SelectTreeLazy.vue +241 -241
  112. package/src/components/SelectTree/index.vue +205 -205
  113. package/src/components/ShowColumn/index.vue +213 -213
  114. package/src/components/Sifting/index.vue +99 -99
  115. package/src/components/Statis/index.vue +97 -97
  116. package/src/components/Statis/statisItem.vue +54 -54
  117. package/src/components/Statis/statisPopover.vue +55 -55
  118. package/src/components/Step/index.vue +38 -38
  119. package/src/components/Suspend/index.vue +72 -72
  120. package/src/components/Table/index.vue +209 -209
  121. package/src/components/Table/indexO.vue +149 -149
  122. package/src/components/Task/index.vue +26 -26
  123. package/src/components/TertiaryTab/index.vue +63 -63
  124. package/src/components/TimePicker/index.vue +28 -28
  125. package/src/components/Upload/index.vue +242 -242
  126. package/src/components/WornPagination/index.vue +73 -73
  127. package/src/directives/VClickOutside/index.js +19 -19
  128. package/src/directives/VHas/index.js +58 -58
  129. package/src/directives/VMove/index.js +42 -42
  130. package/src/directives/VTitle/index.js +69 -69
  131. package/src/directives/VTitle/tooltip.vue +21 -21
  132. package/src/index.js +232 -232
  133. package/src/plugins/CompatibleOld/index.js +57 -57
  134. package/src/plugins/Print/index.js +4 -4
  135. package/src/plugins/Print/print-js/.babelrc +12 -12
  136. package/src/plugins/Print/print-js/LICENSE +21 -21
  137. package/src/plugins/Print/print-js/README.md +98 -98
  138. package/src/plugins/Print/print-js/dist/print.css +96 -96
  139. package/src/plugins/Print/print-js/dist/print.js +990 -990
  140. package/src/plugins/Print/print-js/package.json +60 -60
  141. package/src/plugins/Print/print-js/src/index.d.ts +45 -45
  142. package/src/plugins/Print/print-js/src/index.js +10 -10
  143. package/src/plugins/Print/print-js/src/js/browser.js +33 -33
  144. package/src/plugins/Print/print-js/src/js/functions.js +103 -103
  145. package/src/plugins/Print/print-js/src/js/html.js +70 -70
  146. package/src/plugins/Print/print-js/src/js/image.js +48 -48
  147. package/src/plugins/Print/print-js/src/js/init.js +168 -168
  148. package/src/plugins/Print/print-js/src/js/json.js +109 -109
  149. package/src/plugins/Print/print-js/src/js/modal.js +62 -62
  150. package/src/plugins/Print/print-js/src/js/pdf.js +62 -62
  151. package/src/plugins/Print/print-js/src/js/print.js +102 -102
  152. package/src/plugins/Print/print-js/src/js/raw-html.js +15 -15
  153. package/src/plugins/Print/print-js/src/sass/index.scss +13 -13
  154. package/src/plugins/Print/print-js/src/sass/modules/_colors.scss +9 -9
  155. package/src/plugins/Print/print-js/src/sass/partials/_modal.scss +40 -40
  156. package/src/plugins/Print/print-js/src/sass/partials/_spinner.scss +45 -45
  157. package/src/plugins/Print/print.js +2 -2
  158. package/src/plugins/Print/print.scss +1 -1
  159. package/src/plugins/SetMenuTree/index.vue +41 -41
  160. package/src/plugins/SetMenuTree/logoIcon.vue +37 -37
  161. package/src/plugins/SetMenuTree/setmenutree.vue +427 -427
  162. package/src/plugins/SetMenuTree/utils.js +74 -74
  163. package/src/plugins/Sign/InfosecNetSignCNGAgent.min.js +2000 -2000
  164. package/src/plugins/Sign/index.js +65 -65
  165. package/src/plugins/Sign/sign.js +1 -1
  166. package/src/plugins/setTabsForSub.js +2 -2
  167. package/src/utils/auth.js +53 -53
  168. package/src/utils/axios.js +203 -203
  169. package/src/utils/downloadBlob.js +19 -19
  170. package/src/utils/forEachs.js +16 -16
  171. package/src/utils/getScrollContainer.js +43 -43
  172. package/src/utils/i18n/cn2hk.json +1270 -1270
  173. package/src/utils/i18n/index.js +50 -50
  174. package/src/utils/list2tree.js +36 -36
  175. package/src/utils/msgboxPor.js +26 -26
  176. package/src/utils/print.js +161 -161
  177. package/src/utils/relaNo.js +72 -72
  178. package/src/utils/repairElementUI.js +95 -66
  179. package/src/utils/urlToGo.js +82 -82
  180. package/style/css/normalize.scss +726 -0
  181. package/style/index.css +3 -3
  182. package/style/index.css.map +1 -1
  183. package/style/pageDemo/demo-1.vue +131 -0
  184. package/style/pageDemo/demo-2.vue +35 -0
  185. package/style/pageDemo/demo-3.vue +22 -0
  186. package/style/pageDemo/seeCode.js +20 -0
  187. package/style/server-config.jsonc +606 -0
  188. package/src/components/NstcG6Components/NstcDialog/NstcDialog.vue +0 -185
@@ -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
+ }