n20-common-lib 1.1.98

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 (196) hide show
  1. package/README.md +27 -0
  2. package/package.json +87 -0
  3. package/src/_qiankun/index.js +113 -0
  4. package/src/_qiankun/postMessage.js +48 -0
  5. package/src/assets/css/_coreLib.scss +35 -0
  6. package/src/assets/css/cl-anchor.scss +24 -0
  7. package/src/assets/css/cl-approve-card.scss +58 -0
  8. package/src/assets/css/cl-dialog.scss +99 -0
  9. package/src/assets/css/cl-drag-list.scss +22 -0
  10. package/src/assets/css/cl-empty.scss +10 -0
  11. package/src/assets/css/cl-expandable-pane.scss +25 -0
  12. package/src/assets/css/cl-expandable.scss +23 -0
  13. package/src/assets/css/cl-file-upload-table.scss +11 -0
  14. package/src/assets/css/cl-filter.scss +4 -0
  15. package/src/assets/css/cl-flow-step.scss +186 -0
  16. package/src/assets/css/cl-footer-box.scss +10 -0
  17. package/src/assets/css/cl-form-item.scss +322 -0
  18. package/src/assets/css/cl-general-card.scss +12 -0
  19. package/src/assets/css/cl-layout-aside.scss +88 -0
  20. package/src/assets/css/cl-layout-content.scss +16 -0
  21. package/src/assets/css/cl-layout-header.scss +73 -0
  22. package/src/assets/css/cl-layout-tabs.scss +87 -0
  23. package/src/assets/css/cl-layout.scss +97 -0
  24. package/src/assets/css/cl-login-temporary.scss +37 -0
  25. package/src/assets/css/cl-message.scss +75 -0
  26. package/src/assets/css/cl-more-tab.scss +98 -0
  27. package/src/assets/css/cl-nav-menu.scss +5 -0
  28. package/src/assets/css/cl-pagination.scss +65 -0
  29. package/src/assets/css/cl-secondary-tab.scss +39 -0
  30. package/src/assets/css/cl-showcolumn.scss +23 -0
  31. package/src/assets/css/cl-sifting.scss +51 -0
  32. package/src/assets/css/cl-statis.scss +42 -0
  33. package/src/assets/css/cl-step.scss +73 -0
  34. package/src/assets/css/cl-suspend.scss +19 -0
  35. package/src/assets/css/cl-tertiary-tab.scss +9 -0
  36. package/src/assets/css/cl-upload.scss +41 -0
  37. package/src/assets/css/cl-worn-pagination.scss +50 -0
  38. package/src/assets/css/el-button.scss +169 -0
  39. package/src/assets/css/el-table.scss +79 -0
  40. package/src/assets/css/element-variables.scss +1061 -0
  41. package/src/assets/css/element.dev.scss +21 -0
  42. package/src/assets/css/font-icon.scss +26 -0
  43. package/src/assets/css/index.dev.scss +4 -0
  44. package/src/assets/css/index.scss +11 -0
  45. package/src/assets/css/normalize.scss +723 -0
  46. package/src/assets/css/rootvar.scss +139 -0
  47. package/src/assets/css/select.scss +26 -0
  48. package/src/assets/css/title-pop.scss +4 -0
  49. package/src/assets/getJsonc.js +50 -0
  50. package/src/assets/realUrl.js +12 -0
  51. package/src/components/Anchor/AnchorItem.vue +30 -0
  52. package/src/components/Anchor/index.vue +185 -0
  53. package/src/components/ApprovalButtons/index.vue +232 -0
  54. package/src/components/ApprovalCard/index.vue +128 -0
  55. package/src/components/ApprovalRecord/approvalImg.vue +39 -0
  56. package/src/components/ApprovalRecord/index.vue +59 -0
  57. package/src/components/Button/button-group.vue +150 -0
  58. package/src/components/Button/icon-group-button.vue +61 -0
  59. package/src/components/Button/index.vue +56 -0
  60. package/src/components/ContentLoading/index.vue +41 -0
  61. package/src/components/ContentNull/index.vue +19 -0
  62. package/src/components/DatePicker/index.vue +27 -0
  63. package/src/components/DatePicker/por.vue +169 -0
  64. package/src/components/Dialog/index.vue +26 -0
  65. package/src/components/Dialog/indexO.vue +116 -0
  66. package/src/components/DragList/index.vue +68 -0
  67. package/src/components/Empty/img/404.png +0 -0
  68. package/src/components/Empty/img/abnormal.svg +109 -0
  69. package/src/components/Empty/img/dispose.svg +72 -0
  70. package/src/components/Empty/img/empty.svg +58 -0
  71. package/src/components/Empty/img/general.svg +59 -0
  72. package/src/components/Empty/img/lock.svg +58 -0
  73. package/src/components/Empty/img/network.svg +60 -0
  74. package/src/components/Empty/img/relevant.svg +69 -0
  75. package/src/components/Empty/img/search.svg +73 -0
  76. package/src/components/Empty/index.vue +92 -0
  77. package/src/components/Expandable/index.vue +49 -0
  78. package/src/components/Expandable/main.vue +52 -0
  79. package/src/components/FileUploadTable/index.vue +484 -0
  80. package/src/components/Filters/index.vue +358 -0
  81. package/src/components/Filters/indexO.vue +104 -0
  82. package/src/components/FlowStep/index.vue +69 -0
  83. package/src/components/FooterBox/index.vue +21 -0
  84. package/src/components/GeneralCard/index.vue +15 -0
  85. package/src/components/InputNumber/index.vue +153 -0
  86. package/src/components/InputNumber/numberRange.vue +47 -0
  87. package/src/components/InputSearch/index.vue +75 -0
  88. package/src/components/Layout/AsideNav/index.vue +144 -0
  89. package/src/components/Layout/HeaderWrap/changePwd.vue +215 -0
  90. package/src/components/Layout/HeaderWrap/index.vue +336 -0
  91. package/src/components/Layout/HeaderWrap/noticePop.vue +300 -0
  92. package/src/components/Layout/SubContent/index.vue +131 -0
  93. package/src/components/Layout/TabsNav/index.vue +170 -0
  94. package/src/components/Layout/index.vue +529 -0
  95. package/src/components/Layout/utils.js +12 -0
  96. package/src/components/LoginTemporary/form.vue +511 -0
  97. package/src/components/LoginTemporary/index.vue +122 -0
  98. package/src/components/LoginTemporary/qr.png +0 -0
  99. package/src/components/LoginTemporary/qrcode.vue +90 -0
  100. package/src/components/LoginTemporary/qrt.png +0 -0
  101. package/src/components/LoginTemporary/retrievePw.vue +28 -0
  102. package/src/components/LoginTemporary/utils.js +73 -0
  103. package/src/components/MicroApp/index.js +67 -0
  104. package/src/components/MicroFrame/index.vue +95 -0
  105. package/src/components/MoreTab/index.vue +232 -0
  106. package/src/components/NavMenu/index.vue +60 -0
  107. package/src/components/NstcG6Components/NstcApprovel/NstcApprovel.vue +13 -0
  108. package/src/components/NstcG6Components/NstcDialog/NstcDialog.vue +185 -0
  109. package/src/components/NstcG6Components/Progress/progress.vue +134 -0
  110. package/src/components/PageLayout/page.vue +15 -0
  111. package/src/components/Pagination/index.vue +96 -0
  112. package/src/components/SecondaryTab/index.vue +58 -0
  113. package/src/components/SelectLazy/index.vue +75 -0
  114. package/src/components/SelectTree/SelectTreeLazy.vue +241 -0
  115. package/src/components/SelectTree/index.vue +208 -0
  116. package/src/components/ShowColumn/index.vue +188 -0
  117. package/src/components/Sifting/index.vue +99 -0
  118. package/src/components/Statis/index.vue +97 -0
  119. package/src/components/Statis/statisItem.vue +54 -0
  120. package/src/components/Statis/statisPopover.vue +55 -0
  121. package/src/components/Step/index.vue +38 -0
  122. package/src/components/Suspend/index.vue +72 -0
  123. package/src/components/Table/index.vue +131 -0
  124. package/src/components/Table/indexO.vue +149 -0
  125. package/src/components/Task/index.vue +26 -0
  126. package/src/components/TertiaryTab/index.vue +53 -0
  127. package/src/components/TimePicker/index.vue +28 -0
  128. package/src/components/Upload/index.vue +242 -0
  129. package/src/components/WornPagination/index.vue +73 -0
  130. package/src/directives/VClickOutside/index.js +19 -0
  131. package/src/directives/VDrag/index.js +72 -0
  132. package/src/directives/VHas/index.js +27 -0
  133. package/src/directives/VMove/index.js +42 -0
  134. package/src/directives/VTitle/index.js +56 -0
  135. package/src/directives/VTitle/tooltip.vue +21 -0
  136. package/src/index.js +225 -0
  137. package/src/plugins/CompatibleOld/index.js +57 -0
  138. package/src/plugins/Print/index.js +4 -0
  139. package/src/plugins/Print/print-js/.babelrc +12 -0
  140. package/src/plugins/Print/print-js/LICENSE +21 -0
  141. package/src/plugins/Print/print-js/README.md +98 -0
  142. package/src/plugins/Print/print-js/dist/print.css +97 -0
  143. package/src/plugins/Print/print-js/dist/print.js +991 -0
  144. package/src/plugins/Print/print-js/dist/print.map +1 -0
  145. package/src/plugins/Print/print-js/package.json +60 -0
  146. package/src/plugins/Print/print-js/src/index.d.ts +45 -0
  147. package/src/plugins/Print/print-js/src/index.js +10 -0
  148. package/src/plugins/Print/print-js/src/js/browser.js +33 -0
  149. package/src/plugins/Print/print-js/src/js/functions.js +103 -0
  150. package/src/plugins/Print/print-js/src/js/html.js +70 -0
  151. package/src/plugins/Print/print-js/src/js/image.js +48 -0
  152. package/src/plugins/Print/print-js/src/js/init.js +168 -0
  153. package/src/plugins/Print/print-js/src/js/json.js +109 -0
  154. package/src/plugins/Print/print-js/src/js/modal.js +62 -0
  155. package/src/plugins/Print/print-js/src/js/pdf.js +62 -0
  156. package/src/plugins/Print/print-js/src/js/print.js +102 -0
  157. package/src/plugins/Print/print-js/src/js/raw-html.js +15 -0
  158. package/src/plugins/Print/print-js/src/sass/index.scss +14 -0
  159. package/src/plugins/Print/print-js/src/sass/modules/_colors.scss +10 -0
  160. package/src/plugins/Print/print-js/src/sass/partials/_modal.scss +41 -0
  161. package/src/plugins/Print/print-js/src/sass/partials/_spinner.scss +46 -0
  162. package/src/plugins/Print/print.js +2 -0
  163. package/src/plugins/Print/print.scss +1 -0
  164. package/src/plugins/SetMenuTree/index.vue +41 -0
  165. package/src/plugins/SetMenuTree/logoIcon.vue +37 -0
  166. package/src/plugins/SetMenuTree/setmenutree.vue +427 -0
  167. package/src/plugins/SetMenuTree/utils.js +74 -0
  168. package/src/plugins/Sign/InfosecNetSignCNGAgent.min.js +2000 -0
  169. package/src/plugins/Sign/index.js +65 -0
  170. package/src/plugins/Sign/sign.js +1 -0
  171. package/src/plugins/setTabsForSub.js +2 -0
  172. package/src/utils/auth.js +53 -0
  173. package/src/utils/axios.js +203 -0
  174. package/src/utils/downloadBlob.js +19 -0
  175. package/src/utils/forEachs.js +16 -0
  176. package/src/utils/getScrollContainer.js +43 -0
  177. package/src/utils/i18n/cn2hk.json +1270 -0
  178. package/src/utils/i18n/index.js +54 -0
  179. package/src/utils/list2tree.js +36 -0
  180. package/src/utils/msgboxPor.js +26 -0
  181. package/src/utils/print.js +161 -0
  182. package/src/utils/relaNo.js +35 -0
  183. package/src/utils/repairElementUI.js +66 -0
  184. package/src/utils/urlToGo.js +82 -0
  185. package/style/css/normalize.scss +723 -0
  186. package/style/fonts/element-icons.535877f5.woff +0 -0
  187. package/style/fonts/element-icons.732389de.ttf +0 -0
  188. package/style/index.css +3 -0
  189. package/style/index.css.map +1 -0
  190. package/style/index.umd.min.js +2 -0
  191. package/style/index.umd.min.js.map +1 -0
  192. package/style/pageDemo/demo-1.vue +130 -0
  193. package/style/pageDemo/demo-2.vue +35 -0
  194. package/style/pageDemo/demo-3.vue +22 -0
  195. package/style/pageDemo/seeCode.js +20 -0
  196. package/style/server-config.jsonc +663 -0
@@ -0,0 +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
+ }
@@ -0,0 +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
+ }
@@ -0,0 +1,62 @@
1
+ const Modal = {
2
+ show (params) {
3
+ // Build modal
4
+ const modalStyle = 'font-family:sans-serif; ' +
5
+ 'display:table; ' +
6
+ 'text-align:center; ' +
7
+ 'font-weight:300; ' +
8
+ 'font-size:30px; ' +
9
+ 'left:0; top:0;' +
10
+ 'position:fixed; ' +
11
+ 'z-index: 9990;' +
12
+ 'color: #0460B5; ' +
13
+ 'width: 100%; ' +
14
+ 'height: 100%; ' +
15
+ 'background-color:rgba(255,255,255,.9);' +
16
+ 'transition: opacity .3s ease;'
17
+
18
+ // Create wrapper
19
+ const printModal = document.createElement('div')
20
+ printModal.setAttribute('style', modalStyle)
21
+ printModal.setAttribute('id', 'printJS-Modal')
22
+
23
+ // Create content div
24
+ const contentDiv = document.createElement('div')
25
+ contentDiv.setAttribute('style', 'display:table-cell; vertical-align:middle; padding-bottom:100px;')
26
+
27
+ // Add close button (requires print.css)
28
+ const closeButton = document.createElement('div')
29
+ closeButton.setAttribute('class', 'printClose')
30
+ closeButton.setAttribute('id', 'printClose')
31
+ contentDiv.appendChild(closeButton)
32
+
33
+ // Add spinner (requires print.css)
34
+ const spinner = document.createElement('span')
35
+ spinner.setAttribute('class', 'printSpinner')
36
+ contentDiv.appendChild(spinner)
37
+
38
+ // Add message
39
+ const messageNode = document.createTextNode(params.modalMessage)
40
+ contentDiv.appendChild(messageNode)
41
+
42
+ // Add contentDiv to printModal
43
+ printModal.appendChild(contentDiv)
44
+
45
+ // Append print modal element to document body
46
+ document.getElementsByTagName('body')[0].appendChild(printModal)
47
+
48
+ // Add event listener to close button
49
+ document.getElementById('printClose').addEventListener('click', function () {
50
+ Modal.close()
51
+ })
52
+ },
53
+ close () {
54
+ const printModal = document.getElementById('printJS-Modal')
55
+
56
+ if (printModal) {
57
+ printModal.parentNode.removeChild(printModal)
58
+ }
59
+ }
60
+ }
61
+
62
+ export default Modal
@@ -0,0 +1,62 @@
1
+ import Print from './print'
2
+ import { cleanUp } from './functions'
3
+ import Browser from './browser'
4
+
5
+ export default {
6
+ print: (params, printFrame) => {
7
+ // Check if we have base64 data
8
+ if (params.base64) {
9
+ const bytesArray = Uint8Array.from(atob(params.printable), c => c.charCodeAt(0))
10
+ createBlobAndPrint(params, printFrame, bytesArray)
11
+ return
12
+ }
13
+
14
+ // Format pdf url
15
+ params.printable = /^(blob|http|\/\/)/i.test(params.printable)
16
+ ? params.printable
17
+ : window.location.origin + (params.printable.charAt(0) !== '/' ? '/' + params.printable : params.printable)
18
+
19
+ // Get the file through a http request (Preload)
20
+ const req = new window.XMLHttpRequest()
21
+ req.responseType = 'arraybuffer'
22
+
23
+ req.addEventListener('error', () => {
24
+ cleanUp(params)
25
+ params.onError(req.statusText, req)
26
+
27
+ // Since we don't have a pdf document available, we will stop the print job
28
+ })
29
+
30
+ req.addEventListener('load', () => {
31
+ // Check for errors
32
+ if ([200, 201].indexOf(req.status) === -1) {
33
+ cleanUp(params)
34
+ params.onError(req.statusText, req)
35
+
36
+ // Since we don't have a pdf document available, we will stop the print job
37
+ return
38
+ }
39
+
40
+ // Print requested document
41
+ createBlobAndPrint(params, printFrame, req.response)
42
+ })
43
+
44
+ req.open('GET', params.printable, true)
45
+ req.send()
46
+ }
47
+ }
48
+
49
+ function createBlobAndPrint(params, printFrame, data) {
50
+ // Pass response or base64 data to a blob and create a local object url
51
+ let localPdf = new window.Blob([data], { type: 'application/pdf' })
52
+ localPdf = window.URL.createObjectURL(localPdf)
53
+ // 启程浏览器打印方法
54
+ if (Browser.isNstc()) {
55
+ window.sendMessage(localPdf)
56
+ } else {
57
+ // Set iframe src with pdf document url
58
+ printFrame.setAttribute('src', localPdf)
59
+
60
+ Print.send(params, printFrame)
61
+ }
62
+ }
@@ -0,0 +1,102 @@
1
+ import Browser from './browser'
2
+ import { cleanUp } from './functions'
3
+
4
+ const Print = {
5
+ send: (params, printFrame) => {
6
+ // Append iframe element to document body
7
+ document.getElementsByTagName('body')[0].appendChild(printFrame)
8
+
9
+ // Get iframe element
10
+ const iframeElement = document.getElementById(params.frameId)
11
+
12
+ // Wait for iframe to load all content
13
+ iframeElement.onload = () => {
14
+ if (params.type === 'pdf') {
15
+ // Add a delay for Firefox. In my tests, 1000ms was sufficient but 100ms was not
16
+ if (Browser.isFirefox()) {
17
+ setTimeout(() => performPrint(iframeElement, params), 1000)
18
+ } else {
19
+ performPrint(iframeElement, params)
20
+ }
21
+ return
22
+ }
23
+
24
+ // Get iframe element document
25
+ let printDocument = (iframeElement.contentWindow || iframeElement.contentDocument)
26
+ if (printDocument.document) printDocument = printDocument.document
27
+
28
+ // Append printable element to the iframe body
29
+ printDocument.body.appendChild(params.printableElement)
30
+
31
+ // Add custom style
32
+ if (params.type !== 'pdf' && params.style) {
33
+ // Create style element
34
+ const style = document.createElement('style')
35
+ style.innerHTML = params.style
36
+
37
+ // Append style element to iframe's head
38
+ printDocument.head.appendChild(style)
39
+ }
40
+
41
+ // If printing images, wait for them to load inside the iframe
42
+ const images = printDocument.getElementsByTagName('img')
43
+
44
+ if (images.length > 0) {
45
+ loadIframeImages(Array.from(images)).then(() => performPrint(iframeElement, params))
46
+ } else {
47
+ performPrint(iframeElement, params)
48
+ }
49
+ }
50
+ }
51
+ }
52
+
53
+ function performPrint (iframeElement, params) {
54
+ try {
55
+ iframeElement.focus()
56
+
57
+ // If Edge or IE, try catch with execCommand
58
+ if (Browser.isEdge() || Browser.isIE()) {
59
+ try {
60
+ iframeElement.contentWindow.document.execCommand('print', false, null)
61
+ } catch (e) {
62
+ iframeElement.contentWindow.print()
63
+ }
64
+ } else {
65
+ // Other browsers
66
+ iframeElement.contentWindow.print()
67
+ }
68
+ } catch (error) {
69
+ params.onError(error)
70
+ } finally {
71
+ if (Browser.isFirefox()) {
72
+ // Move the iframe element off-screen and make it invisible
73
+ iframeElement.style.visibility = 'hidden'
74
+ iframeElement.style.left = '-1px'
75
+ }
76
+
77
+ cleanUp(params)
78
+ }
79
+ }
80
+
81
+ function loadIframeImages (images) {
82
+ const promises = images.map(image => {
83
+ if (image.src && image.src !== window.location.href) {
84
+ return loadIframeImage(image)
85
+ }
86
+ })
87
+
88
+ return Promise.all(promises)
89
+ }
90
+
91
+ function loadIframeImage (image) {
92
+ return new Promise(resolve => {
93
+ const pollImage = () => {
94
+ !image || typeof image.naturalWidth === 'undefined' || image.naturalWidth === 0 || !image.complete
95
+ ? setTimeout(pollImage, 500)
96
+ : resolve()
97
+ }
98
+ pollImage()
99
+ })
100
+ }
101
+
102
+ export default Print
@@ -0,0 +1,15 @@
1
+ import Print from './print'
2
+
3
+ export default {
4
+ print: (params, printFrame) => {
5
+ // Create printable element (container)
6
+ params.printableElement = document.createElement('div')
7
+ params.printableElement.setAttribute('style', 'width:100%')
8
+
9
+ // Set our raw html as the printable element inner html content
10
+ params.printableElement.innerHTML = params.printable
11
+
12
+ // Print html contents
13
+ Print.send(params, printFrame)
14
+ }
15
+ }
@@ -0,0 +1,14 @@
1
+ /*
2
+ |--------------------------------------------------------------------------
3
+ | Modules
4
+ |--------------------------------------------------------------------------
5
+ */
6
+ @import './modules/colors';
7
+
8
+ /*
9
+ |--------------------------------------------------------------------------
10
+ | Partials
11
+ |--------------------------------------------------------------------------
12
+ */
13
+ @import './partials/modal';
14
+ @import './partials/spinner';
@@ -0,0 +1,10 @@
1
+ $blue: hsl(209, 96%, 36%);
2
+ $white: hsl(0, 0%, 100%);
3
+
4
+ /*
5
+ |--------------------------------------------------------------------------
6
+ | Aliases
7
+ |--------------------------------------------------------------------------
8
+ */
9
+ $primary: $blue;
10
+ $bg-color: rgba($white, .9);
@@ -0,0 +1,41 @@
1
+ .printModal {
2
+ font-family:sans-serif;
3
+ display:flex;
4
+ text-align:center;
5
+ font-weight:300;
6
+ font-size:30px;
7
+ left:0;
8
+ top:0;
9
+ position:absolute;
10
+ color: $primary;
11
+ width: 100%;
12
+ height: 100%;
13
+ background-color: $bg-color;
14
+ }
15
+
16
+ /*
17
+ |--------------------------------------------------------------------------
18
+ | Close Button
19
+ |--------------------------------------------------------------------------
20
+ */
21
+ .printClose {
22
+ position:absolute;
23
+ right:10px;
24
+ top:10px;
25
+ }
26
+
27
+ .printClose:before {
28
+ content: "\00D7";
29
+ font-family: "Helvetica Neue", sans-serif;
30
+ font-weight: 100;
31
+ line-height: 1px;
32
+ padding-top: 0.5em;
33
+ display: block;
34
+ font-size: 2em;
35
+ text-indent: 1px;
36
+ overflow: hidden;
37
+ height: 1.25em;
38
+ width: 1.25em;
39
+ text-align: center;
40
+ cursor: pointer;
41
+ }
@@ -0,0 +1,46 @@
1
+ .printSpinner {
2
+ margin-top: 3px;
3
+ margin-left: -40px;
4
+ position: absolute;
5
+ display: inline-block;
6
+ width: 25px;
7
+ height: 25px;
8
+ border: 2px solid $primary;
9
+ border-radius: 50%;
10
+ animation: spin 0.75s infinite linear;
11
+ }
12
+
13
+ .printSpinner::before, .printSpinner::after {
14
+ left: -2px;
15
+ top: -2px;
16
+ display: none;
17
+ position: absolute;
18
+ content: '';
19
+ width: inherit;
20
+ height: inherit;
21
+ border: inherit;
22
+ border-radius: inherit;
23
+ }
24
+
25
+ .printSpinner, .printSpinner::before, .printSpinner::after {
26
+ display: inline-block;
27
+ border-color: transparent;
28
+ border-top-color: $primary;
29
+ animation-duration: 1.2s;
30
+ }
31
+ .printSpinner::before {
32
+ transform: rotate(120deg);
33
+ }
34
+ .printSpinner::after {
35
+ transform: rotate(240deg);
36
+ }
37
+
38
+ /* Keyframes for the animation */
39
+ @keyframes spin {
40
+ from {
41
+ transform: rotate(0deg);
42
+ }
43
+ to {
44
+ transform: rotate(360deg);
45
+ }
46
+ }
@@ -0,0 +1,2 @@
1
+ import printJS from './index'
2
+ export default printJS
@@ -0,0 +1 @@
1
+ @import './print-js/src/sass/index.scss';
@@ -0,0 +1,41 @@
1
+ <template>
2
+ <span>
3
+ <span @click="setMenuV = true">
4
+ <slot>
5
+ <el-button
6
+ icon="el-icon-c-scale-to-original"
7
+ plain
8
+ onlyicon
9
+ size="mini"
10
+ />
11
+ </slot>
12
+ </span>
13
+
14
+ <N20Dialog
15
+ title="菜单权限设置"
16
+ :visible.sync="setMenuV"
17
+ width="680px"
18
+ destroy-on-open
19
+ >
20
+ <SetMenuTree :set-new="setNew" />
21
+ </N20Dialog>
22
+ </span>
23
+ </template>
24
+ <script>
25
+ import N20Dialog from '../../components/Dialog'
26
+ import SetMenuTree from './setmenutree.vue'
27
+ export default {
28
+ components: { N20Dialog, SetMenuTree },
29
+ props: {
30
+ setNew: {
31
+ type: Boolean,
32
+ default: true
33
+ }
34
+ },
35
+ data() {
36
+ return {
37
+ setMenuV: false
38
+ }
39
+ }
40
+ }
41
+ </script>