@internetarchive/collection-browser 4.1.3-alpha-webdev8257.0 → 4.1.3

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.
@@ -1,6 +1,5 @@
1
1
  import { css, html, nothing, PropertyValues } from 'lit';
2
2
  import { customElement, property, query } from 'lit/decorators.js';
3
- import { classMap } from 'lit/directives/class-map.js';
4
3
  import { ifDefined } from 'lit/directives/if-defined.js';
5
4
  import { msg } from '@lit/localize';
6
5
  import type {
@@ -19,7 +18,7 @@ import './list/tile-list-compact';
19
18
  import './list/tile-list-compact-header';
20
19
  import type { TileHoverPane } from './hover/tile-hover-pane';
21
20
  import { BaseTileComponent } from './base-tile-component';
22
- import { LayoutType, type TileAction } from './models';
21
+ import { LayoutType } from './models';
23
22
  import {
24
23
  HoverPaneController,
25
24
  HoverPaneControllerInterface,
@@ -73,9 +72,6 @@ export class TileDispatcher
73
72
  'Remove this item from the list',
74
73
  );
75
74
 
76
- /** Action buttons to display at the bottom of the tile (grid mode only) */
77
- @property({ type: Array }) tileActions: TileAction[] = [];
78
-
79
75
  private hoverPaneController?: HoverPaneControllerInterface;
80
76
 
81
77
  @query('#container')
@@ -108,20 +104,14 @@ export class TileDispatcher
108
104
 
109
105
  render() {
110
106
  const isGridMode = this.tileDisplayMode === 'grid';
111
- const hasTileActions = isGridMode && this.showTileActions;
112
107
  const hoverPaneTemplate =
113
108
  this.hoverPaneController?.getTemplate() ?? nothing;
114
- const containerClasses = classMap({
115
- hoverable: isGridMode,
116
- 'has-tile-actions': hasTileActions,
117
- });
118
109
  return html`
119
- <div id="container" class=${containerClasses}>
110
+ <div id="container" class=${isGridMode ? 'hoverable' : ''}>
120
111
  ${this.tileDisplayMode === 'list-header'
121
112
  ? this.headerTemplate
122
113
  : this.tileTemplate}
123
- ${this.tileActionsTemplate} ${this.manageCheckTemplate}
124
- ${hoverPaneTemplate}
114
+ ${this.manageCheckTemplate} ${hoverPaneTemplate}
125
115
  </div>
126
116
  `;
127
117
  }
@@ -316,57 +306,6 @@ export class TileDispatcher
316
306
  });
317
307
  }
318
308
 
319
- /** Whether tile action buttons should be rendered */
320
- private get showTileActions(): boolean {
321
- return (
322
- this.tileActions.length > 0 &&
323
- !this.isManageView &&
324
- this.tileDisplayMode === 'grid'
325
- );
326
- }
327
-
328
- private get tileActionsTemplate() {
329
- if (!this.showTileActions) return nothing;
330
-
331
- return html`
332
- <div
333
- class="tile-actions"
334
- @mouseenter=${this.handleTileActionsMouseEnter}
335
- @mousemove=${(e: Event) => e.stopPropagation()}
336
- >
337
- ${this.tileActions.map(
338
- action => html`
339
- <button
340
- class="tile-action-btn"
341
- @click=${(e: Event) => this.handleTileActionClick(e, action)}
342
- >
343
- ${action.label}
344
- </button>
345
- `,
346
- )}
347
- </div>
348
- `;
349
- }
350
-
351
- /**
352
- * When the mouse enters the tile actions area, dispatch a synthetic mouseleave
353
- * on the host to cancel the hover pane's show timer and hide any visible pane.
354
- */
355
- private handleTileActionsMouseEnter = (): void => {
356
- this.dispatchEvent(new MouseEvent('mouseleave', { bubbles: false }));
357
- };
358
-
359
- private handleTileActionClick(e: Event, action: TileAction): void {
360
- e.stopPropagation();
361
- this.dispatchEvent(
362
- new CustomEvent('tileActionClicked', {
363
- detail: { actionId: action.id, model: this.model },
364
- bubbles: true,
365
- composed: true,
366
- }),
367
- );
368
- }
369
-
370
309
  private get tile() {
371
310
  const {
372
311
  model,
@@ -527,43 +466,8 @@ export class TileDispatcher
527
466
  border-radius: 4px;
528
467
  }
529
468
 
530
- /*
531
- * When tile actions are present, the container becomes the visual "card"
532
- * so that the tile content and action buttons appear as one unified element.
533
- */
534
- /*
535
- * When tile actions are present, the container takes over the tile's
536
- * border-radius and box-shadow so that the action bar appears as part
537
- * of the same card. The inner tile's own shadow/radius are disabled
538
- * via CSS variable overrides so there is no visual duplication.
539
- */
540
- #container.has-tile-actions {
541
- display: flex;
542
- flex-direction: column;
543
- overflow: hidden;
544
- box-shadow: var(--tileShadow, 1px 1px 2px 0);
545
- --tileBoxShadow: none;
546
- --tileCornerRadius: 0;
547
- }
548
-
549
- #container.has-tile-actions .tile-link {
550
- flex: 1;
551
- min-height: 0;
552
- overflow: hidden;
553
- border-radius: 0;
554
- }
555
-
556
- /* Move hover shadow to container level when tile actions are present */
557
- #container.hoverable:not(.has-tile-actions) a:focus,
558
- #container.hoverable:not(.has-tile-actions) a:hover {
559
- box-shadow: var(
560
- --tileHoverBoxShadow,
561
- 0 0 6px 2px rgba(8, 8, 32, 0.8)
562
- );
563
- transition: box-shadow 0.1s ease;
564
- }
565
-
566
- #container.hoverable.has-tile-actions:hover {
469
+ #container.hoverable a:focus,
470
+ #container.hoverable a:hover {
567
471
  box-shadow: var(
568
472
  --tileHoverBoxShadow,
569
473
  0 0 6px 2px rgba(8, 8, 32, 0.8)
@@ -617,32 +521,6 @@ export class TileDispatcher
617
521
  left: -9999px;
618
522
  z-index: 2;
619
523
  }
620
-
621
- .tile-actions {
622
- flex-shrink: 0;
623
- display: flex;
624
- border-top: 1px solid var(--tileActionSeparatorColor, #ddd);
625
- }
626
-
627
- .tile-action-btn {
628
- flex: 1;
629
- padding: 8px;
630
- border: none;
631
- border-radius: 0;
632
- font-size: 1.2rem;
633
- cursor: pointer;
634
- color: var(--tileActionColor, #333);
635
- background: var(--tileActionBg, #fff);
636
- transition: background 0.15s;
637
- }
638
-
639
- .tile-action-btn + .tile-action-btn {
640
- border-left: 1px solid var(--tileActionSeparatorColor, #ddd);
641
- }
642
-
643
- .tile-action-btn:hover {
644
- background: var(--tileActionHoverBg, #f0f0f0);
645
- }
646
524
  `,
647
525
  ];
648
526
  }
package/tsconfig.json CHANGED
@@ -1,25 +1,25 @@
1
- {
2
- "compilerOptions": {
3
- "target": "esnext",
4
- "module": "esnext",
5
- "moduleResolution": "bundler",
6
- "noEmitOnError": true,
7
- "lib": [
8
- "ESNext",
9
- "dom",
10
- "dom.iterable"
11
- ],
12
- "strict": true,
13
- "esModuleInterop": false,
14
- "allowSyntheticDefaultImports": true,
15
- "experimentalDecorators": true,
16
- "importHelpers": true,
17
- "outDir": "dist",
18
- "sourceMap": true,
19
- "inlineSources": true,
20
- "rootDir": "./",
21
- "declaration": true,
22
- "useDefineForClassFields": false,
23
- },
24
- "include": ["src", "test", "index.ts", "types"],
25
- }
1
+ {
2
+ "compilerOptions": {
3
+ "target": "esnext",
4
+ "module": "esnext",
5
+ "moduleResolution": "bundler",
6
+ "noEmitOnError": true,
7
+ "lib": [
8
+ "ESNext",
9
+ "dom",
10
+ "dom.iterable"
11
+ ],
12
+ "strict": true,
13
+ "esModuleInterop": false,
14
+ "allowSyntheticDefaultImports": true,
15
+ "experimentalDecorators": true,
16
+ "importHelpers": true,
17
+ "outDir": "dist",
18
+ "sourceMap": true,
19
+ "inlineSources": true,
20
+ "rootDir": "./",
21
+ "declaration": true,
22
+ "useDefineForClassFields": false,
23
+ },
24
+ "include": ["src", "test", "index.ts", "types"],
25
+ }
@@ -1,30 +1,30 @@
1
- // import { hmrPlugin, presets } from '@open-wc/dev-server-hmr';
2
-
3
- /** Use Hot Module replacement by adding --hmr to the start command */
4
- const hmr = process.argv.includes('--hmr');
5
-
6
- export default /** @type {import('@web/dev-server').DevServerConfig} */ ({
7
- nodeResolve: true,
8
- open: '/',
9
- watch: !hmr,
10
-
11
- /** Compile JS for older browsers. Requires @web/dev-server-esbuild plugin */
12
- // esbuildTarget: 'auto'
13
-
14
- /** Set appIndex to enable SPA routing */
15
- // appIndex: 'demo/index.html',
16
-
17
- /** Confgure bare import resolve plugin */
18
- // nodeResolve: {
19
- // exportConditions: ['browser', 'development']
20
- // },
21
-
22
- plugins: [
23
- /** Use Hot Module Replacement by uncommenting. Requires @open-wc/dev-server-hmr plugin */
24
- // hmr && hmrPlugin({ exclude: ['**/*/node_modules/**/*'], presets: [presets.litElement] }),
25
- ],
26
-
27
- http2: true,
28
- sslCert: './local.archive.org.cert',
29
- sslKey: './local.archive.org.key',
30
- });
1
+ // import { hmrPlugin, presets } from '@open-wc/dev-server-hmr';
2
+
3
+ /** Use Hot Module replacement by adding --hmr to the start command */
4
+ const hmr = process.argv.includes('--hmr');
5
+
6
+ export default /** @type {import('@web/dev-server').DevServerConfig} */ ({
7
+ nodeResolve: true,
8
+ open: '/',
9
+ watch: !hmr,
10
+
11
+ /** Compile JS for older browsers. Requires @web/dev-server-esbuild plugin */
12
+ // esbuildTarget: 'auto'
13
+
14
+ /** Set appIndex to enable SPA routing */
15
+ // appIndex: 'demo/index.html',
16
+
17
+ /** Confgure bare import resolve plugin */
18
+ // nodeResolve: {
19
+ // exportConditions: ['browser', 'development']
20
+ // },
21
+
22
+ plugins: [
23
+ /** Use Hot Module Replacement by uncommenting. Requires @open-wc/dev-server-hmr plugin */
24
+ // hmr && hmrPlugin({ exclude: ['**/*/node_modules/**/*'], presets: [presets.litElement] }),
25
+ ],
26
+
27
+ http2: true,
28
+ sslCert: './local.archive.org.cert',
29
+ sslKey: './local.archive.org.key',
30
+ });
@@ -1,52 +1,52 @@
1
- import rollupImage from '@rollup/plugin-image';
2
- import { rollupAdapter } from '@web/dev-server-rollup';
3
- // import { playwrightLauncher } from '@web/test-runner-playwright';
4
-
5
- const filteredLogs = ['Running in dev mode', 'lit-html is in dev mode'];
6
-
7
- export default /** @type {import("@web/test-runner").TestRunnerConfig} */ ({
8
- /** Test files to run */
9
- files: 'dist/test/**/*.test.js',
10
-
11
- /** Resolve bare module imports */
12
- nodeResolve: {
13
- exportConditions: ['browser', 'development'],
14
- },
15
-
16
- mimeTypes: {
17
- '**/*.scss': 'js',
18
- '**/*.css': 'js',
19
- '**/*.svg': 'js',
20
- '**/*.json': 'js',
21
- },
22
-
23
- /** Filter out lit dev mode logs */
24
- filterBrowserLogs(log) {
25
- for (const arg of log.args) {
26
- if (typeof arg === 'string' && filteredLogs.some(l => arg.includes(l))) {
27
- return false;
28
- }
29
- }
30
- return true;
31
- },
32
-
33
- plugins: [rollupAdapter(rollupImage())],
34
-
35
- /** Compile JS for older browsers. Requires @web/dev-server-esbuild plugin */
36
- // esbuildTarget: 'auto',
37
-
38
- /** Amount of browsers to run concurrently */
39
- // concurrentBrowsers: 2,
40
-
41
- /** Amount of test files per browser to test concurrently */
42
- // concurrency: 1,
43
-
44
- /** Browsers to run tests on */
45
- // browsers: [
46
- // playwrightLauncher({ product: 'chromium' }),
47
- // playwrightLauncher({ product: 'firefox' }),
48
- // playwrightLauncher({ product: 'webkit' }),
49
- // ],
50
-
51
- // See documentation for all available options
52
- });
1
+ import rollupImage from '@rollup/plugin-image';
2
+ import { rollupAdapter } from '@web/dev-server-rollup';
3
+ // import { playwrightLauncher } from '@web/test-runner-playwright';
4
+
5
+ const filteredLogs = ['Running in dev mode', 'lit-html is in dev mode'];
6
+
7
+ export default /** @type {import("@web/test-runner").TestRunnerConfig} */ ({
8
+ /** Test files to run */
9
+ files: 'dist/test/**/*.test.js',
10
+
11
+ /** Resolve bare module imports */
12
+ nodeResolve: {
13
+ exportConditions: ['browser', 'development'],
14
+ },
15
+
16
+ mimeTypes: {
17
+ '**/*.scss': 'js',
18
+ '**/*.css': 'js',
19
+ '**/*.svg': 'js',
20
+ '**/*.json': 'js',
21
+ },
22
+
23
+ /** Filter out lit dev mode logs */
24
+ filterBrowserLogs(log) {
25
+ for (const arg of log.args) {
26
+ if (typeof arg === 'string' && filteredLogs.some(l => arg.includes(l))) {
27
+ return false;
28
+ }
29
+ }
30
+ return true;
31
+ },
32
+
33
+ plugins: [rollupAdapter(rollupImage())],
34
+
35
+ /** Compile JS for older browsers. Requires @web/dev-server-esbuild plugin */
36
+ // esbuildTarget: 'auto',
37
+
38
+ /** Amount of browsers to run concurrently */
39
+ // concurrentBrowsers: 2,
40
+
41
+ /** Amount of test files per browser to test concurrently */
42
+ // concurrency: 1,
43
+
44
+ /** Browsers to run tests on */
45
+ // browsers: [
46
+ // playwrightLauncher({ product: 'chromium' }),
47
+ // playwrightLauncher({ product: 'firefox' }),
48
+ // playwrightLauncher({ product: 'webkit' }),
49
+ // ],
50
+
51
+ // See documentation for all available options
52
+ });
@@ -1,11 +0,0 @@
1
- {
2
- "permissions": {
3
- "allow": [
4
- "Bash(cd /c/Users/Laton/workspace/IA/iaux-collection-browser && npm test 2>&1)",
5
- "Bash(cd /c/Users/Laton/workspace/IA/iaux-collection-browser && yarn run format 2>&1)",
6
- "Bash(cd /c/Users/Laton/workspace/IA/iaux-collection-browser && npx tsc --noEmit 2>&1)",
7
- "Bash(cd /c/Users/Laton/workspace/IA/iaux-collection-browser && npx wtr --coverage 2>&1)",
8
- "Bash(cd /c/Users/Laton/workspace/IA/iaux-collection-browser && npm run format 2>&1)"
9
- ]
10
- }
11
- }