@dcl/asset-packs 1.4.2 → 1.4.3-20231206205632.commit-e83afe8

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.
package/dist/ui.js ADDED
@@ -0,0 +1,198 @@
1
+ import { UiBackground, UiText, UiTransform, } from '@dcl/sdk/ecs';
2
+ import { Color4 } from '@dcl/sdk/math';
3
+ import { AlignMode, Font } from './enums';
4
+ function getAlignMode(align, isColumn) {
5
+ switch (align) {
6
+ case AlignMode.TAM_TOP_LEFT: {
7
+ return {
8
+ alignItems: 1,
9
+ justifyContent: 0,
10
+ };
11
+ }
12
+ case AlignMode.TAM_TOP_CENTER: {
13
+ return isColumn
14
+ ? {
15
+ alignItems: 2,
16
+ justifyContent: 0,
17
+ }
18
+ : {
19
+ alignItems: 1,
20
+ justifyContent: 1,
21
+ };
22
+ }
23
+ case AlignMode.TAM_TOP_RIGHT: {
24
+ return isColumn
25
+ ? {
26
+ alignItems: 3,
27
+ justifyContent: 0,
28
+ }
29
+ : {
30
+ alignItems: 1,
31
+ justifyContent: 2,
32
+ };
33
+ }
34
+ case AlignMode.TAM_MIDDLE_LEFT: {
35
+ return isColumn
36
+ ? {
37
+ alignItems: 1,
38
+ justifyContent: 1,
39
+ }
40
+ : {
41
+ alignItems: 2,
42
+ justifyContent: 0,
43
+ };
44
+ }
45
+ case AlignMode.TAM_MIDDLE_CENTER: {
46
+ return {
47
+ alignItems: 2,
48
+ justifyContent: 1,
49
+ };
50
+ }
51
+ case AlignMode.TAM_MIDDLE_RIGHT: {
52
+ return isColumn
53
+ ? {
54
+ alignItems: 3,
55
+ justifyContent: 1,
56
+ }
57
+ : {
58
+ alignItems: 2,
59
+ justifyContent: 2,
60
+ };
61
+ }
62
+ case AlignMode.TAM_BOTTOM_LEFT: {
63
+ return isColumn
64
+ ? {
65
+ alignItems: 1,
66
+ justifyContent: 2,
67
+ }
68
+ : {
69
+ alignItems: 2,
70
+ justifyContent: 1,
71
+ };
72
+ }
73
+ case AlignMode.TAM_BOTTOM_CENTER: {
74
+ return isColumn
75
+ ? {
76
+ alignItems: 2,
77
+ justifyContent: 2,
78
+ }
79
+ : {
80
+ alignItems: 3,
81
+ justifyContent: 1,
82
+ };
83
+ }
84
+ case AlignMode.TAM_BOTTOM_RIGHT: {
85
+ return {
86
+ alignItems: 3,
87
+ justifyContent: 2,
88
+ };
89
+ }
90
+ }
91
+ }
92
+ export function mapAlignToScreenAlign(align, flexDirection = 0) {
93
+ const isColumn = flexDirection === 1;
94
+ switch (align) {
95
+ case AlignMode.TAM_TOP_LEFT:
96
+ return getAlignMode(align, isColumn);
97
+ case AlignMode.TAM_TOP_CENTER:
98
+ return getAlignMode(align, isColumn);
99
+ case AlignMode.TAM_TOP_RIGHT:
100
+ return getAlignMode(align, isColumn);
101
+ case AlignMode.TAM_MIDDLE_LEFT:
102
+ return getAlignMode(align, isColumn);
103
+ case AlignMode.TAM_MIDDLE_CENTER:
104
+ return getAlignMode(align, isColumn);
105
+ case AlignMode.TAM_MIDDLE_RIGHT:
106
+ return getAlignMode(align, isColumn);
107
+ case AlignMode.TAM_BOTTOM_LEFT:
108
+ return getAlignMode(align, isColumn);
109
+ case AlignMode.TAM_BOTTOM_CENTER:
110
+ return getAlignMode(align, isColumn);
111
+ case AlignMode.TAM_BOTTOM_RIGHT:
112
+ return getAlignMode(align, isColumn);
113
+ default:
114
+ throw new Error(`Unsupported AlignMode: ${align}`);
115
+ }
116
+ }
117
+ export function getUITransform(entiy, height = 100, width = 100, unit = 2) {
118
+ let uiTransformComponent = UiTransform.getMutableOrNull(entiy);
119
+ if (!uiTransformComponent) {
120
+ uiTransformComponent = UiTransform.create(entiy);
121
+ uiTransformComponent.heightUnit = unit;
122
+ uiTransformComponent.widthUnit = unit;
123
+ uiTransformComponent.height = height;
124
+ uiTransformComponent.width = width;
125
+ uiTransformComponent.maxHeightUnit = unit;
126
+ uiTransformComponent.maxWidthUnit = unit;
127
+ uiTransformComponent.maxHeight = height;
128
+ uiTransformComponent.maxWidth = width;
129
+ }
130
+ if (entiy === 0) {
131
+ uiTransformComponent.positionType = 1;
132
+ }
133
+ return uiTransformComponent;
134
+ }
135
+ export function getUIBackground(entity, src, textureMode = 0, wrapMode = 1) {
136
+ return UiBackground.createOrReplace(entity, {
137
+ textureMode,
138
+ texture: {
139
+ tex: {
140
+ $case: 'texture',
141
+ texture: {
142
+ src,
143
+ wrapMode,
144
+ },
145
+ },
146
+ },
147
+ uvs: [],
148
+ });
149
+ }
150
+ function breakLines(text, linelength) {
151
+ const lineBreak = '\n';
152
+ let counter = 0;
153
+ let line = '';
154
+ let returnText = '';
155
+ let bMatchFound = false;
156
+ const lineLen = linelength ? linelength : 50;
157
+ if (!text)
158
+ return '';
159
+ if (text.length < lineLen + 1) {
160
+ return text;
161
+ }
162
+ while (counter < text.length) {
163
+ line = text.substring(counter, counter + lineLen);
164
+ bMatchFound = false;
165
+ if (line.length == lineLen) {
166
+ for (let i = line.length; i > -1; i--) {
167
+ if (line.substring(i, i + 1) == ' ') {
168
+ counter += line.substring(0, i).length;
169
+ line = line.substring(0, i) + lineBreak;
170
+ returnText += line;
171
+ bMatchFound = true;
172
+ break;
173
+ }
174
+ }
175
+ if (!bMatchFound) {
176
+ counter += line.length;
177
+ line = line + lineBreak;
178
+ returnText += line;
179
+ }
180
+ }
181
+ else {
182
+ returnText += line;
183
+ break;
184
+ }
185
+ }
186
+ return returnText;
187
+ }
188
+ export function getUIText(entity, text, fontSize = 10, containerWidth, align = AlignMode.TAM_MIDDLE_CENTER, color = Color4.Black()) {
189
+ const lineLength = Math.floor(containerWidth / (fontSize / 1.7));
190
+ return UiText.createOrReplace(entity, {
191
+ value: breakLines(text, lineLength),
192
+ fontSize,
193
+ font: Font.F_MONOSPACE,
194
+ textAlign: align,
195
+ color,
196
+ });
197
+ }
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.js","sourceRoot":"","sources":["../src/ui.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  BackgroundTextureMode,\n  Entity,\n  TextAlignMode,\n  TextureWrapMode,\n  UiBackground,\n  UiText,\n  UiTransform,\n  YGAlign,\n  YGFlexDirection,\n  YGJustify,\n  YGPositionType,\n  YGUnit,\n} from '@dcl/sdk/ecs'\nimport { Color4 } from '@dcl/sdk/math'\nimport { AlignMode, Font, ScreenAlignMode } from './enums'\n\nfunction getAlignMode(align: AlignMode, isColumn: boolean) {\n  switch (align) {\n    case AlignMode.TAM_TOP_LEFT: {\n      return {\n        alignItems: YGAlign.YGA_FLEX_START,\n        justifyContent: YGJustify.YGJ_FLEX_START,\n      }\n    }\n    case AlignMode.TAM_TOP_CENTER: {\n      return isColumn\n        ? {\n            alignItems: YGAlign.YGA_CENTER,\n            justifyContent: YGJustify.YGJ_FLEX_START,\n          }\n        : {\n            alignItems: YGAlign.YGA_FLEX_START,\n            justifyContent: YGJustify.YGJ_CENTER,\n          }\n    }\n    case AlignMode.TAM_TOP_RIGHT: {\n      return isColumn\n        ? {\n            alignItems: YGAlign.YGA_FLEX_END,\n            justifyContent: YGJustify.YGJ_FLEX_START,\n          }\n        : {\n            alignItems: YGAlign.YGA_FLEX_START,\n            justifyContent: YGJustify.YGJ_FLEX_END,\n          }\n    }\n    case AlignMode.TAM_MIDDLE_LEFT: {\n      return isColumn\n        ? {\n            alignItems: YGAlign.YGA_FLEX_START,\n            justifyContent: YGJustify.YGJ_CENTER,\n          }\n        : {\n            alignItems: YGAlign.YGA_CENTER,\n            justifyContent: YGJustify.YGJ_FLEX_START,\n          }\n    }\n    case AlignMode.TAM_MIDDLE_CENTER: {\n      return {\n        alignItems: YGAlign.YGA_CENTER,\n        justifyContent: YGJustify.YGJ_CENTER,\n      }\n    }\n    case AlignMode.TAM_MIDDLE_RIGHT: {\n      return isColumn\n        ? {\n            alignItems: YGAlign.YGA_FLEX_END,\n            justifyContent: YGJustify.YGJ_CENTER,\n          }\n        : {\n            alignItems: YGAlign.YGA_CENTER,\n            justifyContent: YGJustify.YGJ_FLEX_END,\n          }\n    }\n    case AlignMode.TAM_BOTTOM_LEFT: {\n      return isColumn\n        ? {\n            alignItems: YGAlign.YGA_FLEX_START,\n            justifyContent: YGJustify.YGJ_FLEX_END,\n          }\n        : {\n            alignItems: YGJustify.YGJ_FLEX_END,\n            justifyContent: YGAlign.YGA_FLEX_START,\n          }\n    }\n    case AlignMode.TAM_BOTTOM_CENTER: {\n      return isColumn\n        ? {\n            alignItems: YGAlign.YGA_CENTER,\n            justifyContent: YGJustify.YGJ_FLEX_END,\n          }\n        : {\n            alignItems: YGAlign.YGA_FLEX_END,\n            justifyContent: YGJustify.YGJ_CENTER,\n          }\n    }\n    case AlignMode.TAM_BOTTOM_RIGHT: {\n      return {\n        alignItems: YGAlign.YGA_FLEX_END,\n        justifyContent: YGJustify.YGJ_FLEX_END,\n      }\n    }\n  }\n}\n\nexport function mapAlignToScreenAlign(\n  align: AlignMode,\n  flexDirection = YGFlexDirection.YGFD_ROW,\n): ScreenAlignMode {\n  const isColumn = flexDirection === YGFlexDirection.YGFD_COLUMN\n\n  switch (align) {\n    case AlignMode.TAM_TOP_LEFT:\n      return getAlignMode(align, isColumn) as any\n    case AlignMode.TAM_TOP_CENTER:\n      return getAlignMode(align, isColumn) as any\n    case AlignMode.TAM_TOP_RIGHT:\n      return getAlignMode(align, isColumn) as any\n    case AlignMode.TAM_MIDDLE_LEFT:\n      return getAlignMode(align, isColumn) as any\n    case AlignMode.TAM_MIDDLE_CENTER:\n      return getAlignMode(align, isColumn) as any\n    case AlignMode.TAM_MIDDLE_RIGHT:\n      return getAlignMode(align, isColumn) as any\n    case AlignMode.TAM_BOTTOM_LEFT:\n      return getAlignMode(align, isColumn) as any\n    case AlignMode.TAM_BOTTOM_CENTER:\n      return getAlignMode(align, isColumn) as any\n    case AlignMode.TAM_BOTTOM_RIGHT:\n      return getAlignMode(align, isColumn) as any\n    default:\n      // Handle default case or throw an error if needed\n      throw new Error(`Unsupported AlignMode: ${align}`)\n  }\n}\n\nexport function getUITransform(\n  entiy: Entity,\n  height = 100,\n  width = 100,\n  unit: YGUnit = YGUnit.YGU_PERCENT,\n) {\n  let uiTransformComponent = UiTransform.getMutableOrNull(entiy)\n\n  if (!uiTransformComponent) {\n    uiTransformComponent = UiTransform.create(entiy)\n    uiTransformComponent.heightUnit = unit\n    uiTransformComponent.widthUnit = unit\n    uiTransformComponent.height = height\n    uiTransformComponent.width = width\n    uiTransformComponent.maxHeightUnit = unit\n    uiTransformComponent.maxWidthUnit = unit\n    uiTransformComponent.maxHeight = height\n    uiTransformComponent.maxWidth = width\n  }\n\n  if (entiy === 0) {\n    uiTransformComponent.positionType = YGPositionType.YGPT_ABSOLUTE\n  }\n\n  return uiTransformComponent\n}\n\nexport function getUIBackground(\n  entity: Entity,\n  src: string,\n  textureMode = BackgroundTextureMode.NINE_SLICES,\n  wrapMode = TextureWrapMode.TWM_CLAMP,\n) {\n  return UiBackground.createOrReplace(entity, {\n    textureMode,\n    texture: {\n      tex: {\n        $case: 'texture',\n        texture: {\n          src,\n          wrapMode,\n        },\n      },\n    },\n    uvs: [],\n  })\n}\n\nfunction breakLines(text: string, linelength: number) {\n  const lineBreak = '\\n'\n  let counter = 0\n  let line = ''\n  let returnText = ''\n  let bMatchFound = false\n  const lineLen = linelength ? linelength : 50\n\n  if (!text) return ''\n  if (text.length < lineLen + 1) {\n    return text\n  }\n\n  while (counter < text.length) {\n    line = text.substring(counter, counter + lineLen)\n    bMatchFound = false\n    if (line.length == lineLen) {\n      for (let i = line.length; i > -1; i--) {\n        if (line.substring(i, i + 1) == ' ') {\n          counter += line.substring(0, i).length\n          line = line.substring(0, i) + lineBreak\n          returnText += line\n          bMatchFound = true\n          break\n        }\n      }\n\n      if (!bMatchFound) {\n        counter += line.length\n        line = line + lineBreak\n        returnText += line\n      }\n    } else {\n      returnText += line\n      break // We're breaking out of the the while(), not the for()\n    }\n  }\n\n  return returnText\n}\n\nexport function getUIText(\n  entity: Entity,\n  text: string,\n  fontSize = 10,\n  containerWidth: number,\n  align: AlignMode = AlignMode.TAM_MIDDLE_CENTER,\n  color: Color4 = Color4.Black(),\n) {\n  const lineLength = Math.floor(containerWidth / (fontSize / 1.7))\n\n  return UiText.createOrReplace(entity, {\n    value: breakLines(text, lineLength),\n    fontSize,\n    font: Font.F_MONOSPACE as any,\n    textAlign: align as unknown as TextAlignMode,\n    color,\n  })\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dcl/asset-packs",
3
- "version": "1.4.2",
3
+ "version": "1.4.3-20231206205632.commit-e83afe8",
4
4
  "description": "",
5
5
  "main": "dist/definitions.js",
6
6
  "typings": "dist/definitions.d.ts",
@@ -59,5 +59,5 @@
59
59
  "semi": false,
60
60
  "printWidth": 80
61
61
  },
62
- "commit": "8ce8badcab6df1f8614c4810d2f76af9e12b8be5"
62
+ "commit": "e83afe831c3b87cdc25d27c9f99d4d1effc391a3"
63
63
  }