bfg-common 1.5.491 → 1.5.493

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 (112) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/assets/localization/local_be.json +4 -0
  7. package/assets/localization/local_en.json +6 -2
  8. package/assets/localization/local_hy.json +4 -0
  9. package/assets/localization/local_kk.json +4 -0
  10. package/assets/localization/local_ru.json +6 -2
  11. package/assets/localization/local_zh.json +4 -0
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/collapse/CollapseNav.vue +170 -170
  14. package/components/atoms/perPage/PerPage.vue +58 -58
  15. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  16. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  17. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  18. package/components/common/backup/storage/actions/add/Add.vue +6 -3
  19. package/components/common/backup/storage/actions/add/lib/utils.ts +53 -21
  20. package/components/common/backup/storage/actions/add/lib/validations.ts +16 -8
  21. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  22. package/components/common/context/lib/models/interfaces.ts +33 -33
  23. package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
  24. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  25. package/components/common/diagramMain/port/Port.vue +580 -580
  26. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  27. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  28. package/components/common/pages/backups/DetailView.vue +52 -52
  29. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  30. package/components/common/pages/backups/modals/Modals.vue +243 -243
  31. package/components/common/pages/backups/modals/createBackup/configuration/Configuration.vue +29 -29
  32. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  33. package/components/common/pages/backups/modals/createBackup/datastores/tableView/TableView.vue +95 -95
  34. package/components/common/pages/backups/modals/createBackup/general/General.vue +141 -141
  35. package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +12 -12
  36. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  37. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  38. package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
  39. package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
  40. package/components/common/pages/backups/modals/restore/name/Name.vue +166 -166
  41. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  42. package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
  43. package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
  44. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
  45. package/components/common/pages/backups/tools/Tools.vue +75 -75
  46. package/components/common/pages/backups/tools/lib/config/tabs.ts +36 -36
  47. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  48. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  49. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  50. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  51. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  52. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  53. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  54. package/components/common/select/radio/RadioGroup.vue +137 -137
  55. package/components/common/spiceConsole/Drawer.vue +392 -392
  56. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  57. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  58. package/components/common/tools/Actions.vue +207 -207
  59. package/components/common/treeView/TreeView.vue +52 -52
  60. package/components/common/vm/actions/add/Add.vue +877 -877
  61. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  62. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  63. package/components/common/vm/actions/add/lib/config/steps.ts +347 -347
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +368 -368
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +99 -99
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  73. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  74. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  75. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  76. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  77. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  78. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  79. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  80. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  81. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  82. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  83. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  84. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  85. package/components/common/vm/actions/common/select/name/Name.vue +200 -200
  86. package/components/common/vm/actions/common/select/name/Old.vue +130 -130
  87. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  88. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  89. package/components/common/vm/actions/common/select/storage/new/New.vue +320 -320
  90. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  91. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  92. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  93. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  94. package/components/common/vm/actions/register/Register.vue +267 -267
  95. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  96. package/components/common/wizards/datastore/add/Add.vue +6 -2
  97. package/components/common/wizards/datastore/add/lib/utils.ts +51 -21
  98. package/components/common/wizards/datastore/add/lib/validations.ts +16 -8
  99. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  100. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  101. package/composables/useAppVersion.ts +21 -21
  102. package/composables/useLocal.ts +6 -6
  103. package/composables/useLocalCommon.ts +39 -39
  104. package/package.json +1 -1
  105. package/plugins/date.ts +233 -233
  106. package/plugins/panelStates.ts +70 -70
  107. package/plugins/text.ts +59 -59
  108. package/public/spice-console/lib/images/bitmap.js +203 -203
  109. package/public/spice-console/network/spicechannel.js +440 -440
  110. package/public/spice-console/run.js +210 -210
  111. package/store/main/mutations.ts +7 -7
  112. package/store/main/state.ts +7 -7
@@ -1,70 +1,70 @@
1
- import { defineNuxtPlugin } from '#app'
2
- import type { UI_I_PanelOptions } from '~/lib/models/plugins/panelStates/interfaces'
3
-
4
- export default defineNuxtPlugin(() => {
5
- const panelStates = function (): any {
6
- const self: any = {}
7
- let options: UI_I_PanelOptions = {
8
- leftPanelWidth: 20,
9
- topPanelHeight: 80,
10
- isBottomPanelCollapsed: false,
11
- }
12
-
13
- self.setLeftPanelWidth = function (width: number): void {
14
- options.leftPanelWidth = width
15
-
16
- self.setPanelStatesInStorage()
17
- }
18
- self.setTopPanelHeight = function (height: number): void {
19
- options.topPanelHeight = height
20
-
21
- self.setPanelStatesInStorage()
22
- }
23
- self.bottomPanelCollapse = function (collapse: boolean): void {
24
- options.isBottomPanelCollapsed = collapse
25
-
26
- self.setPanelStatesInStorage()
27
- }
28
-
29
- self.setPanelStatesInStorage = function (): void {
30
- useLocalStorage('panelStates', options)
31
- self.emitChanges()
32
- }
33
- self.getPanelStatesOfStorage = function (): UI_I_PanelOptions {
34
- let panelStates = useLocalStorage('panelStates')
35
-
36
- if (!panelStates) {
37
- // const parent = document.getElementById('default-layout-outer')
38
- const parent = document.body
39
- const parentHeight = parent?.clientHeight || 0
40
- const onePercent = parentHeight / 100
41
- const defaultRecentTasksHeight = 250
42
-
43
- options.topPanelHeight =
44
- (parentHeight - defaultRecentTasksHeight - 1.5) / onePercent
45
-
46
- panelStates = options
47
- }
48
-
49
- options = panelStates
50
-
51
- return panelStates
52
- }
53
-
54
- self.cb = (): void => {}
55
- self.on = function (cb: () => any | void): void {
56
- self.cb = cb
57
- }
58
- self.emitChanges = function (): void {
59
- self.cb(options)
60
- }
61
-
62
- return self
63
- }.call({})
64
-
65
- return {
66
- provide: {
67
- panelStates,
68
- },
69
- }
70
- })
1
+ import { defineNuxtPlugin } from '#app'
2
+ import type { UI_I_PanelOptions } from '~/lib/models/plugins/panelStates/interfaces'
3
+
4
+ export default defineNuxtPlugin(() => {
5
+ const panelStates = function (): any {
6
+ const self: any = {}
7
+ let options: UI_I_PanelOptions = {
8
+ leftPanelWidth: 20,
9
+ topPanelHeight: 80,
10
+ isBottomPanelCollapsed: false,
11
+ }
12
+
13
+ self.setLeftPanelWidth = function (width: number): void {
14
+ options.leftPanelWidth = width
15
+
16
+ self.setPanelStatesInStorage()
17
+ }
18
+ self.setTopPanelHeight = function (height: number): void {
19
+ options.topPanelHeight = height
20
+
21
+ self.setPanelStatesInStorage()
22
+ }
23
+ self.bottomPanelCollapse = function (collapse: boolean): void {
24
+ options.isBottomPanelCollapsed = collapse
25
+
26
+ self.setPanelStatesInStorage()
27
+ }
28
+
29
+ self.setPanelStatesInStorage = function (): void {
30
+ useLocalStorage('panelStates', options)
31
+ self.emitChanges()
32
+ }
33
+ self.getPanelStatesOfStorage = function (): UI_I_PanelOptions {
34
+ let panelStates = useLocalStorage('panelStates')
35
+
36
+ if (!panelStates) {
37
+ // const parent = document.getElementById('default-layout-outer')
38
+ const parent = document.body
39
+ const parentHeight = parent?.clientHeight || 0
40
+ const onePercent = parentHeight / 100
41
+ const defaultRecentTasksHeight = 250
42
+
43
+ options.topPanelHeight =
44
+ (parentHeight - defaultRecentTasksHeight - 1.5) / onePercent
45
+
46
+ panelStates = options
47
+ }
48
+
49
+ options = panelStates
50
+
51
+ return panelStates
52
+ }
53
+
54
+ self.cb = (): void => {}
55
+ self.on = function (cb: () => any | void): void {
56
+ self.cb = cb
57
+ }
58
+ self.emitChanges = function (): void {
59
+ self.cb(options)
60
+ }
61
+
62
+ return self
63
+ }.call({})
64
+
65
+ return {
66
+ provide: {
67
+ panelStates,
68
+ },
69
+ }
70
+ })
package/plugins/text.ts CHANGED
@@ -1,59 +1,59 @@
1
- import type { UI_I_Localization } from '~/lib/models/interfaces'
2
-
3
- export default defineNuxtPlugin(() => {
4
- const text = function () {
5
- const self: any = {}
6
- self.toCapitalize = function (str: string): string {
7
- return str.charAt(0).toUpperCase() + str.slice(1).toLowerCase()
8
- }
9
- self.toLowerCaseFirstLetter = function (str: string): string {
10
- // TODO не используется
11
- return str.charAt(0).toLowerCase() + str.slice(1)
12
- }
13
- self.toCapitalizeEveryWord = function (str: string): string {
14
- return str
15
- .split(' ')
16
- .map((word) => self.toCapitalize(word))
17
- .join(' ')
18
- }
19
- self.toCapitalizeByIndex = function (
20
- str: string,
21
- indexes: number[]
22
- ): string {
23
- return str
24
- .split(' ')
25
- .map((word, index) =>
26
- indexes.includes(index) ? self.toCapitalize(word) : word
27
- )
28
- .join(' ')
29
- }
30
- self.toLowerCaseByIndex = function (
31
- str: string,
32
- indexes: number[]
33
- ): string {
34
- return str
35
- .split(' ')
36
- .map((word, index) =>
37
- indexes.includes(index) ? self.toLowerCaseFirstLetter(word) : word
38
- )
39
- .join(' ')
40
- }
41
- self.replaceStringByLocalization = function (
42
- str: string,
43
- localization: UI_I_Localization
44
- ): string {
45
- return str.replace(/\[\w+\]/g, (val) => {
46
- const variable = val.replace(/\[|\]/g, '')
47
- return localization.common[variable]
48
- })
49
- }
50
-
51
- return self
52
- }.call({})
53
-
54
- return {
55
- provide: {
56
- text,
57
- },
58
- }
59
- })
1
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
2
+
3
+ export default defineNuxtPlugin(() => {
4
+ const text = function () {
5
+ const self: any = {}
6
+ self.toCapitalize = function (str: string): string {
7
+ return str.charAt(0).toUpperCase() + str.slice(1).toLowerCase()
8
+ }
9
+ self.toLowerCaseFirstLetter = function (str: string): string {
10
+ // TODO не используется
11
+ return str.charAt(0).toLowerCase() + str.slice(1)
12
+ }
13
+ self.toCapitalizeEveryWord = function (str: string): string {
14
+ return str
15
+ .split(' ')
16
+ .map((word) => self.toCapitalize(word))
17
+ .join(' ')
18
+ }
19
+ self.toCapitalizeByIndex = function (
20
+ str: string,
21
+ indexes: number[]
22
+ ): string {
23
+ return str
24
+ .split(' ')
25
+ .map((word, index) =>
26
+ indexes.includes(index) ? self.toCapitalize(word) : word
27
+ )
28
+ .join(' ')
29
+ }
30
+ self.toLowerCaseByIndex = function (
31
+ str: string,
32
+ indexes: number[]
33
+ ): string {
34
+ return str
35
+ .split(' ')
36
+ .map((word, index) =>
37
+ indexes.includes(index) ? self.toLowerCaseFirstLetter(word) : word
38
+ )
39
+ .join(' ')
40
+ }
41
+ self.replaceStringByLocalization = function (
42
+ str: string,
43
+ localization: UI_I_Localization
44
+ ): string {
45
+ return str.replace(/\[\w+\]/g, (val) => {
46
+ const variable = val.replace(/\[|\]/g, '')
47
+ return localization.common[variable]
48
+ })
49
+ }
50
+
51
+ return self
52
+ }.call({})
53
+
54
+ return {
55
+ provide: {
56
+ text,
57
+ },
58
+ }
59
+ })
@@ -1,203 +1,203 @@
1
- /*
2
- Copyright (c) 2016 eyeOS
3
-
4
- This file is part of Open365.
5
-
6
- Open365 is free software: you can redistribute it and/or modify
7
- it under the terms of the GNU Affero General Public License as
8
- published by the Free Software Foundation, either version 3 of the
9
- License, or (at your option) any later version.
10
-
11
- This program is distributed in the hope that it will be useful,
12
- but WITHOUT ANY WARRANTY; without even the implied warranty of
13
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
- GNU Affero General Public License for more details.
15
-
16
- You should have received a copy of the GNU Affero General Public License
17
- along with this program. If not, see <http://www.gnu.org/licenses/>.
18
- */
19
-
20
- wdi.BMP2 = $.spcExtend(wdi.SpiceObject, {
21
- objectSize: 0,
22
- mapper: [0, 1, 1, 4, 4, 8, 16, 24, 32, 32],
23
-
24
- init: function(imageData) {
25
- var type = this.bytesToInt8(imageData);
26
- var flags = this.bytesToInt8(imageData); // bit 1 => normal, bit 2 => palette cache (...)
27
- var width = this.bytesToInt32(imageData); // width in pixels
28
- var height = this.bytesToInt32(imageData); // height in pixels
29
- var stride = this.bytesToInt32(imageData); // width in bytes including padding
30
- var len;
31
- var bpp = this.mapper[type];
32
- var i;
33
-
34
-
35
- var paletteSize = 0, unique, paletteData, numEnts = 0;
36
- if (bpp <= 8 && bpp > 0) {
37
- var palette = [];
38
- if (flags & 1) {
39
- var paletteOffset = this.bytesToInt32(imageData); // From the begininig of the spice packet?
40
- len = imageData.length;
41
- paletteSize = 4*Math.pow(2,bpp);
42
- var paletteDataSize = paletteSize + 8 + 2; //palette + unique(64b) + numEnts (16b)
43
- len -= paletteDataSize;
44
- paletteData = imageData.splice(len, paletteDataSize);
45
- unique = this.bytesToInt64(paletteData);
46
- numEnts = this.bytesToInt16(paletteData);
47
- var queue;
48
-
49
- for (i = 0; i < numEnts*4; i+=4) {
50
- queue = new wdi.Queue();
51
- queue.setData(paletteData.slice(i, i+4));
52
- palette.push(new wdi.SpiceColor().demarshall(queue));
53
- }
54
- wdi.ImageCache.addPalette(unique, palette);
55
- } else {
56
- //get palette from cache
57
- unique = this.bytesToInt64(imageData);
58
- len = imageData.length;
59
- palette = wdi.ImageCache.getPalette(unique);
60
- var spiceColors;
61
- paletteData = [];
62
- numEnts = palette.length;
63
- for (i =0; i < numEnts; i++ ) {
64
- spiceColors = palette[i].marshall();
65
- spiceColors.push(0);
66
- paletteData = paletteData.concat(spiceColors);
67
- }
68
-
69
- }
70
- // imageData = paletteData.concat(imageData);
71
-
72
- } else {
73
- // Removing 4 bytes from the image data to fix index out of range error.
74
- var unknown = this.bytesToInt32(imageData);
75
- }
76
-
77
- this.setContent({
78
- imageSize: len,
79
- width: width,
80
- height: height,
81
- bpp: bpp,
82
- imageData: imageData,
83
- paletteSize: numEnts * 4,
84
- palette: palette,
85
- stride: stride,
86
- flags: flags,
87
- type: type
88
- });
89
- },
90
-
91
- setContent: function(c) {
92
- this.imageSize = c.imageSize;
93
- this.width = c.width;
94
- this.height = c.height;
95
- this.bpp = c.bpp;
96
- this.imageData = c.imageData;
97
- this.palette = c.palette;
98
- this.offset = c.paletteSize + 0x36; //0x36 === Current harcoded header size (BMP + DIB)
99
- this.size = this.offset + this.imageSize;
100
- this.stride = c.stride;
101
- this.flags = c.flags;
102
- // this.type = c.type;
103
- // console.log(`тип не 9, тип: ${c.type}`)
104
- this.type = 9;
105
- },
106
-
107
- marshall: function(context) {
108
- var type = this.type;
109
- var palette = this.palette;
110
- var width = this.width;
111
- var height = this.height;
112
- var stride = this.stride;
113
- var data = this.imageData;
114
- var flags = this.flags;
115
- var size = data.length;
116
-
117
- var pixelsStride = stride * 8/this.bpp;
118
- var bytesStride = pixelsStride * 4;
119
- var buf = new ArrayBuffer(bytesStride * height);
120
- var buf8 = new Uint8ClampedArray(buf);
121
- var buf32 = new Uint32Array(buf);
122
- var topdown = data[1];
123
-
124
- var oct, i, pos, buffPos, spiceColor;
125
- var b;
126
- if (palette) {
127
- buffPos = 0
128
- if (type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_1BIT_BE) {
129
- spiceColor = palette[1];
130
- var foreColor = spiceColor.r << 24 | spiceColor.g << 16 | spiceColor.b << 8 | 255;
131
-
132
- spiceColor = palette[0];
133
- var backColor = spiceColor.r << 24 | spiceColor.g << 16 | spiceColor.b << 8 | 255;
134
-
135
- var PLT1_MASK = [1, 2, 4, 8, 16, 32, 64, 128];
136
-
137
- for (pos = 0; pos < size; pos++) {
138
- oct = data[pos];
139
-
140
- for (i = 7; i >= 0; i--) {
141
- if (oct & PLT1_MASK[i]) {
142
- buf32[buffPos++] = foreColor;
143
- } else {
144
- buf32[buffPos++] = backColor;
145
- }
146
- }
147
- }
148
- } else if (type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_4BIT_BE) {
149
- for (pos = 0; pos < size; pos++) {
150
- oct = data[pos];
151
- spiceColor = palette[oct >>> 4];
152
- buf32[buffPos++] = spiceColor.r << 24 | spiceColor.g << 16 | spiceColor.b << 8 | 255;
153
- spiceColor = palette[oct & 0x0f];
154
- buf32[buffPos++] = spiceColor.r << 24 | spiceColor.g << 16 | spiceColor.b << 8 | 255;
155
- }
156
- }
157
-
158
- } else {
159
- if (type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_32BIT || type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_RGBA) {
160
- for (pos = 0; pos < size; pos += 4) {
161
- let b,g,r
162
- b = data[pos];
163
- g = data[pos+1];
164
- r = data[pos+2];
165
-
166
- data[pos] = r;
167
- data[pos + 1] = g;
168
- data[pos + 2] = b;
169
- data[pos + 3] = 255;
170
- }
171
- } else if (type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_24BIT) {
172
- for (pos = 0; pos < size; pos+=3) {
173
- b = data[pos];
174
- data[pos] = data[pos+2];
175
- data[pos+2] = b;
176
- }
177
- }
178
- buf8 = new Uint8ClampedArray(data);
179
- }
180
-
181
- var ret = new ImageData(buf8, pixelsStride, height);
182
-
183
- var tmpCanvas = wdi.graphics.getNewTmpCanvas(width, height);
184
- tmpCanvas.getContext('2d').putImageData(ret, 0, 0, 0, 0, width, height);
185
- ret = tmpCanvas;
186
-
187
- if(flags&4 === 0) {
188
- ret = wdi.RasterOperation.flip(ret);
189
- }
190
-
191
- return ret;
192
-
193
- }
194
- });
195
- function intToByteArray(value) {
196
- // Создаем массив из одного байта
197
- let byteArray = new Uint8Array(1);
198
-
199
- // Устанавливаем значение в массиве байтов
200
- byteArray[0] = value & 0xFF; // Маскирование, чтобы значение поместилось в один байт
201
-
202
- return byteArray;
203
- }
1
+ /*
2
+ Copyright (c) 2016 eyeOS
3
+
4
+ This file is part of Open365.
5
+
6
+ Open365 is free software: you can redistribute it and/or modify
7
+ it under the terms of the GNU Affero General Public License as
8
+ published by the Free Software Foundation, either version 3 of the
9
+ License, or (at your option) any later version.
10
+
11
+ This program is distributed in the hope that it will be useful,
12
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
+ GNU Affero General Public License for more details.
15
+
16
+ You should have received a copy of the GNU Affero General Public License
17
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
18
+ */
19
+
20
+ wdi.BMP2 = $.spcExtend(wdi.SpiceObject, {
21
+ objectSize: 0,
22
+ mapper: [0, 1, 1, 4, 4, 8, 16, 24, 32, 32],
23
+
24
+ init: function(imageData) {
25
+ var type = this.bytesToInt8(imageData);
26
+ var flags = this.bytesToInt8(imageData); // bit 1 => normal, bit 2 => palette cache (...)
27
+ var width = this.bytesToInt32(imageData); // width in pixels
28
+ var height = this.bytesToInt32(imageData); // height in pixels
29
+ var stride = this.bytesToInt32(imageData); // width in bytes including padding
30
+ var len;
31
+ var bpp = this.mapper[type];
32
+ var i;
33
+
34
+
35
+ var paletteSize = 0, unique, paletteData, numEnts = 0;
36
+ if (bpp <= 8 && bpp > 0) {
37
+ var palette = [];
38
+ if (flags & 1) {
39
+ var paletteOffset = this.bytesToInt32(imageData); // From the begininig of the spice packet?
40
+ len = imageData.length;
41
+ paletteSize = 4*Math.pow(2,bpp);
42
+ var paletteDataSize = paletteSize + 8 + 2; //palette + unique(64b) + numEnts (16b)
43
+ len -= paletteDataSize;
44
+ paletteData = imageData.splice(len, paletteDataSize);
45
+ unique = this.bytesToInt64(paletteData);
46
+ numEnts = this.bytesToInt16(paletteData);
47
+ var queue;
48
+
49
+ for (i = 0; i < numEnts*4; i+=4) {
50
+ queue = new wdi.Queue();
51
+ queue.setData(paletteData.slice(i, i+4));
52
+ palette.push(new wdi.SpiceColor().demarshall(queue));
53
+ }
54
+ wdi.ImageCache.addPalette(unique, palette);
55
+ } else {
56
+ //get palette from cache
57
+ unique = this.bytesToInt64(imageData);
58
+ len = imageData.length;
59
+ palette = wdi.ImageCache.getPalette(unique);
60
+ var spiceColors;
61
+ paletteData = [];
62
+ numEnts = palette.length;
63
+ for (i =0; i < numEnts; i++ ) {
64
+ spiceColors = palette[i].marshall();
65
+ spiceColors.push(0);
66
+ paletteData = paletteData.concat(spiceColors);
67
+ }
68
+
69
+ }
70
+ // imageData = paletteData.concat(imageData);
71
+
72
+ } else {
73
+ // Removing 4 bytes from the image data to fix index out of range error.
74
+ var unknown = this.bytesToInt32(imageData);
75
+ }
76
+
77
+ this.setContent({
78
+ imageSize: len,
79
+ width: width,
80
+ height: height,
81
+ bpp: bpp,
82
+ imageData: imageData,
83
+ paletteSize: numEnts * 4,
84
+ palette: palette,
85
+ stride: stride,
86
+ flags: flags,
87
+ type: type
88
+ });
89
+ },
90
+
91
+ setContent: function(c) {
92
+ this.imageSize = c.imageSize;
93
+ this.width = c.width;
94
+ this.height = c.height;
95
+ this.bpp = c.bpp;
96
+ this.imageData = c.imageData;
97
+ this.palette = c.palette;
98
+ this.offset = c.paletteSize + 0x36; //0x36 === Current harcoded header size (BMP + DIB)
99
+ this.size = this.offset + this.imageSize;
100
+ this.stride = c.stride;
101
+ this.flags = c.flags;
102
+ // this.type = c.type;
103
+ // console.log(`тип не 9, тип: ${c.type}`)
104
+ this.type = 9;
105
+ },
106
+
107
+ marshall: function(context) {
108
+ var type = this.type;
109
+ var palette = this.palette;
110
+ var width = this.width;
111
+ var height = this.height;
112
+ var stride = this.stride;
113
+ var data = this.imageData;
114
+ var flags = this.flags;
115
+ var size = data.length;
116
+
117
+ var pixelsStride = stride * 8/this.bpp;
118
+ var bytesStride = pixelsStride * 4;
119
+ var buf = new ArrayBuffer(bytesStride * height);
120
+ var buf8 = new Uint8ClampedArray(buf);
121
+ var buf32 = new Uint32Array(buf);
122
+ var topdown = data[1];
123
+
124
+ var oct, i, pos, buffPos, spiceColor;
125
+ var b;
126
+ if (palette) {
127
+ buffPos = 0
128
+ if (type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_1BIT_BE) {
129
+ spiceColor = palette[1];
130
+ var foreColor = spiceColor.r << 24 | spiceColor.g << 16 | spiceColor.b << 8 | 255;
131
+
132
+ spiceColor = palette[0];
133
+ var backColor = spiceColor.r << 24 | spiceColor.g << 16 | spiceColor.b << 8 | 255;
134
+
135
+ var PLT1_MASK = [1, 2, 4, 8, 16, 32, 64, 128];
136
+
137
+ for (pos = 0; pos < size; pos++) {
138
+ oct = data[pos];
139
+
140
+ for (i = 7; i >= 0; i--) {
141
+ if (oct & PLT1_MASK[i]) {
142
+ buf32[buffPos++] = foreColor;
143
+ } else {
144
+ buf32[buffPos++] = backColor;
145
+ }
146
+ }
147
+ }
148
+ } else if (type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_4BIT_BE) {
149
+ for (pos = 0; pos < size; pos++) {
150
+ oct = data[pos];
151
+ spiceColor = palette[oct >>> 4];
152
+ buf32[buffPos++] = spiceColor.r << 24 | spiceColor.g << 16 | spiceColor.b << 8 | 255;
153
+ spiceColor = palette[oct & 0x0f];
154
+ buf32[buffPos++] = spiceColor.r << 24 | spiceColor.g << 16 | spiceColor.b << 8 | 255;
155
+ }
156
+ }
157
+
158
+ } else {
159
+ if (type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_32BIT || type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_RGBA) {
160
+ for (pos = 0; pos < size; pos += 4) {
161
+ let b,g,r
162
+ b = data[pos];
163
+ g = data[pos+1];
164
+ r = data[pos+2];
165
+
166
+ data[pos] = r;
167
+ data[pos + 1] = g;
168
+ data[pos + 2] = b;
169
+ data[pos + 3] = 255;
170
+ }
171
+ } else if (type === wdi.SpiceBitmapFmt.SPICE_BITMAP_FMT_24BIT) {
172
+ for (pos = 0; pos < size; pos+=3) {
173
+ b = data[pos];
174
+ data[pos] = data[pos+2];
175
+ data[pos+2] = b;
176
+ }
177
+ }
178
+ buf8 = new Uint8ClampedArray(data);
179
+ }
180
+
181
+ var ret = new ImageData(buf8, pixelsStride, height);
182
+
183
+ var tmpCanvas = wdi.graphics.getNewTmpCanvas(width, height);
184
+ tmpCanvas.getContext('2d').putImageData(ret, 0, 0, 0, 0, width, height);
185
+ ret = tmpCanvas;
186
+
187
+ if(flags&4 === 0) {
188
+ ret = wdi.RasterOperation.flip(ret);
189
+ }
190
+
191
+ return ret;
192
+
193
+ }
194
+ });
195
+ function intToByteArray(value) {
196
+ // Создаем массив из одного байта
197
+ let byteArray = new Uint8Array(1);
198
+
199
+ // Устанавливаем значение в массиве байтов
200
+ byteArray[0] = value & 0xFF; // Маскирование, чтобы значение поместилось в один байт
201
+
202
+ return byteArray;
203
+ }