當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript vega-event-selector.selector函數代碼示例

本文整理匯總了TypeScript中vega-event-selector.selector函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript selector函數的具體用法?TypeScript selector怎麽用?TypeScript selector使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了selector函數的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: it

 it('builds them for default invocation', () => {
   model.component.selection = {four: selCmpts['four']};
   const signals = assembleUnitSelectionSignals(model, []);
   expect(signals).toEqual(
     expect.arrayContaining([
       {
         name: 'four_translate_anchor',
         value: {},
         on: [
           {
             events: parseSelector('@four_brush:mousedown', 'scope'),
             update: '{x: x(unit), y: y(unit), extent_x: slice(four_x), extent_y: slice(four_y)}'
           }
         ]
       },
       {
         name: 'four_translate_delta',
         value: {},
         on: [
           {
             events: parseSelector('[@four_brush:mousedown, window:mouseup] > window:mousemove!', 'scope'),
             update: '{x: four_translate_anchor.x - x(unit), y: four_translate_anchor.y - y(unit)}'
           }
         ]
       }
     ])
   );
 });
開發者ID:vega,項目名稱:vega-lite,代碼行數:28,代碼來源:translate.test.ts

示例2: it

 it('builds them for custom events', () => {
   const {model, selCmpts} = getModel();
   model.component.selection = {five: selCmpts['five']};
   const signals = assembleUnitSelectionSignals(model, []);
   expect(signals).toEqual(
     expect.arrayContaining([
       {
         name: 'five_zoom_anchor',
         on: [
           {
             events: parseSelector('@five_brush:wheel, @five_brush:pinch', 'scope'),
             update: '{x: x(unit), y: y(unit)}'
           }
         ]
       },
       {
         name: 'five_zoom_delta',
         on: [
           {
             events: parseSelector('@five_brush:wheel, @five_brush:pinch', 'scope'),
             force: true,
             update: 'pow(1.001, event.deltaY * pow(16, event.deltaMode))'
           }
         ]
       }
     ])
   );
 });
開發者ID:vega,項目名稱:vega-lite,代碼行數:28,代碼來源:zoom.test.ts

示例3: it

 it('appends clear transform', () => {
   const intervalOneSg = interval.signals(model, selCmpts['one']);
   const oneSg = clear.signals(model, selCmpts['one'], intervalOneSg);
   expect(oneSg).toEqual(
     expect.arrayContaining([
       {
         name: 'one_Horsepower',
         on: [
           {
             events: parseSelector('dblclick', 'scope'),
             update: 'null'
           }
         ]
       },
       {
         name: 'one_Miles_per_Gallon',
         on: [
           {
             events: parseSelector('dblclick', 'scope'),
             update: 'null'
           }
         ]
       }
     ])
   );
 });
開發者ID:vega,項目名稱:vega-lite,代碼行數:26,代碼來源:clear.test.ts

示例4: it

  it('supports inline default overrides', () => {
    const component = parseUnitSelection(model, {
      one: {
        type: 'single',
        on: 'dblclick',
        fields: ['Cylinders']
      },
      two: {
        type: 'multi',
        on: 'mouseover',
        toggle: 'event.ctrlKey',
        encodings: ['color']
      },
      three: {
        type: 'interval',
        on: '[mousedown[!event.shiftKey], mouseup] > mousemove',
        encodings: ['y'],
        translate: false,
        zoom: 'wheel[event.altKey]'
      }
    });

    expect(keys(component)).toEqual(['one', 'two', 'three']);

    expect(component.one.name).toBe('one');
    expect(component.one.type).toBe('single');
    expect(component['one'].project.items).toEqual(
      expect.arrayContaining([{field: 'Cylinders', type: 'E', signals: {data: 'one_Cylinders'}}])
    );
    expect(component['one'].events).toEqual(parseSelector('dblclick', 'scope'));

    expect(component.two.name).toBe('two');
    expect(component.two.type).toBe('multi');
    expect(component.two.toggle).toBe('event.ctrlKey');
    expect(component['two'].project.items).toEqual(
      expect.arrayContaining([
        {field: 'Origin', channel: 'color', type: 'E', signals: {data: 'two_Origin', visual: 'two_color'}}
      ])
    );
    expect(component['two'].events).toEqual(parseSelector('mouseover', 'scope'));

    expect(component.three.name).toBe('three');
    expect(component.three.type).toBe('interval');
    expect(component.three.translate).toEqual(false);
    expect(component.three.zoom).toBe('wheel[event.altKey]');
    expect(component['three'].project.items).toEqual(
      expect.arrayContaining([
        {
          field: 'Miles_per_Gallon',
          channel: 'y',
          type: 'R',
          signals: {data: 'three_Miles_per_Gallon', visual: 'three_y'}
        }
      ])
    );
    expect(component['three'].events).toEqual(
      parseSelector('[mousedown[!event.shiftKey], mouseup] > mousemove', 'scope')
    );
  });
開發者ID:vega,項目名稱:vega-lite,代碼行數:59,代碼來源:parse.test.ts

示例5: parseUnitSelection

export function parseUnitSelection(model: UnitModel, selDefs: Dict<SelectionDef>) {
  const selCmpts: Dict<SelectionComponent<any /* this has to be "any" so typing won't fail in test files*/>> = {};
  const selectionConfig = model.config.selection;

  if (selDefs) {
    selDefs = duplicate(selDefs); // duplicate to avoid side effects to original spec
  }

  for (let name in selDefs) {
    if (!selDefs.hasOwnProperty(name)) {
      continue;
    }

    const selDef = selDefs[name];
    const {fields, encodings, ...cfg} = selectionConfig[selDef.type]; // Project transform applies its defaults.

    // Set default values from config if a property hasn't been specified,
    // or if it is true. E.g., "translate": true should use the default
    // event handlers for translate. However, true may be a valid value for
    // a property (e.g., "nearest": true).
    for (const key in cfg) {
      // A selection should contain either `encodings` or `fields`, only use
      // default values for these two values if neither of them is specified.
      if ((key === 'encodings' && selDef.fields) || (key === 'fields' && selDef.encodings)) {
        continue;
      }

      if (key === 'mark') {
        selDef[key] = {...cfg[key], ...selDef[key]};
      }

      if (selDef[key] === undefined || selDef[key] === true) {
        selDef[key] = cfg[key] || selDef[key];
      }
    }

    name = varName(name);
    const selCmpt = (selCmpts[name] = {
      ...selDef,
      name: name,
      events: isString(selDef.on) ? parseSelector(selDef.on, 'scope') : selDef.on
    } as any);

    forEachTransform(selCmpt, txCompiler => {
      if (txCompiler.parse) {
        txCompiler.parse(model, selDef, selCmpt);
      }
    });
  }

  return selCmpts;
}
開發者ID:vega,項目名稱:vega-lite,代碼行數:52,代碼來源:parse.ts

示例6: parseSelector

  signals: (model, selCmpt, signals) => {
    const name = selCmpt.name;
    const hasScales = scalesCompiler.has(selCmpt);
    const anchor = name + ANCHOR;
    const {x, y} = selCmpt.project.has;
    let events = parseSelector(selCmpt.translate, 'scope');

    if (!hasScales) {
      events = events.map(e => ((e.between[0].markname = name + INTERVAL_BRUSH), e));
    }

    signals.push(
      {
        name: anchor,
        value: {},
        on: [
          {
            events: events.map(e => e.between[0]),
            update:
              '{x: x(unit), y: y(unit)' +
              (x !== undefined ? ', extent_x: ' + (hasScales ? domain(model, X) : `slice(${x.signals.visual})`) : '') +
              (y !== undefined ? ', extent_y: ' + (hasScales ? domain(model, Y) : `slice(${y.signals.visual})`) : '') +
              '}'
          }
        ]
      },
      {
        name: name + DELTA,
        value: {},
        on: [
          {
            events: events,
            update: `{x: ${anchor}.x - x(unit), y: ${anchor}.y - y(unit)}`
          }
        ]
      }
    );

    if (x !== undefined) {
      onDelta(model, selCmpt, x, 'width', signals);
    }

    if (y !== undefined) {
      onDelta(model, selCmpt, y, 'height', signals);
    }

    return signals;
  }
開發者ID:vega,項目名稱:vega-lite,代碼行數:48,代碼來源:translate.ts


注:本文中的vega-event-selector.selector函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。