npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@b1cloud/angular-weekly-scheduler

v0.0.13

Published

A scheduler using weeks for AngularJS

Downloads

25

Readme

angular-weekly-scheduler

A weekly scheduler for angularjs

Build Status

Online Demo

http://www.dijit.fr/demo/angular-weekly-scheduler/

screenshot

Plunker

https://embed.plnkr.co/CImLQFfbd64JFezNBTWQ/

Run @ Home

Run the demo @home with few steps (prerequisite git & node V0.10+ & npm installed):

 git clone https://github.com/fmaturel/angular-weekly-scheduler.git && cd angular-weekly-scheduler
 npm install
 npm install -g grunt-cli

Then run

grunt serve:dist

Install

bower install --save angular-weekly-scheduler

or

npm install --save angular-weekly-scheduler

Add the scripts and css to your index.html. The angular-locale_xx-xx.js file is your locale file

  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.6/css/bootstrap.min.css">
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.10/angular.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-i18n/1.4.10/angular-locale_xx-xx.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.13.0/moment.js"></script>
  
  <!-- The library to replace with your local copy of ng-weekly-scheduler -->
  <script src="https://github.com/fmaturel/angular-weekly-scheduler/blob/master/dist/js/ng-weekly-scheduler.js"></script>

Add dependency to timeline your angular module: weeklyScheduler.

Use the directive:

<weekly-scheduler class="scheduler" ng-model="myScopeModel" options="options"></weekly-scheduler>

Features

This directive displays a weekly item scheduler. You can see, add and modify items easily.

Keyboard shortcuts

  • Use mouse wheel on schedule to scroll left and right
  • Use ctrl + mouse wheel to zoom in and out the schedule

Schedules

:information_source: This directive uses MomentJS to position items and calculate localized calendar weeks. Drag the time bar start, end and body to quickly change your schedule period. You can set an editable variable on each item, that will be used to disable item edition if false.

"items": [{
  "label": "Item 1",
  "editable": false,
  "schedules": [
    {
      "start": "2015-12-26T23:00:00.000Z",
      "end": "2016-07-31T22:00:00.000Z"
    }
  ]
}, ...]

Transclusion

This directive is using ng-transclude so that everything in <weekly-scheduler> element will be treated as the labelling object of one item.

<div class="srow">{{::$index + 1}}. {{item.label}}</div>

On transcluded item label, the scope contains item attribute name containing each item model and regular ng-repeat :repeat: scope attributes

Internationalisation (i18n)

I18N uses dynamic angular $locale change. An i18n module named weeklySchedulerI18N is optionally registered when using the core module :

angular.module('demoApp', ['weeklyScheduler', 'weeklySchedulerI18N'])

If present, core directive will retrieve current $locale and use it to translate labelling elements. You can add more $locale translation using provider weeklySchedulerLocaleServiceProvider:

angular.module('demoApp', ['weeklyScheduler', 'weeklySchedulerI18N'])
  .config(['weeklySchedulerLocaleServiceProvider', function (localeServiceProvider) {
    localeServiceProvider.configure({
      doys: {'es-es': 4},
      lang: {'es-es': {month: 'Mes', weekNb: 'número de la semana', addNew: 'Añadir'}},
      localeLocationPattern: '/vendor/angular-i18n/angular-locale_{{locale}}.js'
    });
  }])

Animation

You can add animation to the weekly scheduler directive easily by importing angular module ngAnimate. Your application could for instance use :

angular.module('demoApp', ['ngAnimate', 'weeklyScheduler'])

Don't forget to add the angular-animate javascript file to your Single Page App index.html.

<script src="/vendor/angular-animate/angular-animate.js"></script>

Styling can be changed to whatever you like. This is an example of fading-in items entering the DOM :

.schedule-animate {
  transition: opacity 200ms ease-out;
}
.schedule-animate.ng-enter, .schedule-animate.ng-hide-remove {
  opacity: 0;
}
.schedule-animate.ng-leave, .schedule-animate.ng-hide-add {
  display: none;
  opacity: 1;
}

You should see your scheduler items fading in!

License

Released under the MIT License. See the LICENSE file for further details.