@formicoidea/labre-framework-edgy 0.23.0 → 0.23.1

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 (48) hide show
  1. package/dist/consts.d.ts +47 -0
  2. package/{src/consts.ts → dist/consts.js} +46 -50
  3. package/dist/descriptor.d.ts +7 -0
  4. package/{src/descriptor.ts → dist/descriptor.js} +1 -1
  5. package/dist/effects.d.ts +10 -0
  6. package/dist/effects.js +7 -0
  7. package/dist/element-renderer.d.ts +17 -0
  8. package/dist/element-renderer.js +177 -0
  9. package/dist/element-view.d.ts +19 -0
  10. package/dist/element-view.js +123 -0
  11. package/dist/index.d.ts +2 -0
  12. package/dist/index.js +2 -0
  13. package/dist/label-layout.d.ts +46 -0
  14. package/dist/label-layout.js +69 -0
  15. package/dist/node/consts.d.ts +34 -0
  16. package/{src/node/consts.ts → dist/node/consts.js} +19 -26
  17. package/dist/node/node-renderer.d.ts +14 -0
  18. package/dist/node/node-renderer.js +40 -0
  19. package/dist/node/node-view.d.ts +16 -0
  20. package/{src/node/node-view.ts → dist/node/node-view.js} +15 -21
  21. package/dist/templates/index.d.ts +3 -0
  22. package/dist/templates/index.js +210 -0
  23. package/dist/toolbar/config.d.ts +20 -0
  24. package/dist/toolbar/config.js +71 -0
  25. package/dist/toolbar/edgy-menu.d.ts +31 -0
  26. package/dist/toolbar/edgy-menu.js +195 -0
  27. package/dist/toolbar/edgy-senior-button.d.ts +16 -0
  28. package/{src/toolbar/edgy-senior-button.ts → dist/toolbar/edgy-senior-button.js} +33 -38
  29. package/dist/toolbar/icons.d.ts +13 -0
  30. package/{src/toolbar/icons.ts → dist/toolbar/icons.js} +20 -25
  31. package/dist/toolbar/node-config.d.ts +2 -0
  32. package/dist/toolbar/node-config.js +162 -0
  33. package/dist/toolbar/senior-tool.d.ts +2 -0
  34. package/{src/toolbar/senior-tool.ts → dist/toolbar/senior-tool.js} +5 -5
  35. package/dist/view.d.ts +7 -0
  36. package/dist/view.js +36 -0
  37. package/package.json +15 -6
  38. package/src/effects.ts +0 -14
  39. package/src/element-renderer.ts +0 -208
  40. package/src/element-view.ts +0 -145
  41. package/src/index.ts +0 -1
  42. package/src/label-layout.ts +0 -105
  43. package/src/node/node-renderer.ts +0 -64
  44. package/src/templates/index.ts +0 -254
  45. package/src/toolbar/config.ts +0 -96
  46. package/src/toolbar/edgy-menu.ts +0 -242
  47. package/src/toolbar/node-config.ts +0 -202
  48. package/src/view.ts +0 -39
@@ -1,202 +0,0 @@
1
- import { EdgelessCRUDIdentifier } from '@formicoidea/labre-core/blocks/surface';
2
- import {
3
- packColor,
4
- type PickColorEvent,
5
- } from '@formicoidea/labre-core/components/color-picker';
6
- import { shapeToolbarConfig } from '@formicoidea/labre-core/gfx/shape';
7
- import {
8
- type Color,
9
- DefaultTheme,
10
- isTransparent,
11
- LineWidth,
12
- type Palette,
13
- resolveColor,
14
- ShapeElementModel,
15
- StrokeStyle,
16
- } from '@formicoidea/labre-core/model';
17
- import {
18
- type ToolbarContext,
19
- type ToolbarModuleConfig,
20
- ToolbarModuleExtension,
21
- } from '@formicoidea/labre-core/shared/services';
22
- import { getMostCommonValue } from '@formicoidea/labre-core/shared/utils';
23
- import { BlockFlavourIdentifier } from '@formicoidea/labre-core/std';
24
- import { html } from 'lit';
25
-
26
- /**
27
- * The typical EDGY palette, surfaced as ready-made swatches in the EDGY node
28
- * color picker (facet + intersection colours, saturated then pastel), followed
29
- * by the default editor palette.
30
- */
31
- const EDGY_PALETTES: Palette[] = [
32
- { key: 'Identity', value: '#00ea4e' },
33
- { key: 'Architecture', value: '#034cee' },
34
- { key: 'Experience', value: '#ff0056' },
35
- { key: 'Organisation', value: '#00caf4' },
36
- { key: 'Brand', value: '#ffa500' },
37
- { key: 'Product', value: '#cf00ff' },
38
- { key: 'Identity light', value: '#80ffb7' },
39
- { key: 'Architecture light', value: '#a6c0ff' },
40
- { key: 'Experience light', value: '#ff99bd' },
41
- { key: 'Organisation light', value: '#80eaff' },
42
- { key: 'Brand light', value: '#ffd580' },
43
- { key: 'Product light', value: '#e599ff' },
44
- ];
45
-
46
- /**
47
- * From the default editor palette we keep ONLY the neutrals (greys, white,
48
- * black, transparent) — the historical colours are dropped in favour of the
49
- * EDGY swatches above.
50
- */
51
- const NEUTRAL_KEY = /grey|gray|white|black|transparent/i;
52
-
53
- const EDGY_PALETTE_LIST: Palette[] = [
54
- ...EDGY_PALETTES,
55
- ...DefaultTheme.Palettes.filter(p => NEUTRAL_KEY.test(p.key)),
56
- ];
57
-
58
- // Mirror of the shape color action's text-color rule.
59
- function getTextColor(fillColor: Color) {
60
- if (fillColor === DefaultTheme.black) return DefaultTheme.white;
61
- if (fillColor === DefaultTheme.white) return DefaultTheme.black;
62
- return DefaultTheme.shapeTextColor;
63
- }
64
-
65
- /**
66
- * EDGY fill / stroke colour picker — identical to the shape one but seeded with
67
- * the EDGY palette swatches (`.palettes`).
68
- */
69
- const edgyColorAction = {
70
- id: 'e.color',
71
- when(ctx: ToolbarContext) {
72
- return ctx.getSurfaceModelsByType(ShapeElementModel).length > 0;
73
- },
74
- content(ctx: ToolbarContext) {
75
- const models = ctx.getSurfaceModelsByType(ShapeElementModel);
76
- if (!models.length) return null;
77
-
78
- const enableCustomColor = ctx.features.getFlag('enable_color_picker');
79
- const theme = ctx.theme.edgeless$.value;
80
-
81
- const firstModel = models[0];
82
- const originalFillColor = firstModel.fillColor;
83
- const originalStrokeColor = firstModel.strokeColor;
84
-
85
- const mapped = models.map(
86
- ({ filled, fillColor, strokeColor, strokeWidth, strokeStyle }) => ({
87
- fillColor: filled
88
- ? resolveColor(fillColor, theme)
89
- : DefaultTheme.transparent,
90
- strokeColor: resolveColor(strokeColor, theme),
91
- strokeWidth,
92
- strokeStyle,
93
- })
94
- );
95
- const fillColor =
96
- getMostCommonValue(mapped, 'fillColor') ??
97
- resolveColor(DefaultTheme.shapeFillColor, theme);
98
- const strokeColor =
99
- getMostCommonValue(mapped, 'strokeColor') ??
100
- resolveColor(DefaultTheme.shapeStrokeColor, theme);
101
- const strokeWidth =
102
- getMostCommonValue(mapped, 'strokeWidth') ?? LineWidth.Four;
103
- const strokeStyle =
104
- getMostCommonValue(mapped, 'strokeStyle') ?? StrokeStyle.Solid;
105
-
106
- const pickColorWrapper =
107
- (field: string, pickCallback: (palette: Palette) => void) =>
108
- (e: CustomEvent<PickColorEvent>) => {
109
- e.stopPropagation();
110
- switch (e.detail.type) {
111
- case 'pick':
112
- pickCallback(e.detail.detail);
113
- break;
114
- case 'start':
115
- ctx.store.captureSync();
116
- models.forEach(model => model.stash(field));
117
- break;
118
- case 'end':
119
- ctx.store.transact(() => {
120
- models.forEach(model => model.pop(field));
121
- });
122
- }
123
- };
124
-
125
- const onPickFillColor = pickColorWrapper('fillColor', palette => {
126
- const value = palette.value;
127
- const filled = isTransparent(value);
128
- const props = packColor('fillColor', value);
129
- const crud = ctx.std.get(EdgelessCRUDIdentifier);
130
- models.forEach(model => {
131
- if (filled && !model.filled) {
132
- const color = getTextColor(value);
133
- Object.assign(props, { filled, color });
134
- }
135
- crud.updateElement(model.id, props);
136
- });
137
- });
138
-
139
- const onPickStrokeColor = pickColorWrapper('strokeColor', palette => {
140
- const props = packColor('strokeColor', palette.value);
141
- const crud = ctx.std.get(EdgelessCRUDIdentifier);
142
- models.forEach(model => crud.updateElement(model.id, props));
143
- });
144
-
145
- const onPickStrokeStyle = (
146
- e: CustomEvent<{ type: string; value: number & StrokeStyle }>
147
- ) => {
148
- e.stopPropagation();
149
- const { type, value } = e.detail;
150
- const crud = ctx.std.get(EdgelessCRUDIdentifier);
151
- const props =
152
- type === 'size'
153
- ? { strokeWidth: value as number }
154
- : { strokeStyle: value as StrokeStyle };
155
- for (const model of models) {
156
- crud.updateElement(model.id, props);
157
- }
158
- };
159
-
160
- return html`
161
- <edgeless-shape-color-picker
162
- @pickFillColor=${onPickFillColor}
163
- @pickStrokeColor=${onPickStrokeColor}
164
- @pickStrokeStyle=${onPickStrokeStyle}
165
- .palettes=${EDGY_PALETTE_LIST}
166
- .payload=${{
167
- fillColor,
168
- strokeColor,
169
- strokeWidth,
170
- strokeStyle,
171
- originalFillColor,
172
- originalStrokeColor,
173
- theme,
174
- enableCustomColor,
175
- }}
176
- >
177
- </edgeless-shape-color-picker>
178
- `;
179
- },
180
- };
181
-
182
- /**
183
- * EDGY nodes are {@link ShapeElementModel} subclasses, so the shape toolbar's
184
- * actions operate on them directly. We reuse the line-style + text actions, add
185
- * the EDGY-seeded color picker, and drop the actions that don't fit an EDGY base
186
- * shape (switch shape type, edit polygon vertices).
187
- */
188
- const KEEP_FROM_SHAPE = (id: string) =>
189
- id === 'd.style' || id === 'f.text' || id.startsWith('g.text-');
190
-
191
- const edgyNodeToolbarConfig = {
192
- actions: [
193
- ...shapeToolbarConfig.actions.filter(action => KEEP_FROM_SHAPE(action.id)),
194
- edgyColorAction,
195
- ],
196
- when: shapeToolbarConfig.when,
197
- } as ToolbarModuleConfig;
198
-
199
- export const edgyNodeToolbarExtension = ToolbarModuleExtension({
200
- id: BlockFlavourIdentifier('affine:surface:edgyNode'),
201
- config: edgyNodeToolbarConfig,
202
- });
package/src/view.ts DELETED
@@ -1,39 +0,0 @@
1
- import {
2
- type ViewExtensionContext,
3
- ViewExtensionProvider,
4
- } from '@formicoidea/labre-core/ext-loader';
5
- import { extendTemplateCategory } from '@formicoidea/labre-core/gfx/template';
6
-
7
- import { effects } from './effects';
8
- import { edgyTemplateCategory } from './templates';
9
- import { EdgyFacetsRendererExtension } from './element-renderer';
10
- import { EdgyInteraction, EdgyView } from './element-view';
11
- import { EdgyNodeRendererExtension } from './node/node-renderer';
12
- import { EdgyNodeView } from './node/node-view';
13
- import { edgyToolbarExtension } from './toolbar/config';
14
- import { edgyNodeToolbarExtension } from './toolbar/node-config';
15
- import { edgySeniorTool } from './toolbar/senior-tool';
16
-
17
- export class EdgyViewExtension extends ViewExtensionProvider {
18
- override name = 'affine-edgy-gfx';
19
-
20
- override effect(): void {
21
- super.effect();
22
- effects();
23
- extendTemplateCategory(edgyTemplateCategory);
24
- }
25
-
26
- override setup(context: ViewExtensionContext) {
27
- super.setup(context);
28
- context.register(EdgyView);
29
- context.register(EdgyFacetsRendererExtension);
30
- context.register(EdgyNodeView);
31
- context.register(EdgyNodeRendererExtension);
32
- if (this.isEdgeless(context.scope)) {
33
- context.register(EdgyInteraction);
34
- context.register(edgySeniorTool);
35
- context.register(edgyToolbarExtension);
36
- context.register(edgyNodeToolbarExtension);
37
- }
38
- }
39
- }