valtech-components 2.0.593 → 2.0.594

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,7 +1,8 @@
1
- import { Component, Input, signal } from '@angular/core';
1
+ import { Component, computed, inject, Input, signal } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { RouterLink } from '@angular/router';
4
4
  import { IonButton } from '@ionic/angular/standalone';
5
+ import { I18nService } from '../../../services/i18n';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@angular/common";
7
8
  /**
@@ -28,7 +29,13 @@ import * as i1 from "@angular/common";
28
29
  export class Terminal404Component {
29
30
  constructor() {
30
31
  this.props = {};
32
+ this.i18n = inject(I18nService);
31
33
  this.requestedPath = signal('page-not-found');
34
+ // i18n texts
35
+ this.directoryNotFound = computed(() => this.i18n.t('terminal404.directoryNotFound', 'No such file or directory'));
36
+ this.searching = computed(() => this.i18n.t('terminal404.searching', 'Searching...'));
37
+ this.noResults = computed(() => this.i18n.t('terminal404.noResults', 'No results found.'));
38
+ this.searchTerm = computed(() => this.i18n.t('terminal404.searchTerm', 'page'));
32
39
  }
33
40
  get containerStyles() {
34
41
  const styles = {};
@@ -92,24 +99,24 @@ export class Terminal404Component {
92
99
 
93
100
  <div class="line">
94
101
  <span class="error"
95
- >bash: cd: /{{ requestedPath() }}: No existe el directorio</span
102
+ >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span
96
103
  >
97
104
  </div>
98
105
 
99
106
  <div class="line">
100
107
  <span class="prompt">user&#64;app</span>
101
108
  <span class="command">:~$ </span>
102
- <span class="command">sudo find / -name "pagina"</span>
109
+ <span class="command">sudo find / -name "{{ searchTerm() }}"</span>
103
110
  </div>
104
111
 
105
112
  <div class="line">
106
113
  <span class="info"
107
- ><span class="search-icon">🔍</span> Buscando...</span
114
+ ><span class="search-icon">🔍</span> {{ searching() }}</span
108
115
  >
109
116
  </div>
110
117
 
111
118
  <div class="line">
112
- <span class="warning">find: No se encontraron resultados.</span>
119
+ <span class="warning">find: {{ noResults() }}</span>
113
120
  </div>
114
121
 
115
122
  <div class="line">
@@ -161,24 +168,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
161
168
 
162
169
  <div class="line">
163
170
  <span class="error"
164
- >bash: cd: /{{ requestedPath() }}: No existe el directorio</span
171
+ >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span
165
172
  >
166
173
  </div>
167
174
 
168
175
  <div class="line">
169
176
  <span class="prompt">user&#64;app</span>
170
177
  <span class="command">:~$ </span>
171
- <span class="command">sudo find / -name "pagina"</span>
178
+ <span class="command">sudo find / -name "{{ searchTerm() }}"</span>
172
179
  </div>
173
180
 
174
181
  <div class="line">
175
182
  <span class="info"
176
- ><span class="search-icon">🔍</span> Buscando...</span
183
+ ><span class="search-icon">🔍</span> {{ searching() }}</span
177
184
  >
178
185
  </div>
179
186
 
180
187
  <div class="line">
181
- <span class="warning">find: No se encontraron resultados.</span>
188
+ <span class="warning">find: {{ noResults() }}</span>
182
189
  </div>
183
190
 
184
191
  <div class="line">
@@ -203,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
203
210
  }], propDecorators: { props: [{
204
211
  type: Input
205
212
  }] } });
206
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminal-404.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/organisms/terminal-404/terminal-404.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, signal } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterLink } from '@angular/router';\nimport { IonButton } from '@ionic/angular/standalone';\nimport { Terminal404Metadata } from './types';\n\n/**\n * val-terminal-404\n *\n * A fun, terminal-styled 404 page component with typing animations.\n *\n * Features:\n * - Terminal window aesthetic with colored dots\n * - Typing animation effect with sequential line reveals\n * - Blinking cursor\n * - Customizable colors to match brand\n * - Shows the attempted path\n *\n * @example\n * <val-terminal-404\n *   [props]=\"{\n *     primaryColor: '#4a1d96',\n *     homeRoute: '/',\n *     homeButtonText: 'cd /home'\n *   }\"\n * ></val-terminal-404>\n */\n@Component({\n  selector: 'val-terminal-404',\n  standalone: true,\n  imports: [CommonModule, IonButton, RouterLink],\n  styles: [\n    `\n      :host {\n        display: block;\n        width: 100%;\n        --terminal-primary: var(--ion-color-primary, #4a1d96);\n        --terminal-primary-light: var(--ion-color-primary-tint, #5b21b6);\n      }\n\n      .terminal-container {\n        min-height: 70vh;\n        display: flex;\n        flex-direction: column;\n        justify-content: center;\n        align-items: center;\n        padding: 2rem;\n        border-radius: 16px;\n      }\n\n      .terminal {\n        border-radius: 12px;\n        padding: 0;\n        max-width: 600px;\n        width: 100%;\n        box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n        overflow: hidden;\n      }\n\n      .terminal-header {\n        background: #161b22;\n        padding: 12px 16px;\n        display: flex;\n        align-items: center;\n        gap: 8px;\n      }\n\n      .terminal-dot {\n        width: 12px;\n        height: 12px;\n        border-radius: 50%;\n      }\n\n      .dot-red {\n        background: #ff5f56;\n      }\n      .dot-yellow {\n        background: #ffbd2e;\n      }\n      .dot-green {\n        background: #27ca40;\n      }\n\n      .terminal-title {\n        flex: 1;\n        text-align: center;\n        color: #8b949e;\n        font-size: 0.85rem;\n        font-family: monospace;\n      }\n\n      .terminal-body {\n        padding: 24px;\n        font-family: 'Fira Code', 'Monaco', 'Consolas', monospace;\n        font-size: 0.95rem;\n        line-height: 1.8;\n      }\n\n      .line {\n        margin-bottom: 8px;\n        opacity: 0;\n        animation: fadeIn 0.3s ease forwards;\n      }\n\n      .line:nth-child(1) {\n        animation-delay: 0.2s;\n      }\n      .line:nth-child(2) {\n        animation-delay: 0.8s;\n      }\n      .line:nth-child(3) {\n        animation-delay: 1.4s;\n      }\n      .line:nth-child(4) {\n        animation-delay: 2s;\n      }\n      .line:nth-child(5) {\n        animation-delay: 2.6s;\n      }\n      .line:nth-child(6) {\n        animation-delay: 3.2s;\n      }\n\n      @keyframes fadeIn {\n        to {\n          opacity: 1;\n        }\n      }\n\n      .prompt {\n        color: #7ee787;\n      }\n\n      .command {\n        color: #c9d1d9;\n      }\n\n      .error {\n        color: #f85149;\n      }\n\n      .info {\n        color: #58a6ff;\n      }\n\n      .warning {\n        color: #d29922;\n      }\n\n      .cursor {\n        display: inline-block;\n        width: 10px;\n        height: 18px;\n        background: #7ee787;\n        margin-left: 4px;\n        animation: blink 1s step-end infinite;\n        vertical-align: text-bottom;\n      }\n\n      @keyframes blink {\n        0%,\n        100% {\n          opacity: 1;\n        }\n        50% {\n          opacity: 0;\n        }\n      }\n\n      .error-code {\n        font-size: 6rem;\n        font-weight: 900;\n        text-align: center;\n        margin: 0.5rem 0 1rem;\n        font-family: monospace;\n      }\n\n      .action-container {\n        margin-top: 2rem;\n        text-align: center;\n        opacity: 0;\n        animation: fadeIn 0.5s ease forwards;\n        animation-delay: 3.8s;\n      }\n\n      .home-button {\n        --border-radius: 8px;\n        --background: var(--terminal-primary);\n        --background-hover: var(--terminal-primary-light);\n        font-family: monospace;\n      }\n\n      .error-code {\n        color: var(--terminal-primary);\n        text-shadow: 0 0 40px color-mix(in srgb, var(--terminal-primary) 30%, transparent);\n      }\n\n      .search-icon {\n        animation: searching 2s ease-in-out infinite;\n        display: inline-block;\n      }\n\n      @keyframes searching {\n        0%,\n        100% {\n          transform: translateX(0);\n        }\n        25% {\n          transform: translateX(5px);\n        }\n        75% {\n          transform: translateX(-5px);\n        }\n      }\n    `,\n  ],\n  template: `\n    <div\n      class=\"terminal-container\"\n      [ngStyle]=\"containerStyles\"\n    >\n      <div class=\"error-code\">404</div>\n\n      <div\n        class=\"terminal\"\n        [ngStyle]=\"{ background: props.terminalBackground || '#0d1117' }\"\n      >\n        <div class=\"terminal-header\">\n          <div class=\"terminal-dot dot-red\"></div>\n          <div class=\"terminal-dot dot-yellow\"></div>\n          <div class=\"terminal-dot dot-green\"></div>\n          <span class=\"terminal-title\">bash - 404</span>\n        </div>\n\n        <div class=\"terminal-body\">\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"command\">cd /{{ requestedPath() }}</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"error\"\n              >bash: cd: /{{ requestedPath() }}: No existe el directorio</span\n            >\n          </div>\n\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"command\">sudo find / -name \"pagina\"</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"info\"\n              ><span class=\"search-icon\">🔍</span> Buscando...</span\n            >\n          </div>\n\n          <div class=\"line\">\n            <span class=\"warning\">find: No se encontraron resultados.</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"cursor\"></span>\n          </div>\n        </div>\n      </div>\n\n      <div class=\"action-container\">\n        <ion-button\n          class=\"home-button\"\n          [routerLink]=\"props.homeRoute || '/'\"\n          expand=\"block\"\n        >\n          {{ props.homeButtonText || 'cd /home' }}\n        </ion-button>\n      </div>\n    </div>\n  `,\n})\nexport class Terminal404Component implements OnInit {\n  @Input() props: Terminal404Metadata = {};\n\n  requestedPath = signal('page-not-found');\n\n  get containerStyles(): Record<string, string> {\n    const styles: Record<string, string> = {};\n\n    // Background gradient\n    const bg = this.props.backgroundColor;\n    if (bg) {\n      styles['background'] = `linear-gradient(135deg, ${bg.start} 0%, ${bg.middle} 50%, ${bg.end} 100%)`;\n    } else {\n      styles['background'] = 'linear-gradient(135deg, #ede9fe 0%, #ddd6fe 50%, #c4b5fd 100%)';\n    }\n\n    // Override primary color if provided\n    if (this.props.primaryColor) {\n      styles['--terminal-primary'] = this.props.primaryColor;\n      styles['--terminal-primary-light'] = this.lightenColor(this.props.primaryColor);\n    }\n\n    return styles;\n  }\n\n  ngOnInit(): void {\n    if (typeof window !== 'undefined') {\n      const path = window.location.pathname.slice(1) || 'unknown';\n      this.requestedPath.set(path);\n    }\n  }\n\n  /**\n   * Lighten a hex color for hover states\n   */\n  lightenColor(hex: string): string {\n    // Simple lighten by adding to RGB values\n    const num = parseInt(hex.replace('#', ''), 16);\n    const r = Math.min(255, (num >> 16) + 20);\n    const g = Math.min(255, ((num >> 8) & 0x00ff) + 20);\n    const b = Math.min(255, (num & 0x0000ff) + 20);\n    return `#${((r << 16) | (g << 8) | b).toString(16).padStart(6, '0')}`;\n  }\n}\n"]}
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"terminal-404.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/organisms/terminal-404/terminal-404.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, inject, Input, OnInit, signal } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterLink } from '@angular/router';\nimport { IonButton } from '@ionic/angular/standalone';\nimport { Terminal404Metadata } from './types';\nimport { I18nService } from '../../../services/i18n';\n\n/**\n * val-terminal-404\n *\n * A fun, terminal-styled 404 page component with typing animations.\n *\n * Features:\n * - Terminal window aesthetic with colored dots\n * - Typing animation effect with sequential line reveals\n * - Blinking cursor\n * - Customizable colors to match brand\n * - Shows the attempted path\n *\n * @example\n * <val-terminal-404\n *   [props]=\"{\n *     primaryColor: '#4a1d96',\n *     homeRoute: '/',\n *     homeButtonText: 'cd /home'\n *   }\"\n * ></val-terminal-404>\n */\n@Component({\n  selector: 'val-terminal-404',\n  standalone: true,\n  imports: [CommonModule, IonButton, RouterLink],\n  styles: [\n    `\n      :host {\n        display: block;\n        width: 100%;\n        --terminal-primary: var(--ion-color-primary, #4a1d96);\n        --terminal-primary-light: var(--ion-color-primary-tint, #5b21b6);\n      }\n\n      .terminal-container {\n        min-height: 70vh;\n        display: flex;\n        flex-direction: column;\n        justify-content: center;\n        align-items: center;\n        padding: 2rem;\n        border-radius: 16px;\n      }\n\n      .terminal {\n        border-radius: 12px;\n        padding: 0;\n        max-width: 600px;\n        width: 100%;\n        box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n        overflow: hidden;\n      }\n\n      .terminal-header {\n        background: #161b22;\n        padding: 12px 16px;\n        display: flex;\n        align-items: center;\n        gap: 8px;\n      }\n\n      .terminal-dot {\n        width: 12px;\n        height: 12px;\n        border-radius: 50%;\n      }\n\n      .dot-red {\n        background: #ff5f56;\n      }\n      .dot-yellow {\n        background: #ffbd2e;\n      }\n      .dot-green {\n        background: #27ca40;\n      }\n\n      .terminal-title {\n        flex: 1;\n        text-align: center;\n        color: #8b949e;\n        font-size: 0.85rem;\n        font-family: monospace;\n      }\n\n      .terminal-body {\n        padding: 24px;\n        font-family: 'Fira Code', 'Monaco', 'Consolas', monospace;\n        font-size: 0.95rem;\n        line-height: 1.8;\n      }\n\n      .line {\n        margin-bottom: 8px;\n        opacity: 0;\n        animation: fadeIn 0.3s ease forwards;\n      }\n\n      .line:nth-child(1) {\n        animation-delay: 0.2s;\n      }\n      .line:nth-child(2) {\n        animation-delay: 0.8s;\n      }\n      .line:nth-child(3) {\n        animation-delay: 1.4s;\n      }\n      .line:nth-child(4) {\n        animation-delay: 2s;\n      }\n      .line:nth-child(5) {\n        animation-delay: 2.6s;\n      }\n      .line:nth-child(6) {\n        animation-delay: 3.2s;\n      }\n\n      @keyframes fadeIn {\n        to {\n          opacity: 1;\n        }\n      }\n\n      .prompt {\n        color: #7ee787;\n      }\n\n      .command {\n        color: #c9d1d9;\n      }\n\n      .error {\n        color: #f85149;\n      }\n\n      .info {\n        color: #58a6ff;\n      }\n\n      .warning {\n        color: #d29922;\n      }\n\n      .cursor {\n        display: inline-block;\n        width: 10px;\n        height: 18px;\n        background: #7ee787;\n        margin-left: 4px;\n        animation: blink 1s step-end infinite;\n        vertical-align: text-bottom;\n      }\n\n      @keyframes blink {\n        0%,\n        100% {\n          opacity: 1;\n        }\n        50% {\n          opacity: 0;\n        }\n      }\n\n      .error-code {\n        font-size: 6rem;\n        font-weight: 900;\n        text-align: center;\n        margin: 0.5rem 0 1rem;\n        font-family: monospace;\n      }\n\n      .action-container {\n        margin-top: 2rem;\n        text-align: center;\n        opacity: 0;\n        animation: fadeIn 0.5s ease forwards;\n        animation-delay: 3.8s;\n      }\n\n      .home-button {\n        --border-radius: 8px;\n        --background: var(--terminal-primary);\n        --background-hover: var(--terminal-primary-light);\n        font-family: monospace;\n      }\n\n      .error-code {\n        color: var(--terminal-primary);\n        text-shadow: 0 0 40px color-mix(in srgb, var(--terminal-primary) 30%, transparent);\n      }\n\n      .search-icon {\n        animation: searching 2s ease-in-out infinite;\n        display: inline-block;\n      }\n\n      @keyframes searching {\n        0%,\n        100% {\n          transform: translateX(0);\n        }\n        25% {\n          transform: translateX(5px);\n        }\n        75% {\n          transform: translateX(-5px);\n        }\n      }\n    `,\n  ],\n  template: `\n    <div\n      class=\"terminal-container\"\n      [ngStyle]=\"containerStyles\"\n    >\n      <div class=\"error-code\">404</div>\n\n      <div\n        class=\"terminal\"\n        [ngStyle]=\"{ background: props.terminalBackground || '#0d1117' }\"\n      >\n        <div class=\"terminal-header\">\n          <div class=\"terminal-dot dot-red\"></div>\n          <div class=\"terminal-dot dot-yellow\"></div>\n          <div class=\"terminal-dot dot-green\"></div>\n          <span class=\"terminal-title\">bash - 404</span>\n        </div>\n\n        <div class=\"terminal-body\">\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"command\">cd /{{ requestedPath() }}</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"error\"\n              >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span\n            >\n          </div>\n\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"command\">sudo find / -name \"{{ searchTerm() }}\"</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"info\"\n              ><span class=\"search-icon\">🔍</span> {{ searching() }}</span\n            >\n          </div>\n\n          <div class=\"line\">\n            <span class=\"warning\">find: {{ noResults() }}</span>\n          </div>\n\n          <div class=\"line\">\n            <span class=\"prompt\">user&#64;app</span>\n            <span class=\"command\">:~$ </span>\n            <span class=\"cursor\"></span>\n          </div>\n        </div>\n      </div>\n\n      <div class=\"action-container\">\n        <ion-button\n          class=\"home-button\"\n          [routerLink]=\"props.homeRoute || '/'\"\n          expand=\"block\"\n        >\n          {{ props.homeButtonText || 'cd /home' }}\n        </ion-button>\n      </div>\n    </div>\n  `,\n})\nexport class Terminal404Component implements OnInit {\n  @Input() props: Terminal404Metadata = {};\n\n  private i18n = inject(I18nService);\n\n  requestedPath = signal('page-not-found');\n\n  // i18n texts\n  directoryNotFound = computed(() =>\n    this.i18n.t('terminal404.directoryNotFound', 'No such file or directory')\n  );\n  searching = computed(() =>\n    this.i18n.t('terminal404.searching', 'Searching...')\n  );\n  noResults = computed(() =>\n    this.i18n.t('terminal404.noResults', 'No results found.')\n  );\n  searchTerm = computed(() =>\n    this.i18n.t('terminal404.searchTerm', 'page')\n  );\n\n  get containerStyles(): Record<string, string> {\n    const styles: Record<string, string> = {};\n\n    // Background gradient\n    const bg = this.props.backgroundColor;\n    if (bg) {\n      styles['background'] = `linear-gradient(135deg, ${bg.start} 0%, ${bg.middle} 50%, ${bg.end} 100%)`;\n    } else {\n      styles['background'] = 'linear-gradient(135deg, #ede9fe 0%, #ddd6fe 50%, #c4b5fd 100%)';\n    }\n\n    // Override primary color if provided\n    if (this.props.primaryColor) {\n      styles['--terminal-primary'] = this.props.primaryColor;\n      styles['--terminal-primary-light'] = this.lightenColor(this.props.primaryColor);\n    }\n\n    return styles;\n  }\n\n  ngOnInit(): void {\n    if (typeof window !== 'undefined') {\n      const path = window.location.pathname.slice(1) || 'unknown';\n      this.requestedPath.set(path);\n    }\n  }\n\n  /**\n   * Lighten a hex color for hover states\n   */\n  lightenColor(hex: string): string {\n    // Simple lighten by adding to RGB values\n    const num = parseInt(hex.replace('#', ''), 16);\n    const r = Math.min(255, (num >> 16) + 20);\n    const g = Math.min(255, ((num >> 8) & 0x00ff) + 20);\n    const b = Math.min(255, (num & 0x0000ff) + 20);\n    return `#${((r << 16) | (g << 8) | b).toString(16).padStart(6, '0')}`;\n  }\n}\n"]}
@@ -31147,7 +31147,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
31147
31147
  class Terminal404Component {
31148
31148
  constructor() {
31149
31149
  this.props = {};
31150
+ this.i18n = inject(I18nService);
31150
31151
  this.requestedPath = signal('page-not-found');
31152
+ // i18n texts
31153
+ this.directoryNotFound = computed(() => this.i18n.t('terminal404.directoryNotFound', 'No such file or directory'));
31154
+ this.searching = computed(() => this.i18n.t('terminal404.searching', 'Searching...'));
31155
+ this.noResults = computed(() => this.i18n.t('terminal404.noResults', 'No results found.'));
31156
+ this.searchTerm = computed(() => this.i18n.t('terminal404.searchTerm', 'page'));
31151
31157
  }
31152
31158
  get containerStyles() {
31153
31159
  const styles = {};
@@ -31211,24 +31217,24 @@ class Terminal404Component {
31211
31217
 
31212
31218
  <div class="line">
31213
31219
  <span class="error"
31214
- >bash: cd: /{{ requestedPath() }}: No existe el directorio</span
31220
+ >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span
31215
31221
  >
31216
31222
  </div>
31217
31223
 
31218
31224
  <div class="line">
31219
31225
  <span class="prompt">user&#64;app</span>
31220
31226
  <span class="command">:~$ </span>
31221
- <span class="command">sudo find / -name "pagina"</span>
31227
+ <span class="command">sudo find / -name "{{ searchTerm() }}"</span>
31222
31228
  </div>
31223
31229
 
31224
31230
  <div class="line">
31225
31231
  <span class="info"
31226
- ><span class="search-icon">🔍</span> Buscando...</span
31232
+ ><span class="search-icon">🔍</span> {{ searching() }}</span
31227
31233
  >
31228
31234
  </div>
31229
31235
 
31230
31236
  <div class="line">
31231
- <span class="warning">find: No se encontraron resultados.</span>
31237
+ <span class="warning">find: {{ noResults() }}</span>
31232
31238
  </div>
31233
31239
 
31234
31240
  <div class="line">
@@ -31280,24 +31286,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
31280
31286
 
31281
31287
  <div class="line">
31282
31288
  <span class="error"
31283
- >bash: cd: /{{ requestedPath() }}: No existe el directorio</span
31289
+ >bash: cd: /{{ requestedPath() }}: {{ directoryNotFound() }}</span
31284
31290
  >
31285
31291
  </div>
31286
31292
 
31287
31293
  <div class="line">
31288
31294
  <span class="prompt">user&#64;app</span>
31289
31295
  <span class="command">:~$ </span>
31290
- <span class="command">sudo find / -name "pagina"</span>
31296
+ <span class="command">sudo find / -name "{{ searchTerm() }}"</span>
31291
31297
  </div>
31292
31298
 
31293
31299
  <div class="line">
31294
31300
  <span class="info"
31295
- ><span class="search-icon">🔍</span> Buscando...</span
31301
+ ><span class="search-icon">🔍</span> {{ searching() }}</span
31296
31302
  >
31297
31303
  </div>
31298
31304
 
31299
31305
  <div class="line">
31300
- <span class="warning">find: No se encontraron resultados.</span>
31306
+ <span class="warning">find: {{ noResults() }}</span>
31301
31307
  </div>
31302
31308
 
31303
31309
  <div class="line">