@net7/components 4.5.7 → 4.5.9
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/esm2022/lib/components/histogram-range/histogram-range.mjs +5 -5
- package/esm2022/lib/components/parallel-text-viewer/parallel-text-viewer-dph.mock.mjs +43 -14
- package/esm2022/lib/components/parallel-text-viewer/parallel-text-viewer.mjs +3 -3
- package/fesm2022/net7-components.mjs +48 -19
- package/fesm2022/net7-components.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -41,12 +41,12 @@ export class HistogramRangeComponent {
|
|
|
41
41
|
}
|
|
42
42
|
else {
|
|
43
43
|
this.sliders = d3
|
|
44
|
-
.extent(items, (d) => d.label)
|
|
45
|
-
.map((d) => ({ x: LABELtoX(d) + LABELtoX.bandwidth() / 2, y: height }));
|
|
44
|
+
.extent(items, (d) => +d.label)
|
|
45
|
+
.map((d) => ({ x: LABELtoX(String(d)) + LABELtoX.bandwidth() / 2, y: height }));
|
|
46
46
|
}
|
|
47
47
|
const isInRange = (y) => {
|
|
48
|
-
const allItems = this.sliders.map((d) => XtoLABEL(d.x));
|
|
49
|
-
if (y >= d3.min(allItems) && y <= d3.max(allItems))
|
|
48
|
+
const allItems = this.sliders.map((d) => +XtoLABEL(d.x));
|
|
49
|
+
if (+y >= d3.min(allItems) && +y <= d3.max(allItems))
|
|
50
50
|
return true;
|
|
51
51
|
return false;
|
|
52
52
|
};
|
|
@@ -387,4 +387,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
387
387
|
}], emit: [{
|
|
388
388
|
type: Input
|
|
389
389
|
}] } });
|
|
390
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"histogram-range.js","sourceRoot":"","sources":["../../../../../../projects/dv-components-lib/src/lib/components/histogram-range/histogram-range.ts","../../../../../../projects/dv-components-lib/src/lib/components/histogram-range/histogram-range.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-use-before-define */\n//---------------------------\n// HISTOGRAM-RANGE.ts\n//---------------------------\n\nimport { AfterContentChecked, Component, Input } from '@angular/core';\n/**\n * Interface for HistogramRangeComponent's \"data\"\n */\nexport interface HistogramRangeData {\n  /**\n   * unique identifier for the histogram-range svg\n   */\n  containerId: string;\n  /**\n   * total width for the svg element\n   */\n  width: number;\n  /**\n   * total height for the svg element\n   */\n  height: number;\n  /**\n   * Internal margins of the svg\n   */\n  margin: {\n    left: number;\n    right: number;\n    top: number;\n    bottom: number;\n  };\n  /**\n   * Theme of the histogram\n   */\n  colours: {\n    top: string;\n    bottom: string;\n    accent: string;\n  };\n  /**\n   * Data for the histogram bars\n   */\n  items: {\n    /** default label of the item */\n    label: string;\n    /** y-axis value of the bar (height) */\n    value: number;\n    /** payload that the item should emit when selected */\n    payload: any;\n    /**\n     * 'upper' values of the range.\n     * only used when each bar represents a range.\n     */\n    range?: {\n      /** label loaded when selected by the right-most pointer */\n      label: string;\n      /** payload emitted when selected by the right-most pointer */\n      payload: any;\n    };\n  }[];\n  /**\n   * Axis settings\n   */\n  axis?: {\n    /** Y Axis settings */\n    yAxis?: {\n      /** Turn on and off the axis */\n      show?: boolean;\n      /** Manually set the axis values to show */\n      values?: number[];\n      /** How many ticks do you want to see */\n      tickAmount?: number;\n    };\n  };\n  /**\n   * expose the draw function outside of n7-frontend/components library\n   * this is needed to redraw bubble-chart-component on command\n   */\n  setDraw?: any;\n  /**\n   * setSliders\n   */\n  setSliders?: LabelCouple;\n  /**\n   * Public api\n   */\n  setApi?: any;\n}\n\ntype Sliders = { x: number; y: number }[];\ntype LabelCouple = [string, string];\n\n@Component({\n  selector: 'n7-histogram-range',\n  templateUrl: './histogram-range.html',\n})\nexport class HistogramRangeComponent implements AfterContentChecked {\n  @Input() data: HistogramRangeData;\n\n  @Input() emit: any;\n\n  private d3;\n\n  private sliders: Sliders = [];\n\n  /** d3 selection svg root */\n  private svg;\n\n  private _loaded = false;\n\n  private colourBars;\n\n  private getSelectedRange;\n\n  ngAfterContentChecked() {\n    /*\n         Waits for the dom to be loaded, then fires the draw function\n         that renders the chart.\n    */\n    if (this.data) {\n      if (this._loaded) return;\n      this._loaded = true;\n      setTimeout(() => {\n        import('d3').then((module) => {\n          this.d3 = module;\n          this.draw();\n          this.emitLoaded(true);\n          if (this.data && this.data.setDraw) {\n            this.data.setDraw(this.draw);\n          }\n          if (this.data.setApi) {\n            // expose the component api\n            this.data.setApi({\n              setSliders: this.setSliders,\n              setBars: this.setBars,\n            });\n          }\n          // eslint-disable-next-line dot-notation\n          // window['setSliders'] = this.setSliders;\n        });\n      });\n    }\n  }\n\n  draw = () => {\n    const { d3 } = this;\n    const {\n      width,\n      margin,\n      height,\n      items,\n      colours,\n      containerId,\n      axis,\n      setSliders,\n    } = this.data;\n\n    // data validation\n    const rangeMode = items.every((d) => d.range);\n    if (!rangeMode && items.some((d) => !d.range)) {\n      throw Error('All items must have the \"range\" property');\n    }\n\n    // Helpers - Start:\n    const LABELtoX = d3\n      .scaleBand()\n      .domain(items.map((d) => d.label))\n      .range([0, width])\n      .paddingInner(0.17)\n      .paddingOuter(1);\n\n    const XtoLABEL = (value) => {\n      const domain = LABELtoX.domain();\n      const paddingOuter = LABELtoX(domain[0]);\n      const eachBand = LABELtoX.step();\n      const index = Math.floor((value - paddingOuter) / eachBand);\n      return domain[Math.max(0, Math.min(index, domain.length - 1))];\n    };\n\n    // YEAR SELECTION CIRCLES\n    // let sliders;\n    if (setSliders && this.sliders) {\n      this.sliders = setSliders.map((d) => ({\n        x: LABELtoX(d) + LABELtoX.bandwidth() / 2,\n        y: height,\n      }));\n    } else {\n      this.sliders = d3\n        .extent(items, (d) => d.label)\n        .map((d) => ({ x: LABELtoX(d) + LABELtoX.bandwidth() / 2, y: height }));\n    }\n\n    const isInRange = (y) => {\n      const allItems = this.sliders.map((d) => XtoLABEL(d.x));\n      if (y >= d3.min(allItems) && y <= d3.max(allItems)) return true;\n      return false;\n    };\n\n    function colourBars(d) {\n      if (isInRange(d.label)) return 'url(#gradient)';\n      return '#e3e3e3';\n    }\n    this.colourBars = colourBars;\n\n    this.getSelectedRange = () => {\n      const rangeStart = items.find(\n        (it) => it.label === XtoLABEL(this.sliders[0].x)\n      );\n      const rangeEnd = items.find(\n        (it) => it.label === XtoLABEL(this.sliders[1].x)\n      );\n      return [\n        rangeStart.payload,\n        rangeMode ? rangeEnd.range.payload : rangeEnd.payload,\n      ];\n    };\n    // Helpers - End.\n\n    // clear HTML contents\n    document.getElementById(containerId).innerHTML = '';\n    const svg = d3\n      .select(`#${containerId}`)\n      .attr(\n        'viewBox',\n        `0 0 ${width + margin.left + margin.right} ${height + margin.top + margin.bottom}`\n      );\n    this.svg = svg;\n\n    const scaleHeight = d3\n      .scaleSymlog() // most similar scale to the original\n      .domain([0, d3.max(items, (d) => d.value)])\n      .range([height, 0]);\n\n    // GRADIENT\n    const defs = svg.append('defs'); // definitions\n    const gradient = defs\n      .append('linearGradient')\n      .attr('id', 'gradient')\n      .attr('gradientUnits', 'userSpaceOnUse')\n      .attr('x1', 0)\n      .attr('y1', height)\n      .attr('x2', 0)\n      .attr('y2', margin.top);\n    gradient\n      .append('stop')\n      .attr('class', 'start')\n      .attr('offset', '0%')\n      .attr('stop-color', colours.bottom) // bottom gradient\n      .attr('stop-opacity', 1);\n    gradient\n      .append('stop')\n      .attr('class', 'end')\n      .attr('offset', '100%')\n      .attr('stop-color', colours.top) // top gradient\n      .attr('stop-opacity', 1);\n\n    // DRAW INSIDE MARGINS\n    const g = svg\n      .append('g')\n      .attr('class', 'chart')\n      .attr('transform', `translate(${margin.left},${margin.top})`);\n\n    const barsLayer = g.append('g').attr('class', 'bars');\n    const controlsLayer = g.append('g').attr('class', 'controls');\n\n    // BAR CHART\n    barsLayer // bars\n      .selectAll('rect.bars')\n      .data(items)\n      .join('rect')\n      .attr('class', 'bars')\n      .attr('width', LABELtoX.bandwidth)\n      .attr('height', (d) => height - scaleHeight(d.value))\n      .attr('y', (d) => scaleHeight(d.value))\n      .attr('x', (d) => LABELtoX(d.label))\n      .attr('data-start', (d) => d.payload) // make the data easily accessible\n      .attr('data-end', (d) => (d.range ? d.range.payload : d.payload))\n      .attr('fill', 'url(#gradient)');\n\n    barsLayer // catch bar events\n      .on('mousemove', (event) => {\n        const year = XtoLABEL(this.getEventCoords(event).x);\n        d3.selectAll('rect.bars').attr('fill', (d) => {\n          if (year === d.label) return '#B0CCF8';\n          return colourBars(d);\n        });\n      })\n      .on('mouseout', () => {\n        d3.selectAll('rect.bars').attr('fill', (d) => colourBars(d));\n      })\n      .on('click', (event) => {\n        const label = XtoLABEL(this.getEventCoords(event).x);\n        const xAxisValue = LABELtoX(label) + LABELtoX.bandwidth() / 2;\n        const newValue = {\n          x: xAxisValue,\n          y: height,\n        };\n        this.sliders = [\n          // avoid joining the two objects!\n          { ...newValue },\n          { ...newValue },\n        ];\n        rangePicker\n          .data(this.sliders)\n          .select('circle')\n          .transition()\n          .ease(d3.easeQuadOut)\n          .duration(550)\n          .attr('cx', (d) => d.x);\n        controlsLayer\n          .select('path.blueline')\n          .transition()\n          .ease(d3.easeQuadOut)\n          .duration(550)\n          .attr('d', d3.line()(this.sliders.map((d) => [d.x, d.y])));\n        controlsLayer\n          .selectAll('text')\n          .transition()\n          .ease(d3.easeQuadOut)\n          .duration(550)\n          .attr('x', () => xAxisValue)\n          .text((d, i) => {\n            if (!rangeMode) return label;\n            const item = items.find((it) => it.label === label);\n            if (i > 0) return item.range.label;\n            return item.label;\n          });\n        g.selectAll('rect.bars').attr('fill', (d) => colourBars(d));\n        this.textCollision(this.sliders);\n        this.emit('rangeselected', this.getSelectedRange());\n      });\n\n    controlsLayer // gray line\n      .append('path')\n      .attr('class', 'grayline')\n      .attr(\n        'd',\n        d3.line()([\n          [0, height],\n          [width, height],\n        ])\n      )\n      .attr('stroke-width', 2)\n      .attr('opacity', 1)\n      .attr('stroke', '#C1C5C7');\n\n    controlsLayer // blue line\n      .append('path')\n      .attr('class', 'blueline')\n      .attr('d', d3.line()(this.sliders.map((d) => [d.x, d.y])))\n      .attr('stroke-width', 2)\n      .attr('stroke', colours.accent);\n\n    const rangePicker = controlsLayer\n      .selectAll('g.rangepicker')\n      .data(this.sliders.sort((a, b) => d3.ascending(a.x, b.x)))\n      .join('g')\n      .attr('class', 'rangepicker');\n\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this; // FIXME: Allow use of class \"this\" inside dragging update;\n    /**\n     * Animate the elements while the user is dragging one of the range selectors\n     */\n    function draggingUpdate(event, data) {\n      const label = XtoLABEL(event.x);\n      const xAxisValue = LABELtoX(label) + LABELtoX.bandwidth() / 2;\n      const yb = [];\n      g.selectAll('circle').each(function setBallPosition() {\n        yb.push({ x: +d3.select(this).attr('cx'), y: height });\n      });\n      self.sliders = yb.sort((a, b) => d3.ascending(a.x, b.x));\n      // move the circle\n      d3.select(this)\n        .select('circle')\n        .attr('cx', (data.x = xAxisValue));\n      // move the blue line\n      controlsLayer\n        .select('path.blueline')\n        .attr('d', d3.line()(self.sliders.map((d) => [d.x, d.y])));\n      // change the text position\n      d3.select(this)\n        .select('text')\n        .attr('x', () => xAxisValue);\n      // change the text values\n      controlsLayer.selectAll('text').text((d) => {\n        const l = XtoLABEL(d.x);\n        if (!rangeMode) return l;\n        const position = self.sliders.findIndex((slider) => slider.x === d.x);\n        const range = self.getSelectedRange();\n        if (position === 1) return range[1];\n        return range[0];\n      });\n      self.textCollision(self.sliders);\n      // colour the bars\n      g.selectAll('rect.bars').attr('fill', (d) => colourBars(d));\n    }\n\n    rangePicker // drag handler\n      .call(\n        d3\n          .drag()\n          .on('drag', draggingUpdate)\n          .on('end', (event, data) => {\n            // update one last time to prevent desyncing\n            draggingUpdate(event, data);\n            // emit the selected range\n            this.emit('rangeselected', this.getSelectedRange());\n          })\n      );\n\n    rangePicker\n      .append('circle')\n      .attr('cx', (d) => d.x)\n      .attr('cy', (d) => d.y)\n      .attr('r', 9)\n      .attr('fill', 'white')\n      .attr('stroke-width', 2)\n      .attr('stroke', colours.accent)\n      .attr('style', 'cursor: pointer');\n\n    rangePicker\n      .attr('text-anchor', 'middle')\n      .attr('font-family', 'Roboto, Arial, sans-serif')\n      .attr('font-size', '12px')\n      .append('text')\n      .attr('y', (d) => d.y + margin.bottom / 2)\n      .attr('x', (d) => d.x)\n      .attr('fill', colours.accent)\n      .text((d, i) => {\n        const l = XtoLABEL(d.x);\n        if (rangeMode && i === 1) {\n          return items.find((item) => item.label === l).range.label;\n        }\n        return l;\n      });\n\n    if (axis?.yAxis?.show) {\n      const yAxis = d3\n        .axisLeft(scaleHeight)\n        .ticks(axis.yAxis.tickAmount ?? 2)\n        .tickValues(axis.yAxis.values ? axis.yAxis.values : null);\n      const yAxisGroup = svg\n        .append('g')\n        .attr('transform', `translate(${margin.left}, ${margin.top})`)\n        .call(yAxis);\n\n      yAxisGroup.selectAll('path, line').style('stroke', colours.accent);\n      yAxisGroup.selectAll('text').style('fill', colours.accent);\n    }\n  };\n\n  /** Avoid collision of the slider labels */\n  textCollision = (sliders: Sliders) => {\n    // pre-requisites\n    const controlsLayer = this.d3.select('g.chart').select('g.controls');\n    const { items, margin } = this.data;\n    const rangeMode = items.every((d) => d.range);\n    // run collision detection\n    const isColliding = sliders[0].x === sliders[1].x;\n    if (rangeMode && isColliding) {\n      controlsLayer\n        .selectAll('text')\n        .attr('y', (d, i) =>\n          i > 0 ? d.y + margin.bottom / 2 + 12 : d.y + margin.bottom / 2\n        )\n        .text((d, i) => {\n          const range = this.getSelectedRange();\n          return range[i];\n        });\n    } else {\n      controlsLayer.selectAll('text').attr('y', (d) => d.y + margin.bottom / 2);\n    }\n  };\n\n  /** Get x-axis position from label */\n  labelToX() {\n    return this.d3\n      .scaleBand()\n      .domain(this.data.items.map((d) => d.label))\n      .range([0, this.data.width])\n      .paddingInner(0.17)\n      .paddingOuter(1);\n  }\n\n  /**\n   * Get an event with viewBox coordinates and\n   * parse them in absolute coordinates\n   */\n  getEventCoords(event): { x: number; y: number } {\n    const m = event.target.getScreenCTM();\n    const point = this.svg.node().createSVGPoint();\n    point.x = event.clientX;\n    point.y = event.clientY;\n    return point.matrixTransform(m.inverse());\n  }\n\n  /** Public api that allows to dinamically change the bars */\n  setBars = (newBars) => {\n    this.data.items = newBars;\n    this.draw();\n    this.d3.selectAll('rect.bars').attr('fill', (d) => this.colourBars(d));\n  };\n\n  /** Public api that allows to dinamically change the slider position */\n  setSliders = ([startLabel, endLabel]: LabelCouple, emit = true) => {\n    // setSliders([1450, 1575])\n    this.data.setSliders = [`${startLabel}`, `${endLabel}`];\n    this.draw();\n    this.d3.selectAll('rect.bars').attr('fill', (d) => this.colourBars(d));\n    const range = this.getSelectedRange();\n    if (emit) this.emit('rangeselected', range);\n    this.textCollision(this.sliders);\n    return range;\n  };\n\n  /** Emits an event when the component has loaded */\n  emitLoaded(payload) {\n    if (!this.emit) return;\n    this.emit('loaded', payload);\n  }\n}\n","<div *ngIf=\"data\" class=\"n7-histogram-range\">\n  <svg #histogramRange [id]=\"data.containerId\"></svg>\n</div>\n"]}
|
|
390
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"histogram-range.js","sourceRoot":"","sources":["../../../../../../projects/dv-components-lib/src/lib/components/histogram-range/histogram-range.ts","../../../../../../projects/dv-components-lib/src/lib/components/histogram-range/histogram-range.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-use-before-define */\n//---------------------------\n// HISTOGRAM-RANGE.ts\n//---------------------------\n\nimport { AfterContentChecked, Component, Input } from '@angular/core';\n/**\n * Interface for HistogramRangeComponent's \"data\"\n */\nexport interface HistogramRangeData {\n  /**\n   * unique identifier for the histogram-range svg\n   */\n  containerId: string;\n  /**\n   * total width for the svg element\n   */\n  width: number;\n  /**\n   * total height for the svg element\n   */\n  height: number;\n  /**\n   * Internal margins of the svg\n   */\n  margin: {\n    left: number;\n    right: number;\n    top: number;\n    bottom: number;\n  };\n  /**\n   * Theme of the histogram\n   */\n  colours: {\n    top: string;\n    bottom: string;\n    accent: string;\n  };\n  /**\n   * Data for the histogram bars\n   */\n  items: {\n    /** default label of the item */\n    label: string;\n    /** y-axis value of the bar (height) */\n    value: number;\n    /** payload that the item should emit when selected */\n    payload: any;\n    /**\n     * 'upper' values of the range.\n     * only used when each bar represents a range.\n     */\n    range?: {\n      /** label loaded when selected by the right-most pointer */\n      label: string;\n      /** payload emitted when selected by the right-most pointer */\n      payload: any;\n    };\n  }[];\n  /**\n   * Axis settings\n   */\n  axis?: {\n    /** Y Axis settings */\n    yAxis?: {\n      /** Turn on and off the axis */\n      show?: boolean;\n      /** Manually set the axis values to show */\n      values?: number[];\n      /** How many ticks do you want to see */\n      tickAmount?: number;\n    };\n  };\n  /**\n   * expose the draw function outside of n7-frontend/components library\n   * this is needed to redraw bubble-chart-component on command\n   */\n  setDraw?: any;\n  /**\n   * setSliders\n   */\n  setSliders?: LabelCouple;\n  /**\n   * Public api\n   */\n  setApi?: any;\n}\n\ntype Sliders = { x: number; y: number }[];\ntype LabelCouple = [string, string];\n\n@Component({\n  selector: 'n7-histogram-range',\n  templateUrl: './histogram-range.html',\n})\nexport class HistogramRangeComponent implements AfterContentChecked {\n  @Input() data: HistogramRangeData;\n\n  @Input() emit: any;\n\n  private d3;\n\n  private sliders: Sliders = [];\n\n  /** d3 selection svg root */\n  private svg;\n\n  private _loaded = false;\n\n  private colourBars;\n\n  private getSelectedRange;\n\n  ngAfterContentChecked() {\n    /*\n         Waits for the dom to be loaded, then fires the draw function\n         that renders the chart.\n    */\n    if (this.data) {\n      if (this._loaded) return;\n      this._loaded = true;\n      setTimeout(() => {\n        import('d3').then((module) => {\n          this.d3 = module;\n          this.draw();\n          this.emitLoaded(true);\n          if (this.data && this.data.setDraw) {\n            this.data.setDraw(this.draw);\n          }\n          if (this.data.setApi) {\n            // expose the component api\n            this.data.setApi({\n              setSliders: this.setSliders,\n              setBars: this.setBars,\n            });\n          }\n          // eslint-disable-next-line dot-notation\n          // window['setSliders'] = this.setSliders;\n        });\n      });\n    }\n  }\n\n  draw = () => {\n    const { d3 } = this;\n    const {\n      width,\n      margin,\n      height,\n      items,\n      colours,\n      containerId,\n      axis,\n      setSliders,\n    } = this.data;\n\n    // data validation\n    const rangeMode = items.every((d) => d.range);\n    if (!rangeMode && items.some((d) => !d.range)) {\n      throw Error('All items must have the \"range\" property');\n    }\n\n    // Helpers - Start:\n    const LABELtoX = d3\n      .scaleBand()\n      .domain(items.map((d) => d.label))\n      .range([0, width])\n      .paddingInner(0.17)\n      .paddingOuter(1);\n\n    const XtoLABEL = (value) => {\n      const domain = LABELtoX.domain();\n      const paddingOuter = LABELtoX(domain[0]);\n      const eachBand = LABELtoX.step();\n      const index = Math.floor((value - paddingOuter) / eachBand);\n      return domain[Math.max(0, Math.min(index, domain.length - 1))];\n    };\n\n    // YEAR SELECTION CIRCLES\n    // let sliders;\n    if (setSliders && this.sliders) {\n      this.sliders = setSliders.map((d) => ({\n        x: LABELtoX(d) + LABELtoX.bandwidth() / 2,\n        y: height,\n      }));\n    } else {\n      this.sliders = d3\n        .extent(items, (d) => +d.label)\n        .map((d) => ({ x: LABELtoX(String(d)) + LABELtoX.bandwidth() / 2, y: height }));\n    }\n\n    const isInRange = (y) => {\n      const allItems = this.sliders.map((d) => +XtoLABEL(d.x));\n      if (+y >= d3.min(allItems) && +y <= d3.max(allItems)) return true;\n      return false;\n    };\n\n    function colourBars(d) {\n      if (isInRange(d.label)) return 'url(#gradient)';\n      return '#e3e3e3';\n    }\n    this.colourBars = colourBars;\n\n    this.getSelectedRange = () => {\n      const rangeStart = items.find(\n        (it) => it.label === XtoLABEL(this.sliders[0].x)\n      );\n      const rangeEnd = items.find(\n        (it) => it.label === XtoLABEL(this.sliders[1].x)\n      );\n      return [\n        rangeStart.payload,\n        rangeMode ? rangeEnd.range.payload : rangeEnd.payload,\n      ];\n    };\n    // Helpers - End.\n\n    // clear HTML contents\n    document.getElementById(containerId).innerHTML = '';\n    const svg = d3\n      .select(`#${containerId}`)\n      .attr(\n        'viewBox',\n        `0 0 ${width + margin.left + margin.right} ${height + margin.top + margin.bottom}`\n      );\n    this.svg = svg;\n\n    const scaleHeight = d3\n      .scaleSymlog() // most similar scale to the original\n      .domain([0, d3.max(items, (d) => d.value)])\n      .range([height, 0]);\n\n    // GRADIENT\n    const defs = svg.append('defs'); // definitions\n    const gradient = defs\n      .append('linearGradient')\n      .attr('id', 'gradient')\n      .attr('gradientUnits', 'userSpaceOnUse')\n      .attr('x1', 0)\n      .attr('y1', height)\n      .attr('x2', 0)\n      .attr('y2', margin.top);\n    gradient\n      .append('stop')\n      .attr('class', 'start')\n      .attr('offset', '0%')\n      .attr('stop-color', colours.bottom) // bottom gradient\n      .attr('stop-opacity', 1);\n    gradient\n      .append('stop')\n      .attr('class', 'end')\n      .attr('offset', '100%')\n      .attr('stop-color', colours.top) // top gradient\n      .attr('stop-opacity', 1);\n\n    // DRAW INSIDE MARGINS\n    const g = svg\n      .append('g')\n      .attr('class', 'chart')\n      .attr('transform', `translate(${margin.left},${margin.top})`);\n\n    const barsLayer = g.append('g').attr('class', 'bars');\n    const controlsLayer = g.append('g').attr('class', 'controls');\n\n    // BAR CHART\n    barsLayer // bars\n      .selectAll('rect.bars')\n      .data(items)\n      .join('rect')\n      .attr('class', 'bars')\n      .attr('width', LABELtoX.bandwidth)\n      .attr('height', (d) => height - scaleHeight(d.value))\n      .attr('y', (d) => scaleHeight(d.value))\n      .attr('x', (d) => LABELtoX(d.label))\n      .attr('data-start', (d) => d.payload) // make the data easily accessible\n      .attr('data-end', (d) => (d.range ? d.range.payload : d.payload))\n      .attr('fill', 'url(#gradient)');\n\n    barsLayer // catch bar events\n      .on('mousemove', (event) => {\n        const year = XtoLABEL(this.getEventCoords(event).x);\n        d3.selectAll('rect.bars').attr('fill', (d) => {\n          if (year === d.label) return '#B0CCF8';\n          return colourBars(d);\n        });\n      })\n      .on('mouseout', () => {\n        d3.selectAll('rect.bars').attr('fill', (d) => colourBars(d));\n      })\n      .on('click', (event) => {\n        const label = XtoLABEL(this.getEventCoords(event).x);\n        const xAxisValue = LABELtoX(label) + LABELtoX.bandwidth() / 2;\n        const newValue = {\n          x: xAxisValue,\n          y: height,\n        };\n        this.sliders = [\n          // avoid joining the two objects!\n          { ...newValue },\n          { ...newValue },\n        ];\n        rangePicker\n          .data(this.sliders)\n          .select('circle')\n          .transition()\n          .ease(d3.easeQuadOut)\n          .duration(550)\n          .attr('cx', (d) => d.x);\n        controlsLayer\n          .select('path.blueline')\n          .transition()\n          .ease(d3.easeQuadOut)\n          .duration(550)\n          .attr('d', d3.line()(this.sliders.map((d) => [d.x, d.y])));\n        controlsLayer\n          .selectAll('text')\n          .transition()\n          .ease(d3.easeQuadOut)\n          .duration(550)\n          .attr('x', () => xAxisValue)\n          .text((d, i) => {\n            if (!rangeMode) return label;\n            const item = items.find((it) => it.label === label);\n            if (i > 0) return item.range.label;\n            return item.label;\n          });\n        g.selectAll('rect.bars').attr('fill', (d) => colourBars(d));\n        this.textCollision(this.sliders);\n        this.emit('rangeselected', this.getSelectedRange());\n      });\n\n    controlsLayer // gray line\n      .append('path')\n      .attr('class', 'grayline')\n      .attr(\n        'd',\n        d3.line()([\n          [0, height],\n          [width, height],\n        ])\n      )\n      .attr('stroke-width', 2)\n      .attr('opacity', 1)\n      .attr('stroke', '#C1C5C7');\n\n    controlsLayer // blue line\n      .append('path')\n      .attr('class', 'blueline')\n      .attr('d', d3.line()(this.sliders.map((d) => [d.x, d.y])))\n      .attr('stroke-width', 2)\n      .attr('stroke', colours.accent);\n\n    const rangePicker = controlsLayer\n      .selectAll('g.rangepicker')\n      .data(this.sliders.sort((a, b) => d3.ascending(a.x, b.x)))\n      .join('g')\n      .attr('class', 'rangepicker');\n\n    // eslint-disable-next-line @typescript-eslint/no-this-alias\n    const self = this; // FIXME: Allow use of class \"this\" inside dragging update;\n    /**\n     * Animate the elements while the user is dragging one of the range selectors\n     */\n    function draggingUpdate(event, data) {\n      const label = XtoLABEL(event.x);\n      const xAxisValue = LABELtoX(label) + LABELtoX.bandwidth() / 2;\n      const yb = [];\n      g.selectAll('circle').each(function setBallPosition() {\n        yb.push({ x: +d3.select(this).attr('cx'), y: height });\n      });\n      self.sliders = yb.sort((a, b) => d3.ascending(a.x, b.x));\n      // move the circle\n      d3.select(this)\n        .select('circle')\n        .attr('cx', (data.x = xAxisValue));\n      // move the blue line\n      controlsLayer\n        .select('path.blueline')\n        .attr('d', d3.line()(self.sliders.map((d) => [d.x, d.y])));\n      // change the text position\n      d3.select(this)\n        .select('text')\n        .attr('x', () => xAxisValue);\n      // change the text values\n      controlsLayer.selectAll('text').text((d) => {\n        const l = XtoLABEL(d.x);\n        if (!rangeMode) return l;\n        const position = self.sliders.findIndex((slider) => slider.x === d.x);\n        const range = self.getSelectedRange();\n        if (position === 1) return range[1];\n        return range[0];\n      });\n      self.textCollision(self.sliders);\n      // colour the bars\n      g.selectAll('rect.bars').attr('fill', (d) => colourBars(d));\n    }\n\n    rangePicker // drag handler\n      .call(\n        d3\n          .drag()\n          .on('drag', draggingUpdate)\n          .on('end', (event, data) => {\n            // update one last time to prevent desyncing\n            draggingUpdate(event, data);\n            // emit the selected range\n            this.emit('rangeselected', this.getSelectedRange());\n          })\n      );\n\n    rangePicker\n      .append('circle')\n      .attr('cx', (d) => d.x)\n      .attr('cy', (d) => d.y)\n      .attr('r', 9)\n      .attr('fill', 'white')\n      .attr('stroke-width', 2)\n      .attr('stroke', colours.accent)\n      .attr('style', 'cursor: pointer');\n\n    rangePicker\n      .attr('text-anchor', 'middle')\n      .attr('font-family', 'Roboto, Arial, sans-serif')\n      .attr('font-size', '12px')\n      .append('text')\n      .attr('y', (d) => d.y + margin.bottom / 2)\n      .attr('x', (d) => d.x)\n      .attr('fill', colours.accent)\n      .text((d, i) => {\n        const l = XtoLABEL(d.x);\n        if (rangeMode && i === 1) {\n          return items.find((item) => item.label === l).range.label;\n        }\n        return l;\n      });\n\n    if (axis?.yAxis?.show) {\n      const yAxis = d3\n        .axisLeft(scaleHeight)\n        .ticks(axis.yAxis.tickAmount ?? 2)\n        .tickValues(axis.yAxis.values ? axis.yAxis.values : null);\n      const yAxisGroup = svg\n        .append('g')\n        .attr('transform', `translate(${margin.left}, ${margin.top})`)\n        .call(yAxis);\n\n      yAxisGroup.selectAll('path, line').style('stroke', colours.accent);\n      yAxisGroup.selectAll('text').style('fill', colours.accent);\n    }\n  };\n\n  /** Avoid collision of the slider labels */\n  textCollision = (sliders: Sliders) => {\n    // pre-requisites\n    const controlsLayer = this.d3.select('g.chart').select('g.controls');\n    const { items, margin } = this.data;\n    const rangeMode = items.every((d) => d.range);\n    // run collision detection\n    const isColliding = sliders[0].x === sliders[1].x;\n    if (rangeMode && isColliding) {\n      controlsLayer\n        .selectAll('text')\n        .attr('y', (d, i) =>\n          i > 0 ? d.y + margin.bottom / 2 + 12 : d.y + margin.bottom / 2\n        )\n        .text((d, i) => {\n          const range = this.getSelectedRange();\n          return range[i];\n        });\n    } else {\n      controlsLayer.selectAll('text').attr('y', (d) => d.y + margin.bottom / 2);\n    }\n  };\n\n  /** Get x-axis position from label */\n  labelToX() {\n    return this.d3\n      .scaleBand()\n      .domain(this.data.items.map((d) => d.label))\n      .range([0, this.data.width])\n      .paddingInner(0.17)\n      .paddingOuter(1);\n  }\n\n  /**\n   * Get an event with viewBox coordinates and\n   * parse them in absolute coordinates\n   */\n  getEventCoords(event): { x: number; y: number } {\n    const m = event.target.getScreenCTM();\n    const point = this.svg.node().createSVGPoint();\n    point.x = event.clientX;\n    point.y = event.clientY;\n    return point.matrixTransform(m.inverse());\n  }\n\n  /** Public api that allows to dinamically change the bars */\n  setBars = (newBars) => {\n    this.data.items = newBars;\n    this.draw();\n    this.d3.selectAll('rect.bars').attr('fill', (d) => this.colourBars(d));\n  };\n\n  /** Public api that allows to dinamically change the slider position */\n  setSliders = ([startLabel, endLabel]: LabelCouple, emit = true) => {\n    // setSliders([1450, 1575])\n    this.data.setSliders = [`${startLabel}`, `${endLabel}`];\n    this.draw();\n    this.d3.selectAll('rect.bars').attr('fill', (d) => this.colourBars(d));\n    const range = this.getSelectedRange();\n    if (emit) this.emit('rangeselected', range);\n    this.textCollision(this.sliders);\n    return range;\n  };\n\n  /** Emits an event when the component has loaded */\n  emitLoaded(payload) {\n    if (!this.emit) return;\n    this.emit('loaded', payload);\n  }\n}\n","<div *ngIf=\"data\" class=\"n7-histogram-range\">\n  <svg #histogramRange [id]=\"data.containerId\"></svg>\n</div>\n"]}
|
|
@@ -3,17 +3,18 @@ export const PARALLEL_TEXT_VIEWER_DPH_MOCK = {
|
|
|
3
3
|
// endpoint: 'https://backend.dph.netseven.work/api/public/tei',
|
|
4
4
|
// endpoint: 'http://localhost:8080/exist/apps/tei-publisher',
|
|
5
5
|
endpoint: 'https://teipublisher9.muruca.cloud/exist/apps/tei-publisher',
|
|
6
|
+
// endpoint: 'https://backend.dse.ispf.netseven.work/api/tei',
|
|
6
7
|
docs: [
|
|
7
8
|
{
|
|
8
|
-
xml: 'playground/
|
|
9
|
+
xml: 'playground/SN_44_Ultima.xml',
|
|
9
10
|
// xml: 'playground/pericopi.xml',
|
|
10
11
|
id: 'document1',
|
|
11
12
|
},
|
|
12
|
-
{
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
13
|
+
/* {
|
|
14
|
+
xml: 'playground/SN_44_Ultima.xml',
|
|
15
|
+
// xml: 'playground/postille.xml',
|
|
16
|
+
id: 'document2',
|
|
17
|
+
} */
|
|
17
18
|
],
|
|
18
19
|
mainDoc: {
|
|
19
20
|
odd: 'ISPF_ODD',
|
|
@@ -29,15 +30,43 @@ export const PARALLEL_TEXT_VIEWER_DPH_MOCK = {
|
|
|
29
30
|
emit: 'transcription',
|
|
30
31
|
},
|
|
31
32
|
panels: [
|
|
33
|
+
/* {
|
|
34
|
+
id: '44',
|
|
35
|
+
doc_id: 'document2',
|
|
36
|
+
enabled: true,
|
|
37
|
+
title: 'SN-44',
|
|
38
|
+
type: 'text',
|
|
39
|
+
odd: 'ISPF_ODD',
|
|
40
|
+
// odd: '',
|
|
41
|
+
view: 'page',
|
|
42
|
+
} , */
|
|
32
43
|
{
|
|
33
|
-
id: '
|
|
34
|
-
doc_id: 'document2',
|
|
44
|
+
id: 'facsimile',
|
|
35
45
|
enabled: true,
|
|
36
|
-
title: '
|
|
37
|
-
type: '
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
46
|
+
title: 'Facsimile',
|
|
47
|
+
type: 'facsimile',
|
|
48
|
+
facsimile: {
|
|
49
|
+
enabled: true,
|
|
50
|
+
// uri: 'https://iiif.muruca.cloud/iiif/2/%2Fispf%2Fsn_45%2F',
|
|
51
|
+
// uri: 'https://backend.dse.ispf.netseven.work/iiif/9/2/',
|
|
52
|
+
uri: 'https://iiif.dt-h2iosc.netseven.work/iiif/2/nest%2Fiiif%2F%2F2%2F2D_IMAGES%2F',
|
|
53
|
+
// uri : 'https://iiif.dt-h2iosc.netseven.work/iiif/2/nest%2Fiiif%2F%2F2%2F2D_IMAGES%2Fms-xiii-d-79-000-rvcsjrrzqv0i.jpg/info.json'
|
|
54
|
+
// uri : 'https://iiif.dt-h2iosc.netseven.work/iiif/2/nest%2Fiiif%2F%2F2%2F2D_IMAGES%2Fms-xiii-d-79-000-rvcSJrRZQv0i.JPG/info.json'
|
|
55
|
+
scans: [
|
|
56
|
+
/* 'Ms_XIII_D_79_000_pyramidal.ptif',
|
|
57
|
+
'Ms_XIII_D_79_001_pyramidal.ptif',
|
|
58
|
+
'Ms_XIII_D_79_002_pyramidal.ptif', */
|
|
59
|
+
],
|
|
60
|
+
options: {
|
|
61
|
+
height: '700px',
|
|
62
|
+
defaultZoomLevel: 0,
|
|
63
|
+
showNavigator: true,
|
|
64
|
+
showNavigationControl: true,
|
|
65
|
+
showHomeControl: true,
|
|
66
|
+
showRotationControl: false,
|
|
67
|
+
showFullPageControl: true,
|
|
68
|
+
},
|
|
69
|
+
},
|
|
41
70
|
}
|
|
42
71
|
],
|
|
43
72
|
/* download: {
|
|
@@ -66,4 +95,4 @@ export const PARALLEL_TEXT_VIEWER_DPH_MOCK = {
|
|
|
66
95
|
}
|
|
67
96
|
},
|
|
68
97
|
};
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFyYWxsZWwtdGV4dC12aWV3ZXItZHBoLm1vY2suanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kdi1jb21wb25lbnRzLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvcGFyYWxsZWwtdGV4dC12aWV3ZXIvcGFyYWxsZWwtdGV4dC12aWV3ZXItZHBoLm1vY2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQTJCO0lBQ25FLHlEQUF5RDtJQUN6RCxnRUFBZ0U7SUFDaEUsOERBQThEO0lBQzdELFFBQVEsRUFBRSw2REFBNkQ7SUFDeEUsZ0VBQWdFO0lBR2hFLElBQUksRUFBRTtRQUNKO1lBQ0UsR0FBRyxFQUFFLDZCQUE2QjtZQUNsQyxrQ0FBa0M7WUFDbEMsRUFBRSxFQUFFLFdBQVc7U0FDaEI7UUFDTDs7OzttQkFJVztLQUNSO0lBRUQsT0FBTyxFQUFFO1FBQ1AsR0FBRyxFQUFFLFVBQVU7UUFDZixXQUFXO1FBQ1gsTUFBTSxFQUFFLFdBQVc7UUFDbkIsSUFBSSxFQUFFLE1BQU07S0FDYjtJQUVELFFBQVE7SUFDUixJQUFJLEVBQUU7UUFDSixFQUFFLEVBQUUsTUFBTTtRQUNWLE1BQU0sRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLHlCQUF5QjtRQUN0QyxTQUFTLEVBQUUsZUFBZTtRQUMxQixJQUFJLEVBQUUsZUFBZTtLQUN0QjtJQUVELE1BQU0sRUFBRTtRQUNWOzs7Ozs7Ozs7bUJBU1c7UUFFTDtZQUNFLEVBQUUsRUFBRSxXQUFXO1lBQ2YsT0FBTyxFQUFFLElBQUk7WUFDYixLQUFLLEVBQUUsV0FBVztZQUNsQixJQUFJLEVBQUUsV0FBVztZQUNqQixTQUFTLEVBQUU7Z0JBQ1QsT0FBTyxFQUFFLElBQUk7Z0JBQ2YsOERBQThEO2dCQUM5RCwyREFBMkQ7Z0JBQzNELEdBQUcsRUFBRywrRUFBK0U7Z0JBQ3JGLG1JQUFtSTtnQkFDbkksbUlBQW1JO2dCQUNuSSxLQUFLLEVBQUU7Z0JBQ2Y7OytEQUUrQztpQkFDdEM7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLE1BQU0sRUFBRSxPQUFPO29CQUNmLGdCQUFnQixFQUFFLENBQUM7b0JBQ25CLGFBQWEsRUFBRSxJQUFJO29CQUNuQixxQkFBcUIsRUFBRSxJQUFJO29CQUMzQixlQUFlLEVBQUUsSUFBSTtvQkFDckIsbUJBQW1CLEVBQUUsS0FBSztvQkFDMUIsbUJBQW1CLEVBQUUsSUFBSTtpQkFDMUI7YUFDRjtTQUNGO0tBQ0Y7SUFHSDs7OztXQUlPO0lBR0wsU0FBUztJQUNULE1BQU0sRUFBRTtRQUNOLElBQUksRUFBRSxvQkFBb0I7UUFDMUIsU0FBUyxFQUFFLFlBQVk7UUFDdkIsR0FBRyxFQUFFLG1CQUFtQjtRQUN4QixPQUFPLEVBQUUsWUFBWTtLQUN0QjtJQUVELFVBQVUsRUFBRTtRQUNWLE1BQU0sRUFBRTtZQUNOLFNBQVMsRUFDVDtZQUNBLHdEQUF3RDthQUN2RDtTQUNGO1FBQ0QsR0FBRyxFQUFFO1lBQ0gsT0FBTyxFQUFFLElBQUk7U0FDZDtRQUNELElBQUksRUFBRTtZQUNKLGdCQUFnQixFQUFFLElBQUk7U0FDdkI7S0FDRjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQYXJhbGxlbFRleHRWaWV3ZXJEYXRhIH0gZnJvbSAnLi9wYXJhbGxlbC10ZXh0LXZpZXdlcic7XG5cbmV4cG9ydCBjb25zdCBQQVJBTExFTF9URVhUX1ZJRVdFUl9EUEhfTU9DSzogUGFyYWxsZWxUZXh0Vmlld2VyRGF0YSA9IHtcbiAgLy8gZW5kcG9pbnQ6ICdodHRwczovL2JhY2tlbmQuZHBoLm5ldHNldmVuLndvcmsvYXBpL3RlaScsXG4gIC8vIGVuZHBvaW50OiAnaHR0cHM6Ly9iYWNrZW5kLmRwaC5uZXRzZXZlbi53b3JrL2FwaS9wdWJsaWMvdGVpJyxcbiAgLy8gZW5kcG9pbnQ6ICdodHRwOi8vbG9jYWxob3N0OjgwODAvZXhpc3QvYXBwcy90ZWktcHVibGlzaGVyJyxcbiAgIGVuZHBvaW50OiAnaHR0cHM6Ly90ZWlwdWJsaXNoZXI5Lm11cnVjYS5jbG91ZC9leGlzdC9hcHBzL3RlaS1wdWJsaXNoZXInLFxuICAvLyAgIGVuZHBvaW50OiAnaHR0cHM6Ly9iYWNrZW5kLmRzZS5pc3BmLm5ldHNldmVuLndvcmsvYXBpL3RlaScsXG5cblxuICBkb2NzOiBbXG4gICAge1xuICAgICAgeG1sOiAncGxheWdyb3VuZC9TTl80NF9VbHRpbWEueG1sJyxcbiAgICAgIC8vIHhtbDogJ3BsYXlncm91bmQvcGVyaWNvcGkueG1sJyxcbiAgICAgIGlkOiAnZG9jdW1lbnQxJyxcbiAgICB9LFxuLyogICAgICAgIHtcbiAgICAgIHhtbDogJ3BsYXlncm91bmQvU05fNDRfVWx0aW1hLnhtbCcsXG4gICAgICAvLyB4bWw6ICdwbGF5Z3JvdW5kL3Bvc3RpbGxlLnhtbCcsXG4gICAgICBpZDogJ2RvY3VtZW50MicsXG4gICAgfSAgICAqL1xuICBdLFxuXG4gIG1haW5Eb2M6IHtcbiAgICBvZGQ6ICdJU1BGX09ERCcsXG4gICAgLy8gb2RkOiAnJyxcbiAgICBkb2NfaWQ6ICdkb2N1bWVudDEnLFxuICAgIHZpZXc6ICdwYWdlJyxcbiAgfSxcblxuICAvLyBHcmlkIFxuICBncmlkOiB7XG4gICAgaWQ6ICdncmlkJyxcbiAgICBwYW5lbHM6IFswXSwgLy8gSW5pdGlhbCBwYW5lbHMgdG8gc2hvd1xuICAgIHN1YnNjcmliZTogJ3RyYW5zY3JpcHRpb24nLFxuICAgIGVtaXQ6ICd0cmFuc2NyaXB0aW9uJyxcbiAgfSxcblxuICBwYW5lbHM6IFtcbi8qICAgICB7XG4gICAgICBpZDogJzQ0JyxcbiAgICAgIGRvY19pZDogJ2RvY3VtZW50MicsICBcbiAgICAgIGVuYWJsZWQ6IHRydWUsXG4gICAgICB0aXRsZTogJ1NOLTQ0JyxcbiAgICAgIHR5cGU6ICd0ZXh0JyxcbiAgICAgIG9kZDogJ0lTUEZfT0REJyxcbiAgICAgIC8vIG9kZDogJycsXG4gICAgICB2aWV3OiAncGFnZScsXG4gICAgfSAgLCAqL1xuXG4gICAgICB7XG4gICAgICAgIGlkOiAnZmFjc2ltaWxlJyxcbiAgICAgICAgZW5hYmxlZDogdHJ1ZSxcbiAgICAgICAgdGl0bGU6ICdGYWNzaW1pbGUnLFxuICAgICAgICB0eXBlOiAnZmFjc2ltaWxlJyxcbiAgICAgICAgZmFjc2ltaWxlOiB7XG4gICAgICAgICAgZW5hYmxlZDogdHJ1ZSxcbiAgICAgICAgLy8gdXJpOiAnaHR0cHM6Ly9paWlmLm11cnVjYS5jbG91ZC9paWlmLzIvJTJGaXNwZiUyRnNuXzQ1JTJGJyxcbiAgICAgICAgLy8gdXJpOiAnaHR0cHM6Ly9iYWNrZW5kLmRzZS5pc3BmLm5ldHNldmVuLndvcmsvaWlpZi85LzIvJyxcbiAgICAgICAgdXJpIDogJ2h0dHBzOi8vaWlpZi5kdC1oMmlvc2MubmV0c2V2ZW4ud29yay9paWlmLzIvbmVzdCUyRmlpaWYlMkYlMkYyJTJGMkRfSU1BR0VTJTJGJyxcbiAgICAgICAgLy8gdXJpIDogJ2h0dHBzOi8vaWlpZi5kdC1oMmlvc2MubmV0c2V2ZW4ud29yay9paWlmLzIvbmVzdCUyRmlpaWYlMkYlMkYyJTJGMkRfSU1BR0VTJTJGbXMteGlpaS1kLTc5LTAwMC1ydmNzanJyenF2MGkuanBnL2luZm8uanNvbidcbiAgICAgICAgLy8gdXJpIDogJ2h0dHBzOi8vaWlpZi5kdC1oMmlvc2MubmV0c2V2ZW4ud29yay9paWlmLzIvbmVzdCUyRmlpaWYlMkYlMkYyJTJGMkRfSU1BR0VTJTJGbXMteGlpaS1kLTc5LTAwMC1ydmNTSnJSWlF2MGkuSlBHL2luZm8uanNvbidcbiAgICAgICAgc2NhbnM6IFtcbi8qICAgICAgICAgICAnTXNfWElJSV9EXzc5XzAwMF9weXJhbWlkYWwucHRpZicsXG4gICAgICAgICAgJ01zX1hJSUlfRF83OV8wMDFfcHlyYW1pZGFsLnB0aWYnLFxuICAgICAgICAgICdNc19YSUlJX0RfNzlfMDAyX3B5cmFtaWRhbC5wdGlmJywgKi9cbiAgICAgICAgXSxcbiAgICAgICAgb3B0aW9uczoge1xuICAgICAgICAgIGhlaWdodDogJzcwMHB4JyxcbiAgICAgICAgICBkZWZhdWx0Wm9vbUxldmVsOiAwLFxuICAgICAgICAgIHNob3dOYXZpZ2F0b3I6IHRydWUsXG4gICAgICAgICAgc2hvd05hdmlnYXRpb25Db250cm9sOiB0cnVlLFxuICAgICAgICAgIHNob3dIb21lQ29udHJvbDogdHJ1ZSxcbiAgICAgICAgICBzaG93Um90YXRpb25Db250cm9sOiBmYWxzZSxcbiAgICAgICAgICBzaG93RnVsbFBhZ2VDb250cm9sOiB0cnVlLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9ICBcbiAgXSxcbiBcblxuLyogICBkb3dubG9hZDoge1xuICAgIGxhYmVsOiAnRG93bmxvYWQnLFxuICAgIGZpbGU6ICdodHRwOi8vc3RhZ2luZy50ZWlwdWJsaXNoZXIubmV0c2V2ZW4uaXQvZXhpc3QvYXBwcy90ZWktcHVibGlzaGVyL2FwaS9kb2N1bWVudC9tYW1icmlubyUyRnNtMV9zb3VyY2VfZGVmXzE2NDczMzQzOTMueG1sJyxcbiAgICBmb3JtYXQ6ICdYTUwnLFxuICB9LCAqL1xuICBcblxuICAvLyBMYWJlbHNcbiAgbGFiZWxzOiB7XG4gICAgdmlldzogJ1BsYWluIFJlYWRpbmcgVmlldycsXG4gICAgYWRkQ29sdW1uOiAnQWRkIENvbHVtbicsXG4gICAgdG9jOiAnVGFibGUgb2YgQ29udGVudHMnLFxuICAgIGxvYWRpbmc6ICdMb2FkaW5nLi4uJyxcbiAgfSxcblxuICBsaWJPcHRpb25zOiB7XG4gICAgcGJQYWdlOiB7XG4gICAgICB1cmxJZ25vcmU6IFxuICAgICAgW1xuICAgICAgLy8gIFwiaGlnaGxpZ2h0MSxvZGQsdmlldyxwYXRoLHNlbGVjdG9ycyxoaWdobGlnaHQsdmlldzJcIlxuICAgICAgXSxcbiAgICB9LFxuICAgIHRvYzoge1xuICAgICAgZGlzYWJsZTogdHJ1ZSxcbiAgICB9LFxuICAgIGdyaWQ6IHtcbiAgICAgIGRpc2FibGVBZGRDb2x1bW46IHRydWUsXG4gICAgfVxuICB9LFxufTtcbiAgIl19
|
|
@@ -36,14 +36,14 @@ export class ParallelTextViewerComponent {
|
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
38
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ParallelTextViewerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
39
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ParallelTextViewerComponent, selector: "n7-parallel-text-viewer", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div\n class=\"n7-parallel-text-viewer {{data?.classes || ''}}\"\n *ngIf=\"data && data.endpoint\"\n>\n <pb-page \n [attr.endpoint]=\"data.endpoint\" \n api-version=\"1.0.0\" \n url-path=\"query\"\n [attr.url-ignore]=\"data.libOptions?.pbPage?.urlIgnore?.join(',') || 'odd,view,path,selectors,highlight,view2'\"\n >\n <!-- PB DOCUMENT-->\n <pb-document\n *ngFor=\"let doc of data.docs; index as $i\"\n [attr.path]=\"doc.xml\"\n [attr.odd]=\"doc.odd\"\n [attr.id]=\"doc.id\"\n [attr.view]=\"doc.view\"\n [attr.disable-history]=\"doc.disableHistory === true ? '' : null\"\n [attr.root-path]=\"doc.rootPath\"\n >\n </pb-document>\n\n <app-drawer-layout force-narrow=\"force-narrow\" narrow=\"\">\n <app-header-layout>\n <app-header\n fixed=\"fixed\"\n data-template=\"browse:fix-links\"\n style=\"\n transition-duration: 0ms;\n transform: translate3d(0px, 0px, 0px);\n left: 0px;\n right: 0.399994px;\n \"\n >\n <app-toolbar\n class=\"toolbar\"\n sticky=\"sticky\"\n style=\"transform: translate3d(0px, 0px, 0px)\"\n >\n <!-- TOC button -->\n <paper-icon-button\n id=\"tocToggle\"\n class=\"toc-toggle\"\n icon=\"icons:view-list\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n\n <!-- Plain reading view-->\n <pb-toggle-feature\n *ngIf=\"data.docs?.length === 1\"\n name=\"highlight1\"\n selector=\"tei-app,pb-popover,pb-highlight,.quote,pb-alternate\"\n default=\"off\"\n action=\"disable\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n >\n <ng-container *ngIf=\"data.labels && data.labels.view\">\n {{data.labels.view}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.view\">\n <pb-i18n key=\"document.plain\">Plain Reading View</pb-i18n>\n </ng-container>\n </pb-toggle-feature>\n\n <!-- Zoom Controls -->\n <pb-zoom\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n direction=\"in\"\n icon=\"icons:zoom-in\"\n ></pb-zoom>\n <pb-zoom\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n direction=\"out\"\n icon=\"icons:zoom-out\"\n ></pb-zoom>\n\n <!-- Navigation Controls -->\n <pb-navigation\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n keyboard=\"left\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n direction=\"backward\"\n unit=\"page\"\n >\n <paper-icon-button\n icon=\"icons:chevron-left\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n </pb-navigation>\n <pb-navigation\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n keyboard=\"right\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n direction=\"forward\"\n unit=\"page\"\n >\n <paper-icon-button\n icon=\"icons:chevron-right\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n </pb-navigation>\n\n <!-- Pulsante aggiungi pannello -->\n <pb-grid-action \n *ngIf=\"!data.libOptions?.grid?.disableAddColumn\"\n action=\"add\" \n class=\"grid-add\" \n [attr.grid]=\"'#' + (data.grid?.id || 'grid')\"\n >\n <paper-button \n role=\"button\" \n tabindex=\"0\" \n animated=\"\" \n elevation=\"0\" \n aria-disabled=\"false\"\n >\n <iron-icon icon=\"icons:add\"></iron-icon> \n {{ data.labels?.addColumn || 'Aggiungi colonna' }}\n </paper-button>\n </pb-grid-action>\n\n <!-- Pulsante download -->\n <ng-container *ngIf=\"data.download\">\n <div class=\"n7-parallel-text-viewer__toolbar-container-flex\">\n <pb-download\n [type]=\"data.download.format || ''\"\n [src]=\"data.docs[0].id\"\n [url]=\"data.download.file || ''\"\n dialog=\"downloadDialog\"\n (click)=\"openDownload($event, data.download.file)\"\n [title]=\"data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : ''\"\n >\n <paper-button raised=\"\">\n {{data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : 'Download'}}\n </paper-button>\n </pb-download>\n </div>\n </ng-container>\n\n <pb-progress\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n indeterminate=\"\"\n bottom-item=\"bottom-item\"\n style=\"visibility: hidden\"\n ></pb-progress>\n </app-toolbar>\n </app-header>\n\n <!-- Main Content with Parallel Grid -->\n <main class=\"content-body\">\n <pb-grid \n [id]=\"data.grid?.id || 'grid'\"\n [attr.panels]=\"data.grid?.panels ? '[' + data.grid.panels.join(',') + ']' : '[0]'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n >\n <!-- Main pb-->\n <pb-view \n id=\"transcription-view\"\n [attr.src]=\"data.mainDoc.doc_id || data.docs[0].id\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n [attr.odd]=\"data.mainDoc.odd\"\n [attr.view]=\"data.mainDoc.view\"\n (click)=\"onClick($event)\"\n [attr.url]=\"data.mainDoc.rootPath\"\n append-footnotes=\"append-footnotes\"\n >\n </pb-view>\n\n <!-- Template -->\n <template>\n <pb-panel [attr.emit]=\"data.grid?.emit || 'transcription'\">\n <!-- Rimozione colonna -->\n <pb-grid-action \n [attr.grid]=\"'#' + (data.grid?.id || 'grid')\" \n slot=\"toolbar\" \n action=\"remove\"\n >\n <paper-icon-button icon=\"icons:close\"></paper-icon-button>\n </pb-grid-action>\n\n <!-- Pannelli secondari -->\n \n <ng-container *ngFor=\"let panel of data.panels\">\n <ng-container *ngIf=\"panel.enabled\">\n <ng-container [ngSwitch]=\"panel.type\">\n\n <ng-container *ngSwitchCase=\"'text'\">\n <template [attr.title]=\"panel.title\">\n <pb-view \n [attr.id]=\"panel.id + '-view'\"\n [attr.src]=\"panel.doc_id || data.docs[0].id\"\n [attr.odd]=\"panel.odd\"\n [attr.view]=\"panel.view || 'single'\"\n [attr.xpath]=\"panel.xpath\"\n [attr.map]=\"panel.mapFunction\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n (click)=\"onClick($event)\"\n [attr.url]=\"data.mainDoc.rootPath\"\n disable-history=\"\"\n >\n <pb-param \n *ngFor=\"let param of panel.params || []\"\n [attr.name]=\"param.name\"\n [attr.value]=\"param.value\"\n ></pb-param>\n </pb-view>\n </template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'facsimile'\">\n <template [attr.title]=\"panel.title\">\n <pb-facsimile\n *ngIf=\"panel.facsimile?.enabled\"\n [attr.base-uri]=\"panel.facsimile.uri\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n class=\"pb-facsimile\"\n [style.height]=\"panel.facsimile.options?.height || '600px'\"\n [attr.default-zoom-level]=\"panel.facsimile.options?.defaultZoomLevel || 0\"\n [attr.show-navigator]=\"panel.facsimile.options?.showNavigator ? 'show-navigator' : null\"\n [attr.show-navigation-control]=\"panel.facsimile.options?.showNavigationControl ? 'show-navigation-control' : null\"\n [attr.show-home-control]=\"panel.facsimile.options?.showHomeControl ? 'show-home-control' : null\"\n [attr.show-rotation-control]=\"panel.facsimile.options?.showRotationControl ? 'show-rotation-control' : null\"\n [attr.show-full-page-control]=\"panel.facsimile.options?.showFullPageControl ? 'show-full-page-control' : null\"\n [scans]=\"panel.facsimile.scans\"\n >\n </pb-facsimile>\n </template>\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n </pb-panel>\n </template>\n </pb-grid>\n </main>\n\n <!-- TOC Drawer -->\n <pb-drawer\n toggle=\"tocToggle\"\n class=\"tocDrawer\"\n emit=\"toc\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n >\n <div class=\"drawer-content\">\n <h3>\n <ng-container *ngIf=\"data.labels && data.labels.toc\">\n {{data.labels.toc}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.toc\">\n <pb-i18n key=\"document.contents\">Contents</pb-i18n>\n </ng-container>\n </h3>\n <pb-load\n *ngIf=\"data.docs && data.docs.length > 0 && !data.libOptions?.toc?.disable\"\n id=\"toc\"\n [attr.url]=\"data.mainDoc.rootPath ? (data.mainDoc.rootPath + '/' + data.mainDoc.doc_id + '/contents?target=transcription&icons=true') : 'api/document/{doc}/contents?target=transcription&icons=true'\"\n [attr.src]=\"data.mainDoc.doc_id\"\n subscribe=\"toc\"\n emit=\"toc\"\n expand=\"expand\"\n auto=\"auto\"\n >\n <ng-container *ngIf=\"data.labels && data.labels.loading\">\n {{data.labels.loading}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.loading\">\n <pb-i18n key=\"dialogs.loading\">Loading</pb-i18n>\n </ng-container>\n </pb-load>\n </div>\n </pb-drawer>\n </app-header-layout>\n </app-drawer-layout>\n </pb-page>\n</div>\n\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }] }); }
|
|
39
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ParallelTextViewerComponent, selector: "n7-parallel-text-viewer", inputs: { data: "data", emit: "emit" }, ngImport: i0, template: "<div\n class=\"n7-parallel-text-viewer {{data?.classes || ''}}\"\n *ngIf=\"data && data.endpoint\"\n>\n <pb-page \n [attr.endpoint]=\"data.endpoint\" \n api-version=\"1.0.0\" \n url-path=\"query\"\n [attr.url-ignore]=\"data.libOptions?.pbPage?.urlIgnore?.join(',') || 'odd,view,path,selectors,highlight,view2'\"\n >\n <!-- PB DOCUMENT-->\n <pb-document\n *ngFor=\"let doc of data.docs; index as $i\"\n [attr.path]=\"doc.xml\"\n [attr.odd]=\"doc.odd\"\n [attr.id]=\"doc.id\"\n [attr.view]=\"doc.view\"\n [attr.disable-history]=\"doc.disableHistory === true ? '' : null\"\n [attr.root-path]=\"doc.rootPath\"\n >\n </pb-document>\n\n <app-drawer-layout force-narrow=\"force-narrow\" narrow=\"\">\n <app-header-layout>\n <app-header\n fixed=\"fixed\"\n data-template=\"browse:fix-links\"\n style=\"\n transition-duration: 0ms;\n transform: translate3d(0px, 0px, 0px);\n left: 0px;\n right: 0.399994px;\n \"\n >\n <app-toolbar\n class=\"toolbar\"\n sticky=\"sticky\"\n style=\"transform: translate3d(0px, 0px, 0px)\"\n >\n <!-- TOC button -->\n <paper-icon-button\n id=\"tocToggle\"\n class=\"toc-toggle\"\n icon=\"icons:view-list\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n\n <!-- Plain reading view-->\n <pb-toggle-feature\n *ngIf=\"data.docs?.length === 1\"\n name=\"highlight1\"\n selector=\"tei-app,pb-popover,pb-highlight,.quote,pb-alternate\"\n default=\"off\"\n action=\"disable\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n >\n <ng-container *ngIf=\"data.labels && data.labels.view\">\n {{data.labels.view}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.view\">\n <pb-i18n key=\"document.plain\">Plain Reading View</pb-i18n>\n </ng-container>\n </pb-toggle-feature>\n\n <!-- Zoom Controls -->\n <pb-zoom\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n direction=\"in\"\n icon=\"icons:zoom-in\"\n ></pb-zoom>\n <pb-zoom\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n direction=\"out\"\n icon=\"icons:zoom-out\"\n ></pb-zoom>\n\n <!-- Navigation Controls -->\n <pb-navigation\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n keyboard=\"left\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n direction=\"backward\"\n unit=\"page\"\n >\n <paper-icon-button\n icon=\"icons:chevron-left\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n </pb-navigation>\n <pb-navigation\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n keyboard=\"right\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n direction=\"forward\"\n unit=\"page\"\n >\n <paper-icon-button\n icon=\"icons:chevron-right\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n </pb-navigation>\n\n <!-- Pulsante aggiungi pannello -->\n <pb-grid-action \n *ngIf=\"!data.libOptions?.grid?.disableAddColumn\"\n action=\"add\" \n class=\"grid-add\" \n [attr.grid]=\"'#' + (data.grid?.id || 'grid')\"\n >\n <paper-button \n role=\"button\" \n tabindex=\"0\" \n animated=\"\" \n elevation=\"0\" \n aria-disabled=\"false\"\n >\n <iron-icon icon=\"icons:add\"></iron-icon> \n {{ data.labels?.addColumn || 'Aggiungi colonna' }}\n </paper-button>\n </pb-grid-action>\n\n <!-- Pulsante download -->\n <ng-container *ngIf=\"data.download\">\n <div class=\"n7-parallel-text-viewer__toolbar-container-flex\">\n <pb-download\n [type]=\"data.download.format || ''\"\n [src]=\"data.docs[0].id\"\n [url]=\"data.download.file || ''\"\n dialog=\"downloadDialog\"\n (click)=\"openDownload($event, data.download.file)\"\n [title]=\"data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : ''\"\n >\n <paper-button raised=\"\">\n {{data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : 'Download'}}\n </paper-button>\n </pb-download>\n </div>\n </ng-container>\n\n <pb-progress\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n indeterminate=\"\"\n bottom-item=\"bottom-item\"\n style=\"visibility: hidden\"\n ></pb-progress>\n </app-toolbar>\n </app-header>\n\n <!-- Main Content with Parallel Grid -->\n <main class=\"content-body\">\n <pb-grid \n [id]=\"data.grid?.id || 'grid'\"\n [attr.panels]=\"data.grid?.panels ? '[' + data.grid.panels.join(',') + ']' : '[0]'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n >\n <!-- Main pb-->\n <pb-view \n id=\"transcription-view\"\n [attr.src]=\"data.mainDoc.doc_id || data.docs[0].id\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n [attr.odd]=\"data.mainDoc.odd\"\n [attr.view]=\"data.mainDoc.view\"\n (click)=\"onClick($event)\"\n [attr.url]=\"data.mainDoc.rootPath\"\n append-footnotes=\"append-footnotes\"\n >\n <!-- Param per ricerca avanzata -->\n <pb-param\n *ngIf=\"data.mainDoc.url\"\n name=\"url\"\n [attr.value]=\"data.mainDoc.url\"\n ></pb-param>\n </pb-view>\n\n <!-- Template -->\n <template>\n <pb-panel [attr.emit]=\"data.grid?.emit || 'transcription'\">\n <!-- Rimozione colonna -->\n <pb-grid-action \n [attr.grid]=\"'#' + (data.grid?.id || 'grid')\" \n slot=\"toolbar\" \n action=\"remove\"\n >\n <paper-icon-button icon=\"icons:close\"></paper-icon-button>\n </pb-grid-action>\n\n <!-- Pannelli secondari -->\n \n <ng-container *ngFor=\"let panel of data.panels\">\n <ng-container *ngIf=\"panel.enabled\">\n <ng-container [ngSwitch]=\"panel.type\">\n\n <ng-container *ngSwitchCase=\"'text'\">\n <template [attr.title]=\"panel.title\">\n <pb-view \n [attr.id]=\"panel.id + '-view'\"\n [attr.src]=\"panel.doc_id || data.docs[0].id\"\n [attr.odd]=\"panel.odd\"\n [attr.view]=\"panel.view || 'single'\"\n [attr.xpath]=\"panel.xpath\"\n [attr.map]=\"panel.mapFunction\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n (click)=\"onClick($event)\"\n [attr.url]=\"data.mainDoc.rootPath\"\n disable-history=\"\"\n >\n <pb-param \n *ngFor=\"let param of panel.params || []\"\n [attr.name]=\"param.name\"\n [attr.value]=\"param.value\"\n ></pb-param>\n </pb-view>\n </template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'facsimile'\">\n <template [attr.title]=\"panel.title\">\n <pb-facsimile\n *ngIf=\"panel.facsimile?.enabled\"\n [attr.base-uri]=\"panel.facsimile.uri\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n class=\"pb-facsimile\"\n [style.height]=\"panel.facsimile.options?.height || '600px'\"\n [attr.default-zoom-level]=\"panel.facsimile.options?.defaultZoomLevel || 0\"\n [attr.show-navigator]=\"panel.facsimile.options?.showNavigator ? 'show-navigator' : null\"\n [attr.show-navigation-control]=\"panel.facsimile.options?.showNavigationControl ? 'show-navigation-control' : null\"\n [attr.show-home-control]=\"panel.facsimile.options?.showHomeControl ? 'show-home-control' : null\"\n [attr.show-rotation-control]=\"panel.facsimile.options?.showRotationControl ? 'show-rotation-control' : null\"\n [attr.show-full-page-control]=\"panel.facsimile.options?.showFullPageControl ? 'show-full-page-control' : null\"\n [scans]=\"panel.facsimile.scans\"\n >\n </pb-facsimile>\n </template>\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n </pb-panel>\n </template>\n </pb-grid>\n </main>\n\n <!-- TOC Drawer -->\n <pb-drawer\n toggle=\"tocToggle\"\n class=\"tocDrawer\"\n emit=\"toc\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n >\n <div class=\"drawer-content\">\n <h3>\n <ng-container *ngIf=\"data.labels && data.labels.toc\">\n {{data.labels.toc}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.toc\">\n <pb-i18n key=\"document.contents\">Contents</pb-i18n>\n </ng-container>\n </h3>\n <pb-load\n *ngIf=\"data.docs && data.docs.length > 0 && !data.libOptions?.toc?.disable\"\n id=\"toc\"\n [attr.url]=\"data.mainDoc.rootPath ? (data.mainDoc.rootPath + '/' + data.mainDoc.doc_id + '/contents?target=transcription&icons=true') : 'api/document/{doc}/contents?target=transcription&icons=true'\"\n [attr.src]=\"data.mainDoc.doc_id\"\n subscribe=\"toc\"\n emit=\"toc\"\n expand=\"expand\"\n auto=\"auto\"\n >\n <ng-container *ngIf=\"data.labels && data.labels.loading\">\n {{data.labels.loading}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.loading\">\n <pb-i18n key=\"dialogs.loading\">Loading</pb-i18n>\n </ng-container>\n </pb-load>\n </div>\n </pb-drawer>\n </app-header-layout>\n </app-drawer-layout>\n </pb-page>\n</div>\n\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }] }); }
|
|
40
40
|
}
|
|
41
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ParallelTextViewerComponent, decorators: [{
|
|
42
42
|
type: Component,
|
|
43
|
-
args: [{ selector: 'n7-parallel-text-viewer', template: "<div\n class=\"n7-parallel-text-viewer {{data?.classes || ''}}\"\n *ngIf=\"data && data.endpoint\"\n>\n <pb-page \n [attr.endpoint]=\"data.endpoint\" \n api-version=\"1.0.0\" \n url-path=\"query\"\n [attr.url-ignore]=\"data.libOptions?.pbPage?.urlIgnore?.join(',') || 'odd,view,path,selectors,highlight,view2'\"\n >\n <!-- PB DOCUMENT-->\n <pb-document\n *ngFor=\"let doc of data.docs; index as $i\"\n [attr.path]=\"doc.xml\"\n [attr.odd]=\"doc.odd\"\n [attr.id]=\"doc.id\"\n [attr.view]=\"doc.view\"\n [attr.disable-history]=\"doc.disableHistory === true ? '' : null\"\n [attr.root-path]=\"doc.rootPath\"\n >\n </pb-document>\n\n <app-drawer-layout force-narrow=\"force-narrow\" narrow=\"\">\n <app-header-layout>\n <app-header\n fixed=\"fixed\"\n data-template=\"browse:fix-links\"\n style=\"\n transition-duration: 0ms;\n transform: translate3d(0px, 0px, 0px);\n left: 0px;\n right: 0.399994px;\n \"\n >\n <app-toolbar\n class=\"toolbar\"\n sticky=\"sticky\"\n style=\"transform: translate3d(0px, 0px, 0px)\"\n >\n <!-- TOC button -->\n <paper-icon-button\n id=\"tocToggle\"\n class=\"toc-toggle\"\n icon=\"icons:view-list\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n\n <!-- Plain reading view-->\n <pb-toggle-feature\n *ngIf=\"data.docs?.length === 1\"\n name=\"highlight1\"\n selector=\"tei-app,pb-popover,pb-highlight,.quote,pb-alternate\"\n default=\"off\"\n action=\"disable\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n >\n <ng-container *ngIf=\"data.labels && data.labels.view\">\n {{data.labels.view}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.view\">\n <pb-i18n key=\"document.plain\">Plain Reading View</pb-i18n>\n </ng-container>\n </pb-toggle-feature>\n\n <!-- Zoom Controls -->\n <pb-zoom\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n direction=\"in\"\n icon=\"icons:zoom-in\"\n ></pb-zoom>\n <pb-zoom\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n direction=\"out\"\n icon=\"icons:zoom-out\"\n ></pb-zoom>\n\n <!-- Navigation Controls -->\n <pb-navigation\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n keyboard=\"left\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n direction=\"backward\"\n unit=\"page\"\n >\n <paper-icon-button\n icon=\"icons:chevron-left\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n </pb-navigation>\n <pb-navigation\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n keyboard=\"right\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n direction=\"forward\"\n unit=\"page\"\n >\n <paper-icon-button\n icon=\"icons:chevron-right\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n </pb-navigation>\n\n <!-- Pulsante aggiungi pannello -->\n <pb-grid-action \n *ngIf=\"!data.libOptions?.grid?.disableAddColumn\"\n action=\"add\" \n class=\"grid-add\" \n [attr.grid]=\"'#' + (data.grid?.id || 'grid')\"\n >\n <paper-button \n role=\"button\" \n tabindex=\"0\" \n animated=\"\" \n elevation=\"0\" \n aria-disabled=\"false\"\n >\n <iron-icon icon=\"icons:add\"></iron-icon> \n {{ data.labels?.addColumn || 'Aggiungi colonna' }}\n </paper-button>\n </pb-grid-action>\n\n <!-- Pulsante download -->\n <ng-container *ngIf=\"data.download\">\n <div class=\"n7-parallel-text-viewer__toolbar-container-flex\">\n <pb-download\n [type]=\"data.download.format || ''\"\n [src]=\"data.docs[0].id\"\n [url]=\"data.download.file || ''\"\n dialog=\"downloadDialog\"\n (click)=\"openDownload($event, data.download.file)\"\n [title]=\"data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : ''\"\n >\n <paper-button raised=\"\">\n {{data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : 'Download'}}\n </paper-button>\n </pb-download>\n </div>\n </ng-container>\n\n <pb-progress\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n indeterminate=\"\"\n bottom-item=\"bottom-item\"\n style=\"visibility: hidden\"\n ></pb-progress>\n </app-toolbar>\n </app-header>\n\n <!-- Main Content with Parallel Grid -->\n <main class=\"content-body\">\n <pb-grid \n [id]=\"data.grid?.id || 'grid'\"\n [attr.panels]=\"data.grid?.panels ? '[' + data.grid.panels.join(',') + ']' : '[0]'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n >\n <!-- Main pb-->\n <pb-view \n id=\"transcription-view\"\n [attr.src]=\"data.mainDoc.doc_id || data.docs[0].id\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n [attr.odd]=\"data.mainDoc.odd\"\n [attr.view]=\"data.mainDoc.view\"\n (click)=\"onClick($event)\"\n [attr.url]=\"data.mainDoc.rootPath\"\n append-footnotes=\"append-footnotes\"\n >\n </pb-view>\n\n <!-- Template -->\n <template>\n <pb-panel [attr.emit]=\"data.grid?.emit || 'transcription'\">\n <!-- Rimozione colonna -->\n <pb-grid-action \n [attr.grid]=\"'#' + (data.grid?.id || 'grid')\" \n slot=\"toolbar\" \n action=\"remove\"\n >\n <paper-icon-button icon=\"icons:close\"></paper-icon-button>\n </pb-grid-action>\n\n <!-- Pannelli secondari -->\n \n <ng-container *ngFor=\"let panel of data.panels\">\n <ng-container *ngIf=\"panel.enabled\">\n <ng-container [ngSwitch]=\"panel.type\">\n\n <ng-container *ngSwitchCase=\"'text'\">\n <template [attr.title]=\"panel.title\">\n <pb-view \n [attr.id]=\"panel.id + '-view'\"\n [attr.src]=\"panel.doc_id || data.docs[0].id\"\n [attr.odd]=\"panel.odd\"\n [attr.view]=\"panel.view || 'single'\"\n [attr.xpath]=\"panel.xpath\"\n [attr.map]=\"panel.mapFunction\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n (click)=\"onClick($event)\"\n [attr.url]=\"data.mainDoc.rootPath\"\n disable-history=\"\"\n >\n <pb-param \n *ngFor=\"let param of panel.params || []\"\n [attr.name]=\"param.name\"\n [attr.value]=\"param.value\"\n ></pb-param>\n </pb-view>\n </template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'facsimile'\">\n <template [attr.title]=\"panel.title\">\n <pb-facsimile\n *ngIf=\"panel.facsimile?.enabled\"\n [attr.base-uri]=\"panel.facsimile.uri\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n class=\"pb-facsimile\"\n [style.height]=\"panel.facsimile.options?.height || '600px'\"\n [attr.default-zoom-level]=\"panel.facsimile.options?.defaultZoomLevel || 0\"\n [attr.show-navigator]=\"panel.facsimile.options?.showNavigator ? 'show-navigator' : null\"\n [attr.show-navigation-control]=\"panel.facsimile.options?.showNavigationControl ? 'show-navigation-control' : null\"\n [attr.show-home-control]=\"panel.facsimile.options?.showHomeControl ? 'show-home-control' : null\"\n [attr.show-rotation-control]=\"panel.facsimile.options?.showRotationControl ? 'show-rotation-control' : null\"\n [attr.show-full-page-control]=\"panel.facsimile.options?.showFullPageControl ? 'show-full-page-control' : null\"\n [scans]=\"panel.facsimile.scans\"\n >\n </pb-facsimile>\n </template>\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n </pb-panel>\n </template>\n </pb-grid>\n </main>\n\n <!-- TOC Drawer -->\n <pb-drawer\n toggle=\"tocToggle\"\n class=\"tocDrawer\"\n emit=\"toc\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n >\n <div class=\"drawer-content\">\n <h3>\n <ng-container *ngIf=\"data.labels && data.labels.toc\">\n {{data.labels.toc}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.toc\">\n <pb-i18n key=\"document.contents\">Contents</pb-i18n>\n </ng-container>\n </h3>\n <pb-load\n *ngIf=\"data.docs && data.docs.length > 0 && !data.libOptions?.toc?.disable\"\n id=\"toc\"\n [attr.url]=\"data.mainDoc.rootPath ? (data.mainDoc.rootPath + '/' + data.mainDoc.doc_id + '/contents?target=transcription&icons=true') : 'api/document/{doc}/contents?target=transcription&icons=true'\"\n [attr.src]=\"data.mainDoc.doc_id\"\n subscribe=\"toc\"\n emit=\"toc\"\n expand=\"expand\"\n auto=\"auto\"\n >\n <ng-container *ngIf=\"data.labels && data.labels.loading\">\n {{data.labels.loading}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.loading\">\n <pb-i18n key=\"dialogs.loading\">Loading</pb-i18n>\n </ng-container>\n </pb-load>\n </div>\n </pb-drawer>\n </app-header-layout>\n </app-drawer-layout>\n </pb-page>\n</div>\n\n" }]
|
|
43
|
+
args: [{ selector: 'n7-parallel-text-viewer', template: "<div\n class=\"n7-parallel-text-viewer {{data?.classes || ''}}\"\n *ngIf=\"data && data.endpoint\"\n>\n <pb-page \n [attr.endpoint]=\"data.endpoint\" \n api-version=\"1.0.0\" \n url-path=\"query\"\n [attr.url-ignore]=\"data.libOptions?.pbPage?.urlIgnore?.join(',') || 'odd,view,path,selectors,highlight,view2'\"\n >\n <!-- PB DOCUMENT-->\n <pb-document\n *ngFor=\"let doc of data.docs; index as $i\"\n [attr.path]=\"doc.xml\"\n [attr.odd]=\"doc.odd\"\n [attr.id]=\"doc.id\"\n [attr.view]=\"doc.view\"\n [attr.disable-history]=\"doc.disableHistory === true ? '' : null\"\n [attr.root-path]=\"doc.rootPath\"\n >\n </pb-document>\n\n <app-drawer-layout force-narrow=\"force-narrow\" narrow=\"\">\n <app-header-layout>\n <app-header\n fixed=\"fixed\"\n data-template=\"browse:fix-links\"\n style=\"\n transition-duration: 0ms;\n transform: translate3d(0px, 0px, 0px);\n left: 0px;\n right: 0.399994px;\n \"\n >\n <app-toolbar\n class=\"toolbar\"\n sticky=\"sticky\"\n style=\"transform: translate3d(0px, 0px, 0px)\"\n >\n <!-- TOC button -->\n <paper-icon-button\n id=\"tocToggle\"\n class=\"toc-toggle\"\n icon=\"icons:view-list\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n\n <!-- Plain reading view-->\n <pb-toggle-feature\n *ngIf=\"data.docs?.length === 1\"\n name=\"highlight1\"\n selector=\"tei-app,pb-popover,pb-highlight,.quote,pb-alternate\"\n default=\"off\"\n action=\"disable\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n >\n <ng-container *ngIf=\"data.labels && data.labels.view\">\n {{data.labels.view}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.view\">\n <pb-i18n key=\"document.plain\">Plain Reading View</pb-i18n>\n </ng-container>\n </pb-toggle-feature>\n\n <!-- Zoom Controls -->\n <pb-zoom\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n direction=\"in\"\n icon=\"icons:zoom-in\"\n ></pb-zoom>\n <pb-zoom\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n direction=\"out\"\n icon=\"icons:zoom-out\"\n ></pb-zoom>\n\n <!-- Navigation Controls -->\n <pb-navigation\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n keyboard=\"left\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n direction=\"backward\"\n unit=\"page\"\n >\n <paper-icon-button\n icon=\"icons:chevron-left\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n </pb-navigation>\n <pb-navigation\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n keyboard=\"right\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n direction=\"forward\"\n unit=\"page\"\n >\n <paper-icon-button\n icon=\"icons:chevron-right\"\n role=\"button\"\n tabindex=\"0\"\n aria-disabled=\"false\"\n ></paper-icon-button>\n </pb-navigation>\n\n <!-- Pulsante aggiungi pannello -->\n <pb-grid-action \n *ngIf=\"!data.libOptions?.grid?.disableAddColumn\"\n action=\"add\" \n class=\"grid-add\" \n [attr.grid]=\"'#' + (data.grid?.id || 'grid')\"\n >\n <paper-button \n role=\"button\" \n tabindex=\"0\" \n animated=\"\" \n elevation=\"0\" \n aria-disabled=\"false\"\n >\n <iron-icon icon=\"icons:add\"></iron-icon> \n {{ data.labels?.addColumn || 'Aggiungi colonna' }}\n </paper-button>\n </pb-grid-action>\n\n <!-- Pulsante download -->\n <ng-container *ngIf=\"data.download\">\n <div class=\"n7-parallel-text-viewer__toolbar-container-flex\">\n <pb-download\n [type]=\"data.download.format || ''\"\n [src]=\"data.docs[0].id\"\n [url]=\"data.download.file || ''\"\n dialog=\"downloadDialog\"\n (click)=\"openDownload($event, data.download.file)\"\n [title]=\"data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : ''\"\n >\n <paper-button raised=\"\">\n {{data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : 'Download'}}\n </paper-button>\n </pb-download>\n </div>\n </ng-container>\n\n <pb-progress\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n indeterminate=\"\"\n bottom-item=\"bottom-item\"\n style=\"visibility: hidden\"\n ></pb-progress>\n </app-toolbar>\n </app-header>\n\n <!-- Main Content with Parallel Grid -->\n <main class=\"content-body\">\n <pb-grid \n [id]=\"data.grid?.id || 'grid'\"\n [attr.panels]=\"data.grid?.panels ? '[' + data.grid.panels.join(',') + ']' : '[0]'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n >\n <!-- Main pb-->\n <pb-view \n id=\"transcription-view\"\n [attr.src]=\"data.mainDoc.doc_id || data.docs[0].id\"\n [attr.emit]=\"data.grid?.emit || 'transcription'\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n [attr.odd]=\"data.mainDoc.odd\"\n [attr.view]=\"data.mainDoc.view\"\n (click)=\"onClick($event)\"\n [attr.url]=\"data.mainDoc.rootPath\"\n append-footnotes=\"append-footnotes\"\n >\n <!-- Param per ricerca avanzata -->\n <pb-param\n *ngIf=\"data.mainDoc.url\"\n name=\"url\"\n [attr.value]=\"data.mainDoc.url\"\n ></pb-param>\n </pb-view>\n\n <!-- Template -->\n <template>\n <pb-panel [attr.emit]=\"data.grid?.emit || 'transcription'\">\n <!-- Rimozione colonna -->\n <pb-grid-action \n [attr.grid]=\"'#' + (data.grid?.id || 'grid')\" \n slot=\"toolbar\" \n action=\"remove\"\n >\n <paper-icon-button icon=\"icons:close\"></paper-icon-button>\n </pb-grid-action>\n\n <!-- Pannelli secondari -->\n \n <ng-container *ngFor=\"let panel of data.panels\">\n <ng-container *ngIf=\"panel.enabled\">\n <ng-container [ngSwitch]=\"panel.type\">\n\n <ng-container *ngSwitchCase=\"'text'\">\n <template [attr.title]=\"panel.title\">\n <pb-view \n [attr.id]=\"panel.id + '-view'\"\n [attr.src]=\"panel.doc_id || data.docs[0].id\"\n [attr.odd]=\"panel.odd\"\n [attr.view]=\"panel.view || 'single'\"\n [attr.xpath]=\"panel.xpath\"\n [attr.map]=\"panel.mapFunction\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n (click)=\"onClick($event)\"\n [attr.url]=\"data.mainDoc.rootPath\"\n disable-history=\"\"\n >\n <pb-param \n *ngFor=\"let param of panel.params || []\"\n [attr.name]=\"param.name\"\n [attr.value]=\"param.value\"\n ></pb-param>\n </pb-view>\n </template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'facsimile'\">\n <template [attr.title]=\"panel.title\">\n <pb-facsimile\n *ngIf=\"panel.facsimile?.enabled\"\n [attr.base-uri]=\"panel.facsimile.uri\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n class=\"pb-facsimile\"\n [style.height]=\"panel.facsimile.options?.height || '600px'\"\n [attr.default-zoom-level]=\"panel.facsimile.options?.defaultZoomLevel || 0\"\n [attr.show-navigator]=\"panel.facsimile.options?.showNavigator ? 'show-navigator' : null\"\n [attr.show-navigation-control]=\"panel.facsimile.options?.showNavigationControl ? 'show-navigation-control' : null\"\n [attr.show-home-control]=\"panel.facsimile.options?.showHomeControl ? 'show-home-control' : null\"\n [attr.show-rotation-control]=\"panel.facsimile.options?.showRotationControl ? 'show-rotation-control' : null\"\n [attr.show-full-page-control]=\"panel.facsimile.options?.showFullPageControl ? 'show-full-page-control' : null\"\n [scans]=\"panel.facsimile.scans\"\n >\n </pb-facsimile>\n </template>\n </ng-container>\n </ng-container>\n </ng-container>\n </ng-container>\n\n </pb-panel>\n </template>\n </pb-grid>\n </main>\n\n <!-- TOC Drawer -->\n <pb-drawer\n toggle=\"tocToggle\"\n class=\"tocDrawer\"\n emit=\"toc\"\n [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n >\n <div class=\"drawer-content\">\n <h3>\n <ng-container *ngIf=\"data.labels && data.labels.toc\">\n {{data.labels.toc}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.toc\">\n <pb-i18n key=\"document.contents\">Contents</pb-i18n>\n </ng-container>\n </h3>\n <pb-load\n *ngIf=\"data.docs && data.docs.length > 0 && !data.libOptions?.toc?.disable\"\n id=\"toc\"\n [attr.url]=\"data.mainDoc.rootPath ? (data.mainDoc.rootPath + '/' + data.mainDoc.doc_id + '/contents?target=transcription&icons=true') : 'api/document/{doc}/contents?target=transcription&icons=true'\"\n [attr.src]=\"data.mainDoc.doc_id\"\n subscribe=\"toc\"\n emit=\"toc\"\n expand=\"expand\"\n auto=\"auto\"\n >\n <ng-container *ngIf=\"data.labels && data.labels.loading\">\n {{data.labels.loading}}\n </ng-container>\n <ng-container *ngIf=\"!data.labels || !data.labels.loading\">\n <pb-i18n key=\"dialogs.loading\">Loading</pb-i18n>\n </ng-container>\n </pb-load>\n </div>\n </pb-drawer>\n </app-header-layout>\n </app-drawer-layout>\n </pb-page>\n</div>\n\n" }]
|
|
44
44
|
}], propDecorators: { data: [{
|
|
45
45
|
type: Input
|
|
46
46
|
}], emit: [{
|
|
47
47
|
type: Input
|
|
48
48
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parallel-text-viewer.js","sourceRoot":"","sources":["../../../../../../projects/dv-components-lib/src/lib/components/parallel-text-viewer/parallel-text-viewer.ts","../../../../../../projects/dv-components-lib/src/lib/components/parallel-text-viewer/parallel-text-viewer.html"],"names":[],"mappings":"AAAA,6BAA6B;AAC7B,0BAA0B;AAC1B,6BAA6B;AAC7B,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;;;AA6KzD,MAAM,OAAO,2BAA2B;aAK/B,YAAO,GAAG,KAAK,AAAR,CAAS;IAGvB,QAAQ;QACN,IAAI,CAAC,2BAA2B,CAAC,OAAO,EAAE,CAAC;YACzC,MAAM,CAAC,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAC3C,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;YACxC,CAAC,CAAC,YAAY,CACZ,KAAK,EAAE,GAAG,QACV,oDAAoD,CACrD,CAAC;YACF,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YACjC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC;YAC/B,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,OAAO;QACvB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC5B,CAAC;IAED,cAAc;QACZ,2BAA2B,CAAC,OAAO,GAAG,IAAI,CAAC;IAC7C,CAAC;IAED,OAAO,CAAC,OAAO;QACb,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,OAAO;QACvB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAC9B,CAAC;IAED,YAAY,CAAC,KAAY,EAAE,GAAW;QACpC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,GAAG,EAAE,CAAC;YACR,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;+GAzCU,2BAA2B;mGAA3B,2BAA2B,uGChLxC,kqXA8RA;;4FD9Ga,2BAA2B;kBAJvC,SAAS;+BACE,yBAAyB;8BAI1B,IAAI;sBAAZ,KAAK;gBAEG,IAAI;sBAAZ,KAAK","sourcesContent":["//---------------------------\n// PARALLEL-TEXT-VIEWER.ts\n//---------------------------\nimport { Component, Input, OnInit } from '@angular/core';\n\n/**\n * Interface for ParallelTextViewerComponent's \"data\"\n * Interface for TextViewerComponent's \"data\"\n * @property endpoint (required)\n * @property doc (required)\n * @property facsimile (optional)\n */\n\n\nexport interface PanelConfig {\n  id: string;              \n  enabled: boolean;         \n  title: string;           \n  type: 'text' | 'facsimile'; \n  \n  // testo\n  odd?: string;\n  doc_id?: string;\n  view?: string;\n  xpath?: string;\n  mapFunction?: string;\n  src?: string;\n\n\n  // facsimile\n  facsimile?: {\n    enabled?: boolean;\n    uri: string;\n    scans?: string[];\n    options?: {\n      height?: string;\n      defaultZoomLevel?: number;\n      showHomeControl?: boolean;\n      showFullPageControl?: boolean;\n      showRotationControl?: boolean;\n      showNavigator?: boolean;\n      showNavigationControl?: boolean;\n    };\n  }; \n\n  params?: Array<\n  { name: string; value: string }\n  >;\n}\n\n\nexport interface ParallelTextViewerData {\n  /*\n   * TEI Publisher server endpoint\n   */\n  endpoint: string;\n  \n  /*\n   * Documents configuration\n   */\n  docs: {\n    xml: string;\n    id: string;  \n    url?: string;\n    rootPath?: string;\n    \n  }[];\n\n  mainDoc: {\n    doc_id: string;\n    odd: string;\n    view: string;\n    channel?: string;\n    translation?: boolean;\n    download?: string;\n    rootPath?: string;\n    mapFunction?: string;\n    url?: string;\n    xpath?: string;\n    disableHistory?: boolean;\n    apparatus?: {\n      mapFunction?: string;\n      rootPath?: string;\n      odd: string;\n      channel?: string;\n      view: string;\n      params?: {\n        name: string;\n        value: string;\n      }[];\n      standalone?: boolean;\n    };\n  };\n\n  /*\n   * Grid configuration for parallel layout\n   */\n  grid?: {\n    id?: string;\n    panels?: number[]; \n    subscribe?: string;\n    emit?: string;\n    initialPanels?: string;\n    columnWidths?: string;\n  };\n\n  /*\n   * Configurazione pannelli secondari\n   */\n  /*\n   * Array generico per panels\n   */\n  panels?: PanelConfig[];\n  /*\n   * DOWNLOAD FILES\n   */\n  download?: {\n    label?: string;\n    file?: string;\n    format?: string;\n  };\n  /*\n   * scrollSync option\n   */\n  scrollSync?: boolean;\n  /*\n\n  /*\n   * LABELS for TOOLBAR\n   */\n  labels?: {\n    view?: string;\n    addColumn?: string;\n    select?: {\n      label?: string;\n      type?: {\n        [key: string]: string;\n      };\n    };\n    index?: {\n      show?: string;\n      hide?: string;\n    };\n    toc?: string;\n    loading?: string;\n  };\n  /*\n   * toggle column\n   */\n  toggleColumn?: boolean;\n  \n  \n\n  libOptions?: {\n    pbPage?: {\n      urlIgnore?: string[];\n    };\n    toc?: {\n      disable?: boolean;\n    };\n    grid?: {\n      disableAddColumn?: boolean;\n    };\n  };\n\n\n  /**\n   * additional html classes\n   */\n  classes?: string;\n}\n\n@Component({\n  selector: 'n7-parallel-text-viewer',\n  templateUrl: './parallel-text-viewer.html',\n})\nexport class ParallelTextViewerComponent implements OnInit {\n  @Input() data: ParallelTextViewerData;\n\n  @Input() emit: any;\n\n  static _loaded = false;\n\n\n  ngOnInit() {\n    if (!ParallelTextViewerComponent._loaded) {\n      const s = document.createElement('script');\n      const baseHref = window.location.origin;\n      s.setAttribute(\n        'src', `${baseHref  \n        }/assets/pb-components/dist/pb-components-bundle.js`\n      );\n      s.setAttribute('type', 'module');\n      s.onload = this.onScriptLoaded;\n      document.head.appendChild(s);\n    }\n  }\n\n  displayIndex() {\n    if (!this.emit) return;\n    this.emit('togglecolumn');\n  }\n\n  onScriptLoaded() {\n    ParallelTextViewerComponent._loaded = true;\n  }\n\n  onClick(payload) {\n    if (!this.emit) return;     \n    this.emit('click', payload);\n  }\n\n  openDownload(event: Event, url: string) {\n    event.preventDefault();\n    if (url) {\n      window.open(url, '_blank');\n    }\n  }\n}","<div\n  class=\"n7-parallel-text-viewer {{data?.classes || ''}}\"\n  *ngIf=\"data && data.endpoint\"\n>\n  <pb-page \n    [attr.endpoint]=\"data.endpoint\" \n    api-version=\"1.0.0\" \n    url-path=\"query\"\n    [attr.url-ignore]=\"data.libOptions?.pbPage?.urlIgnore?.join(',') || 'odd,view,path,selectors,highlight,view2'\"\n  >\n    <!-- PB DOCUMENT-->\n    <pb-document\n      *ngFor=\"let doc of data.docs; index as $i\"\n      [attr.path]=\"doc.xml\"\n      [attr.odd]=\"doc.odd\"\n      [attr.id]=\"doc.id\"\n      [attr.view]=\"doc.view\"\n      [attr.disable-history]=\"doc.disableHistory === true ? '' : null\"\n      [attr.root-path]=\"doc.rootPath\"\n    >\n    </pb-document>\n\n    <app-drawer-layout force-narrow=\"force-narrow\" narrow=\"\">\n      <app-header-layout>\n        <app-header\n          fixed=\"fixed\"\n          data-template=\"browse:fix-links\"\n          style=\"\n            transition-duration: 0ms;\n            transform: translate3d(0px, 0px, 0px);\n            left: 0px;\n            right: 0.399994px;\n          \"\n        >\n          <app-toolbar\n            class=\"toolbar\"\n            sticky=\"sticky\"\n            style=\"transform: translate3d(0px, 0px, 0px)\"\n          >\n            <!-- TOC button -->\n            <paper-icon-button\n              id=\"tocToggle\"\n              class=\"toc-toggle\"\n              icon=\"icons:view-list\"\n              role=\"button\"\n              tabindex=\"0\"\n              aria-disabled=\"false\"\n            ></paper-icon-button>\n\n            <!-- Plain reading view-->\n            <pb-toggle-feature\n              *ngIf=\"data.docs?.length === 1\"\n              name=\"highlight1\"\n              selector=\"tei-app,pb-popover,pb-highlight,.quote,pb-alternate\"\n              default=\"off\"\n              action=\"disable\"\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n            >\n              <ng-container *ngIf=\"data.labels && data.labels.view\">\n                {{data.labels.view}}\n              </ng-container>\n              <ng-container *ngIf=\"!data.labels || !data.labels.view\">\n                <pb-i18n key=\"document.plain\">Plain Reading View</pb-i18n>\n              </ng-container>\n            </pb-toggle-feature>\n\n            <!-- Zoom Controls -->\n            <pb-zoom\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              direction=\"in\"\n              icon=\"icons:zoom-in\"\n            ></pb-zoom>\n            <pb-zoom\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              direction=\"out\"\n              icon=\"icons:zoom-out\"\n            ></pb-zoom>\n\n            <!-- Navigation Controls -->\n            <pb-navigation\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              keyboard=\"left\"\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n              direction=\"backward\"\n              unit=\"page\"\n            >\n              <paper-icon-button\n                icon=\"icons:chevron-left\"\n                role=\"button\"\n                tabindex=\"0\"\n                aria-disabled=\"false\"\n              ></paper-icon-button>\n            </pb-navigation>\n            <pb-navigation\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              keyboard=\"right\"\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n              direction=\"forward\"\n              unit=\"page\"\n            >\n              <paper-icon-button\n                icon=\"icons:chevron-right\"\n                role=\"button\"\n                tabindex=\"0\"\n                aria-disabled=\"false\"\n              ></paper-icon-button>\n            </pb-navigation>\n\n            <!-- Pulsante aggiungi pannello -->\n            <pb-grid-action \n              *ngIf=\"!data.libOptions?.grid?.disableAddColumn\"\n              action=\"add\" \n              class=\"grid-add\" \n              [attr.grid]=\"'#' + (data.grid?.id || 'grid')\"\n            >\n              <paper-button \n                role=\"button\" \n                tabindex=\"0\" \n                animated=\"\" \n                elevation=\"0\" \n                aria-disabled=\"false\"\n              >\n                <iron-icon icon=\"icons:add\"></iron-icon> \n                {{ data.labels?.addColumn || 'Aggiungi colonna' }}\n              </paper-button>\n            </pb-grid-action>\n\n            <!-- Pulsante download -->\n            <ng-container *ngIf=\"data.download\">\n              <div class=\"n7-parallel-text-viewer__toolbar-container-flex\">\n                <pb-download\n                  [type]=\"data.download.format || ''\"\n                  [src]=\"data.docs[0].id\"\n                  [url]=\"data.download.file || ''\"\n                  dialog=\"downloadDialog\"\n                  (click)=\"openDownload($event, data.download.file)\"\n                  [title]=\"data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : ''\"\n                >\n                  <paper-button raised=\"\">\n                    {{data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : 'Download'}}\n                  </paper-button>\n                </pb-download>\n              </div>\n            </ng-container>\n\n            <pb-progress\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n              indeterminate=\"\"\n              bottom-item=\"bottom-item\"\n              style=\"visibility: hidden\"\n            ></pb-progress>\n          </app-toolbar>\n        </app-header>\n\n        <!-- Main Content with Parallel Grid -->\n        <main class=\"content-body\">\n          <pb-grid \n            [id]=\"data.grid?.id || 'grid'\"\n            [attr.panels]=\"data.grid?.panels ? '[' + data.grid.panels.join(',') + ']' : '[0]'\"\n            [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n            [attr.emit]=\"data.grid?.emit || 'transcription'\"\n          >\n            <!-- Main pb-->\n            <pb-view \n              id=\"transcription-view\"\n              [attr.src]=\"data.mainDoc.doc_id || data.docs[0].id\"\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n              [attr.odd]=\"data.mainDoc.odd\"\n              [attr.view]=\"data.mainDoc.view\"\n              (click)=\"onClick($event)\"\n              [attr.url]=\"data.mainDoc.rootPath\"\n              append-footnotes=\"append-footnotes\"\n            >\n            </pb-view>\n\n            <!-- Template -->\n            <template>\n              <pb-panel [attr.emit]=\"data.grid?.emit || 'transcription'\">\n                <!-- Rimozione colonna -->\n                <pb-grid-action \n                  [attr.grid]=\"'#' + (data.grid?.id || 'grid')\" \n                  slot=\"toolbar\" \n                  action=\"remove\"\n                >\n                  <paper-icon-button icon=\"icons:close\"></paper-icon-button>\n                </pb-grid-action>\n\n                <!-- Pannelli secondari -->\n                \n                <ng-container *ngFor=\"let panel of data.panels\">\n                  <ng-container *ngIf=\"panel.enabled\">\n                    <ng-container [ngSwitch]=\"panel.type\">\n\n                      <ng-container *ngSwitchCase=\"'text'\">\n                      <template [attr.title]=\"panel.title\">\n                      <pb-view \n                        [attr.id]=\"panel.id + '-view'\"\n                        [attr.src]=\"panel.doc_id || data.docs[0].id\"\n                        [attr.odd]=\"panel.odd\"\n                        [attr.view]=\"panel.view || 'single'\"\n                        [attr.xpath]=\"panel.xpath\"\n                        [attr.map]=\"panel.mapFunction\"\n                        [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n                        (click)=\"onClick($event)\"\n                        [attr.url]=\"data.mainDoc.rootPath\"\n                        disable-history=\"\"\n                      >\n                        <pb-param \n                          *ngFor=\"let param of panel.params || []\"\n                          [attr.name]=\"param.name\"\n                          [attr.value]=\"param.value\"\n                        ></pb-param>\n                      </pb-view>\n                    </template>\n                  </ng-container>\n\n                  <ng-container *ngSwitchCase=\"'facsimile'\">\n                    <template [attr.title]=\"panel.title\">\n                      <pb-facsimile\n                      *ngIf=\"panel.facsimile?.enabled\"\n                      [attr.base-uri]=\"panel.facsimile.uri\"\n                      [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n                      class=\"pb-facsimile\"\n                      [style.height]=\"panel.facsimile.options?.height || '600px'\"\n                      [attr.default-zoom-level]=\"panel.facsimile.options?.defaultZoomLevel || 0\"\n                      [attr.show-navigator]=\"panel.facsimile.options?.showNavigator ? 'show-navigator' : null\"\n                      [attr.show-navigation-control]=\"panel.facsimile.options?.showNavigationControl ? 'show-navigation-control' : null\"\n                      [attr.show-home-control]=\"panel.facsimile.options?.showHomeControl ? 'show-home-control' : null\"\n                      [attr.show-rotation-control]=\"panel.facsimile.options?.showRotationControl ? 'show-rotation-control' : null\"\n                      [attr.show-full-page-control]=\"panel.facsimile.options?.showFullPageControl ? 'show-full-page-control' : null\"\n                      [scans]=\"panel.facsimile.scans\"\n                    >\n                    </pb-facsimile>\n                    </template>\n                  </ng-container>\n                </ng-container>\n              </ng-container>\n              </ng-container>\n\n              </pb-panel>\n            </template>\n          </pb-grid>\n        </main>\n\n        <!-- TOC Drawer -->\n        <pb-drawer\n          toggle=\"tocToggle\"\n          class=\"tocDrawer\"\n          emit=\"toc\"\n          [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n        >\n          <div class=\"drawer-content\">\n            <h3>\n              <ng-container *ngIf=\"data.labels && data.labels.toc\">\n                {{data.labels.toc}}\n              </ng-container>\n              <ng-container *ngIf=\"!data.labels || !data.labels.toc\">\n                <pb-i18n key=\"document.contents\">Contents</pb-i18n>\n              </ng-container>\n            </h3>\n            <pb-load\n              *ngIf=\"data.docs && data.docs.length > 0 && !data.libOptions?.toc?.disable\"\n              id=\"toc\"\n              [attr.url]=\"data.mainDoc.rootPath ? (data.mainDoc.rootPath + '/' + data.mainDoc.doc_id + '/contents?target=transcription&icons=true') : 'api/document/{doc}/contents?target=transcription&icons=true'\"\n              [attr.src]=\"data.mainDoc.doc_id\"\n              subscribe=\"toc\"\n              emit=\"toc\"\n              expand=\"expand\"\n              auto=\"auto\"\n            >\n              <ng-container *ngIf=\"data.labels && data.labels.loading\">\n                {{data.labels.loading}}\n              </ng-container>\n              <ng-container *ngIf=\"!data.labels || !data.labels.loading\">\n                <pb-i18n key=\"dialogs.loading\">Loading</pb-i18n>\n              </ng-container>\n            </pb-load>\n          </div>\n        </pb-drawer>\n      </app-header-layout>\n    </app-drawer-layout>\n  </pb-page>\n</div>\n\n"]}
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parallel-text-viewer.js","sourceRoot":"","sources":["../../../../../../projects/dv-components-lib/src/lib/components/parallel-text-viewer/parallel-text-viewer.ts","../../../../../../projects/dv-components-lib/src/lib/components/parallel-text-viewer/parallel-text-viewer.html"],"names":[],"mappings":"AAAA,6BAA6B;AAC7B,0BAA0B;AAC1B,6BAA6B;AAC7B,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;;;AA6KzD,MAAM,OAAO,2BAA2B;aAK/B,YAAO,GAAG,KAAK,AAAR,CAAS;IAGvB,QAAQ;QACN,IAAI,CAAC,2BAA2B,CAAC,OAAO,EAAE,CAAC;YACzC,MAAM,CAAC,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YAC3C,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;YACxC,CAAC,CAAC,YAAY,CACZ,KAAK,EAAE,GAAG,QACV,oDAAoD,CACrD,CAAC;YACF,CAAC,CAAC,YAAY,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC;YACjC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC;YAC/B,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,OAAO;QACvB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC5B,CAAC;IAED,cAAc;QACZ,2BAA2B,CAAC,OAAO,GAAG,IAAI,CAAC;IAC7C,CAAC;IAED,OAAO,CAAC,OAAO;QACb,IAAI,CAAC,IAAI,CAAC,IAAI;YAAE,OAAO;QACvB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAC9B,CAAC;IAED,YAAY,CAAC,KAAY,EAAE,GAAW;QACpC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,GAAG,EAAE,CAAC;YACR,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;+GAzCU,2BAA2B;mGAA3B,2BAA2B,uGChLxC,m3XAoSA;;4FDpHa,2BAA2B;kBAJvC,SAAS;+BACE,yBAAyB;8BAI1B,IAAI;sBAAZ,KAAK;gBAEG,IAAI;sBAAZ,KAAK","sourcesContent":["//---------------------------\n// PARALLEL-TEXT-VIEWER.ts\n//---------------------------\nimport { Component, Input, OnInit } from '@angular/core';\n\n/**\n * Interface for ParallelTextViewerComponent's \"data\"\n * Interface for TextViewerComponent's \"data\"\n * @property endpoint (required)\n * @property doc (required)\n * @property facsimile (optional)\n */\n\n\nexport interface PanelConfig {\n  id: string;              \n  enabled: boolean;         \n  title: string;           \n  type: 'text' | 'facsimile'; \n  \n  // testo\n  odd?: string;\n  doc_id?: string;\n  view?: string;\n  xpath?: string;\n  mapFunction?: string;\n  src?: string;\n\n\n  // facsimile\n  facsimile?: {\n    enabled?: boolean;\n    uri: string;\n    scans?: string[];\n    options?: {\n      height?: string;\n      defaultZoomLevel?: number;\n      showHomeControl?: boolean;\n      showFullPageControl?: boolean;\n      showRotationControl?: boolean;\n      showNavigator?: boolean;\n      showNavigationControl?: boolean;\n    };\n  }; \n\n  params?: Array<\n  { name: string; value: string }\n  >;\n}\n\n\nexport interface ParallelTextViewerData {\n  /*\n   * TEI Publisher server endpoint\n   */\n  endpoint: string;\n  \n  /*\n   * Documents configuration\n   */\n  docs: {\n    xml: string;\n    id: string;  \n    url?: string;\n    rootPath?: string;\n    \n  }[];\n\n  mainDoc: {\n    doc_id: string;\n    odd: string;\n    view: string;\n    channel?: string;\n    translation?: boolean;\n    download?: string;\n    rootPath?: string;\n    mapFunction?: string;\n    url?: string;\n    xpath?: string;\n    disableHistory?: boolean;\n    apparatus?: {\n      mapFunction?: string;\n      rootPath?: string;\n      odd: string;\n      channel?: string;\n      view: string;\n      params?: {\n        name: string;\n        value: string;\n      }[];\n      standalone?: boolean;\n    };\n  };\n\n  /*\n   * Grid configuration for parallel layout\n   */\n  grid?: {\n    id?: string;\n    panels?: number[]; \n    subscribe?: string;\n    emit?: string;\n    initialPanels?: string;\n    columnWidths?: string;\n  };\n\n  /*\n   * Configurazione pannelli secondari\n   */\n  /*\n   * Array generico per panels\n   */\n  panels?: PanelConfig[];\n  /*\n   * DOWNLOAD FILES\n   */\n  download?: {\n    label?: string;\n    file?: string;\n    format?: string;\n  };\n  /*\n   * scrollSync option\n   */\n  scrollSync?: boolean;\n  /*\n\n  /*\n   * LABELS for TOOLBAR\n   */\n  labels?: {\n    view?: string;\n    addColumn?: string;\n    select?: {\n      label?: string;\n      type?: {\n        [key: string]: string;\n      };\n    };\n    index?: {\n      show?: string;\n      hide?: string;\n    };\n    toc?: string;\n    loading?: string;\n  };\n  /*\n   * toggle column\n   */\n  toggleColumn?: boolean;\n  \n  \n\n  libOptions?: {\n    pbPage?: {\n      urlIgnore?: string[];\n    };\n    toc?: {\n      disable?: boolean;\n    };\n    grid?: {\n      disableAddColumn?: boolean;\n    };\n  };\n\n\n  /**\n   * additional html classes\n   */\n  classes?: string;\n}\n\n@Component({\n  selector: 'n7-parallel-text-viewer',\n  templateUrl: './parallel-text-viewer.html',\n})\nexport class ParallelTextViewerComponent implements OnInit {\n  @Input() data: ParallelTextViewerData;\n\n  @Input() emit: any;\n\n  static _loaded = false;\n\n\n  ngOnInit() {\n    if (!ParallelTextViewerComponent._loaded) {\n      const s = document.createElement('script');\n      const baseHref = window.location.origin;\n      s.setAttribute(\n        'src', `${baseHref  \n        }/assets/pb-components/dist/pb-components-bundle.js`\n      );\n      s.setAttribute('type', 'module');\n      s.onload = this.onScriptLoaded;\n      document.head.appendChild(s);\n    }\n  }\n\n  displayIndex() {\n    if (!this.emit) return;\n    this.emit('togglecolumn');\n  }\n\n  onScriptLoaded() {\n    ParallelTextViewerComponent._loaded = true;\n  }\n\n  onClick(payload) {\n    if (!this.emit) return;     \n    this.emit('click', payload);\n  }\n\n  openDownload(event: Event, url: string) {\n    event.preventDefault();\n    if (url) {\n      window.open(url, '_blank');\n    }\n  }\n}","<div\n  class=\"n7-parallel-text-viewer {{data?.classes || ''}}\"\n  *ngIf=\"data && data.endpoint\"\n>\n  <pb-page \n    [attr.endpoint]=\"data.endpoint\" \n    api-version=\"1.0.0\" \n    url-path=\"query\"\n    [attr.url-ignore]=\"data.libOptions?.pbPage?.urlIgnore?.join(',') || 'odd,view,path,selectors,highlight,view2'\"\n  >\n    <!-- PB DOCUMENT-->\n    <pb-document\n      *ngFor=\"let doc of data.docs; index as $i\"\n      [attr.path]=\"doc.xml\"\n      [attr.odd]=\"doc.odd\"\n      [attr.id]=\"doc.id\"\n      [attr.view]=\"doc.view\"\n      [attr.disable-history]=\"doc.disableHistory === true ? '' : null\"\n      [attr.root-path]=\"doc.rootPath\"\n    >\n    </pb-document>\n\n    <app-drawer-layout force-narrow=\"force-narrow\" narrow=\"\">\n      <app-header-layout>\n        <app-header\n          fixed=\"fixed\"\n          data-template=\"browse:fix-links\"\n          style=\"\n            transition-duration: 0ms;\n            transform: translate3d(0px, 0px, 0px);\n            left: 0px;\n            right: 0.399994px;\n          \"\n        >\n          <app-toolbar\n            class=\"toolbar\"\n            sticky=\"sticky\"\n            style=\"transform: translate3d(0px, 0px, 0px)\"\n          >\n            <!-- TOC button -->\n            <paper-icon-button\n              id=\"tocToggle\"\n              class=\"toc-toggle\"\n              icon=\"icons:view-list\"\n              role=\"button\"\n              tabindex=\"0\"\n              aria-disabled=\"false\"\n            ></paper-icon-button>\n\n            <!-- Plain reading view-->\n            <pb-toggle-feature\n              *ngIf=\"data.docs?.length === 1\"\n              name=\"highlight1\"\n              selector=\"tei-app,pb-popover,pb-highlight,.quote,pb-alternate\"\n              default=\"off\"\n              action=\"disable\"\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n            >\n              <ng-container *ngIf=\"data.labels && data.labels.view\">\n                {{data.labels.view}}\n              </ng-container>\n              <ng-container *ngIf=\"!data.labels || !data.labels.view\">\n                <pb-i18n key=\"document.plain\">Plain Reading View</pb-i18n>\n              </ng-container>\n            </pb-toggle-feature>\n\n            <!-- Zoom Controls -->\n            <pb-zoom\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              direction=\"in\"\n              icon=\"icons:zoom-in\"\n            ></pb-zoom>\n            <pb-zoom\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              direction=\"out\"\n              icon=\"icons:zoom-out\"\n            ></pb-zoom>\n\n            <!-- Navigation Controls -->\n            <pb-navigation\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              keyboard=\"left\"\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n              direction=\"backward\"\n              unit=\"page\"\n            >\n              <paper-icon-button\n                icon=\"icons:chevron-left\"\n                role=\"button\"\n                tabindex=\"0\"\n                aria-disabled=\"false\"\n              ></paper-icon-button>\n            </pb-navigation>\n            <pb-navigation\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              keyboard=\"right\"\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n              direction=\"forward\"\n              unit=\"page\"\n            >\n              <paper-icon-button\n                icon=\"icons:chevron-right\"\n                role=\"button\"\n                tabindex=\"0\"\n                aria-disabled=\"false\"\n              ></paper-icon-button>\n            </pb-navigation>\n\n            <!-- Pulsante aggiungi pannello -->\n            <pb-grid-action \n              *ngIf=\"!data.libOptions?.grid?.disableAddColumn\"\n              action=\"add\" \n              class=\"grid-add\" \n              [attr.grid]=\"'#' + (data.grid?.id || 'grid')\"\n            >\n              <paper-button \n                role=\"button\" \n                tabindex=\"0\" \n                animated=\"\" \n                elevation=\"0\" \n                aria-disabled=\"false\"\n              >\n                <iron-icon icon=\"icons:add\"></iron-icon> \n                {{ data.labels?.addColumn || 'Aggiungi colonna' }}\n              </paper-button>\n            </pb-grid-action>\n\n            <!-- Pulsante download -->\n            <ng-container *ngIf=\"data.download\">\n              <div class=\"n7-parallel-text-viewer__toolbar-container-flex\">\n                <pb-download\n                  [type]=\"data.download.format || ''\"\n                  [src]=\"data.docs[0].id\"\n                  [url]=\"data.download.file || ''\"\n                  dialog=\"downloadDialog\"\n                  (click)=\"openDownload($event, data.download.file)\"\n                  [title]=\"data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : ''\"\n                >\n                  <paper-button raised=\"\">\n                    {{data.download.label && data.download.format ? data.download.label + ' ' + data.download.format : 'Download'}}\n                  </paper-button>\n                </pb-download>\n              </div>\n            </ng-container>\n\n            <pb-progress\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n              indeterminate=\"\"\n              bottom-item=\"bottom-item\"\n              style=\"visibility: hidden\"\n            ></pb-progress>\n          </app-toolbar>\n        </app-header>\n\n        <!-- Main Content with Parallel Grid -->\n        <main class=\"content-body\">\n          <pb-grid \n            [id]=\"data.grid?.id || 'grid'\"\n            [attr.panels]=\"data.grid?.panels ? '[' + data.grid.panels.join(',') + ']' : '[0]'\"\n            [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n            [attr.emit]=\"data.grid?.emit || 'transcription'\"\n          >\n            <!-- Main pb-->\n            <pb-view \n              id=\"transcription-view\"\n              [attr.src]=\"data.mainDoc.doc_id || data.docs[0].id\"\n              [attr.emit]=\"data.grid?.emit || 'transcription'\"\n              [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n              [attr.odd]=\"data.mainDoc.odd\"\n              [attr.view]=\"data.mainDoc.view\"\n              (click)=\"onClick($event)\"\n              [attr.url]=\"data.mainDoc.rootPath\"\n              append-footnotes=\"append-footnotes\"\n            >\n            <!-- Param per ricerca avanzata -->\n            <pb-param\n            *ngIf=\"data.mainDoc.url\"\n            name=\"url\"\n            [attr.value]=\"data.mainDoc.url\"\n          ></pb-param>\n            </pb-view>\n\n            <!-- Template -->\n            <template>\n              <pb-panel [attr.emit]=\"data.grid?.emit || 'transcription'\">\n                <!-- Rimozione colonna -->\n                <pb-grid-action \n                  [attr.grid]=\"'#' + (data.grid?.id || 'grid')\" \n                  slot=\"toolbar\" \n                  action=\"remove\"\n                >\n                  <paper-icon-button icon=\"icons:close\"></paper-icon-button>\n                </pb-grid-action>\n\n                <!-- Pannelli secondari -->\n                \n                <ng-container *ngFor=\"let panel of data.panels\">\n                  <ng-container *ngIf=\"panel.enabled\">\n                    <ng-container [ngSwitch]=\"panel.type\">\n\n                      <ng-container *ngSwitchCase=\"'text'\">\n                      <template [attr.title]=\"panel.title\">\n                      <pb-view \n                        [attr.id]=\"panel.id + '-view'\"\n                        [attr.src]=\"panel.doc_id || data.docs[0].id\"\n                        [attr.odd]=\"panel.odd\"\n                        [attr.view]=\"panel.view || 'single'\"\n                        [attr.xpath]=\"panel.xpath\"\n                        [attr.map]=\"panel.mapFunction\"\n                        [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n                        (click)=\"onClick($event)\"\n                        [attr.url]=\"data.mainDoc.rootPath\"\n                        disable-history=\"\"\n                      >\n                        <pb-param \n                          *ngFor=\"let param of panel.params || []\"\n                          [attr.name]=\"param.name\"\n                          [attr.value]=\"param.value\"\n                        ></pb-param>\n                      </pb-view>\n                    </template>\n                  </ng-container>\n\n                  <ng-container *ngSwitchCase=\"'facsimile'\">\n                    <template [attr.title]=\"panel.title\">\n                      <pb-facsimile\n                      *ngIf=\"panel.facsimile?.enabled\"\n                      [attr.base-uri]=\"panel.facsimile.uri\"\n                      [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n                      class=\"pb-facsimile\"\n                      [style.height]=\"panel.facsimile.options?.height || '600px'\"\n                      [attr.default-zoom-level]=\"panel.facsimile.options?.defaultZoomLevel || 0\"\n                      [attr.show-navigator]=\"panel.facsimile.options?.showNavigator ? 'show-navigator' : null\"\n                      [attr.show-navigation-control]=\"panel.facsimile.options?.showNavigationControl ? 'show-navigation-control' : null\"\n                      [attr.show-home-control]=\"panel.facsimile.options?.showHomeControl ? 'show-home-control' : null\"\n                      [attr.show-rotation-control]=\"panel.facsimile.options?.showRotationControl ? 'show-rotation-control' : null\"\n                      [attr.show-full-page-control]=\"panel.facsimile.options?.showFullPageControl ? 'show-full-page-control' : null\"\n                      [scans]=\"panel.facsimile.scans\"\n                    >\n                    </pb-facsimile>\n                    </template>\n                  </ng-container>\n                </ng-container>\n              </ng-container>\n              </ng-container>\n\n              </pb-panel>\n            </template>\n          </pb-grid>\n        </main>\n\n        <!-- TOC Drawer -->\n        <pb-drawer\n          toggle=\"tocToggle\"\n          class=\"tocDrawer\"\n          emit=\"toc\"\n          [attr.subscribe]=\"data.grid?.subscribe || 'transcription'\"\n        >\n          <div class=\"drawer-content\">\n            <h3>\n              <ng-container *ngIf=\"data.labels && data.labels.toc\">\n                {{data.labels.toc}}\n              </ng-container>\n              <ng-container *ngIf=\"!data.labels || !data.labels.toc\">\n                <pb-i18n key=\"document.contents\">Contents</pb-i18n>\n              </ng-container>\n            </h3>\n            <pb-load\n              *ngIf=\"data.docs && data.docs.length > 0 && !data.libOptions?.toc?.disable\"\n              id=\"toc\"\n              [attr.url]=\"data.mainDoc.rootPath ? (data.mainDoc.rootPath + '/' + data.mainDoc.doc_id + '/contents?target=transcription&icons=true') : 'api/document/{doc}/contents?target=transcription&icons=true'\"\n              [attr.src]=\"data.mainDoc.doc_id\"\n              subscribe=\"toc\"\n              emit=\"toc\"\n              expand=\"expand\"\n              auto=\"auto\"\n            >\n              <ng-container *ngIf=\"data.labels && data.labels.loading\">\n                {{data.labels.loading}}\n              </ng-container>\n              <ng-container *ngIf=\"!data.labels || !data.labels.loading\">\n                <pb-i18n key=\"dialogs.loading\">Loading</pb-i18n>\n              </ng-container>\n            </pb-load>\n          </div>\n        </pb-drawer>\n      </app-header-layout>\n    </app-drawer-layout>\n  </pb-page>\n</div>\n\n"]}
|