Jump to content

clangstaff

School User
  • Posts

    432
  • Joined

  • Last visited

Posts posted by clangstaff

  1. 1 hour ago, Graham Quince said:

    Hi @clangstaff

    Wouldn't the page link option in the text widget do what you're after?

    The text widget would but if feasible I'd prefer to use the format of the external link widget for consistency across the platform. If not I'll be using the text widget.

  2. @Graham Thorpe if we could get this in for Dickens we'll be very happy - we are launching assignments including the 'Homework Portal' soon after Christmas.

    @Chris.Smith Thanks for that I'll take a look when i get some time.

     

    I've been trying to work out how we can reorder our list of assignments to show the ones with the closest deadlines rather than the assignments with the furthest away deadlines - is this possible? I can't find any other 'order' commands listed anywhere.

     

        var assignments = FrogOS.fdp({
            url: 'assignment/getAssigned',
            data: { status: 'open', limit: 5, order: 'start desc' }
        });

     

  3. Don't seem to have the option to edit my previous post to add this. One thing that would quickly and drastically improve the assignments facility is if when an assignment is created through assignment manager it is added to a mobile friendly theme - surely this has to be a relatively quick fix?

    Below is how the student homework portal looks on an android phone - it's clear and easy to follow but is let down when clicking in to an assignment as the content does not auto adjust to the screen.

     

    homework-portal-mobile-small.png

    • Like 3
  4. @Graham Quince  @Chris.Smith Even better could we have a couple of links to the right of each assignment - Quick view to view as student and another to open within Assignment Manager.

    In the future I'll be looking to build a similar homework page for parents so if anyone has anything created already - please let me know!

    Thanks,

     

     

    • Like 1
  5. @Chris.Smith Thanks for your help - I wasn't too far off in the end.

    Updated code for anyone who wants it. Also see attached our first attempt at a 'Homework portal' Each page will be embedded within the staff and student dashboards. After christmas all homework will begin to be driven through Frog.

    <style>
    .trs-student-current-assignments-widget {
    background-color: #ffffff;
    border-radius: 5px;
    overflow: hidden;
    }
    .trs-student-current-assignments-widget .assignment-widget-header {
    background-color: #231f20;
    padding: 1em;
    position: relative;
    text-align: left;
    }
    .trs-student-current-assignments-widget .assignment-widget-header::after {
    content: "";
    width: 98%;
    height: 60%;
    position: absolute;
    top: 3%;
    left: 1%;
    border-radius: 5px;
    }
    .trs-student-current-assignments-widget .assignment-widget-header h1 {
    color: #fff;
    font-size: 20px;
    margin: 0;
    }   
    .trs-student-current-assignments-widget .no-homework {
    padding: 1em;
    text-align: center;
    }
    .trs-student-current-assignments-widget .assignment-list {
    list-style: none;
    padding: 0 1em;
    margin:0 0 0 0;
    }    
        
    
        
    .trs-student-current-assignments-widget .assignment-list :hover{
    background-color:#ededed;
    }        
        
    .trs-student-current-assignments-widget .assignment-list .assignment-link {
    border-bottom: 1px solid #ddd;
    padding: 10px 10px  10px 10px;
    margin: 0.5em 0;
    cursor: pointer;
    }
        
    .trs-student-current-assignments-widget .assignment-list .assignment-link p {
    margin: 0;
    }
    .trs-student-current-assignments-widget .assignment-list .assignment-link .assign-icon {
    width: 32px;
    height: 32px;
    display: block;
    float: left;
    margin-top: 2px;
    background: url() no-repeat;
    }
        
    .trs-student-current-assignments-widget .assignment-list .assignment-link .assign-details {
    padding: 0 1em;
    float: left;
    }
    </style>
    
    <div class="trs-student-current-assignments-widget">
        <div class="assignment-widget-header">
            <h1>My Recent Homework</h1>
        </div>
        <p class="no-homework">You've not been set any homework yet</p>
        <ul class="assignment-list" style="display: none;">
            
        </ul>
    </div>
    
    <script>
    
        var getHTMLElem = arguments[0];
        
        var assignments = FrogOS.fdp({
            url: 'assignment/getAssigned',
            data: { status: 'open', limit: 5, order: 'start desc' }
        });
    
        assignments.done(function(data) {
           var assignments = data.response.assignments,
        assignment;
    
    for (var uuid in assignments) {
    	if (assignments.hasOwnProperty(uuid)) {
    		assignment = assignments[uuid].assignment;
          
                    
                    getHTMLElem.find('.assignment-list').show();
                    getHTMLElem.find('.trs-student-current-assignments-widget .no-homework').hide();
                
                    var assignSubject = '<p><strong>' + assignment.subject.name + '</strong></p>';
                    var assignTitle = '<p>' + assignment.name + '</p>';
                    var assignEnd = '<p style="color: red;"><strong>Due: ' + moment(assignment.end, 'X').format('Do MMM YYYY') + '</strong></p>';
                    var assignLink = assignment.link;
                
                    var liElem = '<li class="assignment-link clearfix" data-assignment-link="' + assignLink + '"><div class="assign-icon"></div><div class="assign-details">' + assignSubject + '' + assignTitle + '' + assignEnd + '</div></li>';
                
                    getHTMLElem.find('.trs-student-current-assignments-widget .assignment-list').append(liElem);
                    
                }
            }
        });
        
        $(getHTMLElem).on('click', '.assignment-link', function(el){
            $(this).trigger('os.app.siteviewer', {
                data: { site: el.currentTarget.dataset.assignmentLink }
            });
        });
        </script>

     

    staff-homework-portal.png

    student-homework-portal.png

    • Like 1
  6. I've been trying to create a replica of the code below but for students rather than staff. I prefer the layout of this and find it easier to work with than the cloning table row method used in the example for students. I am however, struggling to replicate this with student data can anyone spot where I'm going wrong? @Chris.Smith @Graham Quince

    Staff Code working fine:

    <style>
    .trs-staff-current-assignments-widget {
    background-color: #ffffff;
    border-radius: 5px;
    overflow: hidden;
    }
    .trs-staff-current-assignments-widget .assignment-widget-header {
    background-color: #231f20;
    padding: 1em;
    position: relative;
    text-align: left;
    }
    .trs-staff-current-assignments-widget .assignment-widget-header::after {
    content: "";
    width: 98%;
    height: 60%;
    position: absolute;
    top: 3%;
    left: 1%;
    border-radius: 5px;
    }
    .trs-staff-current-assignments-widget .assignment-widget-header h1 {
    color: #fff;
    font-size: 20px;
    margin: 0;
    }   
    .trs-staff-current-assignments-widget .no-homework {
    padding: 1em;
    text-align: center;
    }
    .trs-staff-current-assignments-widget .assignment-list {
    list-style: none;
    padding: 0 1em;
    }    
        
    .trs-staff-current-assignments-widget .assignment-list :hover{
    background-color:#ededed;
    }        
        
    .trs-staff-current-assignments-widget .assignment-list .assignement-link {
    border-bottom: 1px solid #ddd;
    padding: 10px 10px  10px 10px;
    margin: 0.5em 0;
    cursor: pointer;
    }
        
    .trs-staff-current-assignments-widget .assignment-list .assignement-link p {
    margin: 0;
    }
    .trs-staff-current-assignments-widget .assignment-list .assignement-link .assign-icon {
    width: 32px;
    height: 32px;
    display: block;
    float: left;
    margin-top: 2px;
    background: url() no-repeat;
    }
    .trs-staff-current-assignments-widget .assignment-list .assignement-link .assign-details {
    padding: 0 1em;
    float: left;
    }
    </style>
    
    <div class="trs-staff-current-assignments-widget">
        <div class="assignment-widget-header">
            <h1>My Recent Homework</h1>
        </div>
        <p class="no-homework">You've not set any homework yet</p>
        <ul class="assignment-list" style="display: none;">
            
        </ul>
    </div>
    
    <script>
    
        var getHTMLElem = arguments[0];
        
        var assignments = FrogOS.fdp({
            url: 'assignment/getCreated',
            data: { status: 'open', limit: 5, order: 'start desc' }
        });
    
        assignments.done(function(data) {
            var staffAssignments = data.response.assignments;
            for (var uuid in staffAssignments) {
                if (staffAssignments.hasOwnProperty(uuid)) {
                    
                    getHTMLElem.find('.assignment-list').show();
                    getHTMLElem.find('.trs-staff-current-assignments-widget .no-homework').hide();
                
                    var assignSubject = '<p><strong>' + staffAssignments[uuid].subject.name + '</strong></p>';
                    var assignTitle = '<p>' + staffAssignments[uuid].name + '</p>';
                    var assignEnd = '<p style="color: red;"><strong>Due: ' + moment(staffAssignments[uuid].end, 'X').format('Do MMM YYYY') + '</strong></p>';
                    var assignLink = staffAssignments[uuid].link;
                
                    var liElem = '<li class="assignement-link clearfix" data-assignment-link="' + assignLink + '"><div class="assign-icon"></div><div class="assign-details">' + assignSubject + '' + assignTitle + '' + assignEnd + '</div></li>';
                
                    getHTMLElem.find('.trs-staff-current-assignments-widget .assignment-list').append(liElem);
                    
                }
            }
        });
        
        $(getHTMLElem).on('click', '.assignement-link', function(el){
            $(this).trigger('os.app.siteviewer', {
                data: { site: el.currentTarget.dataset.assignmentLink }
            });
        });
        
    </script>

    Student code attempt:

    <style>
    .trs-student-current-assignments-widget {
    background-color: #ffffff;
    border-radius: 5px;
    overflow: hidden;
    }
    .trs-student-current-assignments-widget .assignment-widget-header {
    background-color: #231f20;
    padding: 1em;
    position: relative;
    text-align: left;
    }
    .trs-student-current-assignments-widget .assignment-widget-header::after {
    content: "";
    width: 98%;
    height: 60%;
    position: absolute;
    top: 3%;
    left: 1%;
    border-radius: 5px;
    }
    .trs-student-current-assignments-widget .assignment-widget-header h1 {
    color: #fff;
    font-size: 20px;
    margin: 0;
    }   
    .trs-student-current-assignments-widget .no-homework {
    padding: 1em;
    text-align: center;
    }
    .trs-student-current-assignments-widget .assignment-list {
    list-style: none;
    padding: 0 1em;
    }    
        
    .trs-student-current-assignments-widget .assignment-list :hover{
    background-color:#ededed;
    }        
        
    .trs-student-current-assignments-widget .assignment-list .assignement-link {
    border-bottom: 1px solid #ddd;
    padding: 10px 10px  10px 10px;
    margin: 0.5em 0;
    cursor: pointer;
    }
        
    .trs-student-current-assignments-widget .assignment-list .assignement-link p {
    margin: 0;
    }
    .trs-student-current-assignments-widget .assignment-list .assignement-link .assign-icon {
    width: 32px;
    height: 32px;
    display: block;
    float: left;
    margin-top: 2px;
    background: url() no-repeat;
    }
    .trs-student-current-assignments-widget .assignment-list .assignement-link .assign-details {
    padding: 0 1em;
    float: left;
    }
    </style>
    
    <div class="trs-student-current-assignments-widget">
        <div class="assignment-widget-header">
            <h1>My Recent Homework</h1>
        </div>
        <p class="no-homework">You've not been set any homework yet</p>
        <ul class="assignment-list" style="display: none;">
            
        </ul>
    </div>
    
    <script>
    
        var getHTMLElem = arguments[0];
        
        var assignments = FrogOS.fdp({
            url: 'assignment/getAssigned',
            data: { status: 'open', limit: 5, order: 'start desc' }
        });
    
        assignments.done(function(data) {
            var assignments = data.response.assignments;
            for (var uuid in assignments) {
                if (assignments.hasOwnProperty(uuid)) {
                    
                    getHTMLElem.find('.assignment-list').show();
                    getHTMLElem.find('.trs-student-current-assignments-widget .no-homework').hide();
                
                    var assignSubject = '<p><strong>' + assignments[uuid].subject.name + '</strong></p>';
                    var assignTitle = '<p>' + assignments[uuid].name + '</p>';
                    var assignEnd = '<p style="color: red;"><strong>Due: ' + moment(assignments[uuid].end, 'X').format('Do MMM YYYY') + '</strong></p>';
                    var assignLink = assignments[uuid].link;
                
                    var liElem = '<li class="assignment-link clearfix" data-assignment-link="' + assignLink + '"><div class="assign-icon"></div><div class="assign-details">' + assignSubject + '' + assignTitle + '' + assignEnd + '</div></li>';
                
                    getHTMLElem.find('.trs-student-current-assignments-widget .assignment-list').append(liElem);
                    
                }
            }
        });
        
        $(getHTMLElem).on('click', '.assignment-link', function(el){
            $(this).trigger('os.app.siteviewer', {
                data: { site: el.currentTarget.dataset.assignmentLink }
            });
        });
        </script>

     

  7. @THaines we are an Office 365 school so have gone down this route.

    We have a member of staff who updates a single staff only calendar, any events on this calendar can then be shared with another account on creation. We have another account set up for parents and the wider public.

    This works great as all office 365 users automatically have the school calendar added to their account but we can also share the calendars we want to with whoever we want to without duplicating events. In theory you could do this with as many calendars as you liked, having another for students, sporting events and so on.

    My only negative for this system is that Office 365 is very limited when it comes to customisation of the look of a calendar when showing this publicly (to users that aren't logged in). A solution would be to import the calendar in to a Google account which gives you some further options for customisation. I'm still not massively happy with the look of the Google calendar embeds but without a public web server this has it's limitations.

     

  8. @Graham Quince I thought I'd have a quick look at the snow code but this doesn't seem to be working for me when pasted in to a HTML widget on a site.

     

    <style>
    .snowflakes {
        position: absolute;
        left: 5%;
        top: -15px;
        width: 90%;
        overflow: visible;
    }
    .snowflake {
        position: absolute;
        color: #fff;
        -webkit-animation: falling 4.7s linear 0s infinite;
        -moz-animation: falling 4.7s linear 0s infinite;
        animation: falling 4.7s linear 0s infinite;
    }
    @-webkit-keyframes falling {
        0% {
            -webkit-transform: translate3d(0, 0, 0) rotate(0deg);
        }
        95% {
            opacity: 0.8;
        }
        100% {
            -webkit-transform: translate3d(0, 0, 0) rotate(360deg);
        }
    }
    @-moz-keyframes falling {
        0% {
            -moz-transform: translate3d(0, 0, 0) rotate(0deg);
        }
        95% {
            opacity: 0.8;
        }
        100% {
            -moz-transform: translate(0, 0) rotate(360deg);
        }
    }
    @keyframes falling {
        0% {
            transform: translate3d(0, 0, 0) rotate(0deg);
        }
        95% {
            opacity: 0.8;
        }
        100% {
            transform: translate(0, 0) rotate(360deg);
        }
    }
    .uk_primary .os-titlebar .navbar-inner {
        background-color: #d62441!important;
        border-bottom: 3px solid #980000 !important
    }
    body.uk_primary .os-titlebar .navbar-search input {
        background-color: #980000 !important;
        border-color: #980000 !important;
    }
    </style>
    <script>
    var frogRevealingModule = (function() {
        var keyframeprefix = '',
            domPrefixes = 'Webkit Moz O ms Khtml'.split(' '),
            pfx = '',
            elm = document.createElement('div'),
            snowing = new $.Deferred();
        for (var i = 0; i < domPrefixes.length; i++) {
            if (elm.style[domPrefixes[i] + 'AnimationName'] !== undefined) {
                pfx = domPrefixes[i];
                keyframeprefix = '-' + pfx.toLowerCase() + '-';
                break;
            }
        }
        var randInt = function(from, to) {
            return Math.floor(Math.random() * (to - from + 1) + from);
        };
        var findKeyframeAnimation = function(a) {
            var ss = document.styleSheets;
            for (var i = ss.length - 1; i >= 0; i--) {
                try {
                    var s = ss[i],
                        rs = s.cssRules ? s.cssRules :
                        s.rules ? s.rules : [];
                    for (var j = rs.length - 1; j >= 0; j--) {
                        if ((rs[j].type === window.CSSRule.WEBKIT_KEYFRAMES_RULE || rs[j].type === window.CSSRule.MOZ_KEYFRAMES_RULE) && rs[j].name == a) {
                            return rs[j];
                        }
                    }
                    // Trying to interrogate a stylesheet from
                    // another domain will throw a security error
                } catch (e) {}
            }
            return null;
        };
        $.fn.snow = function(options) {
            options = options || {};
            var me = this,
                count = options.flakeCount || 20,
                minDiameter = options.minDiameter || 20,
                maxDiameter = options.maxDiameter || 35,
                minOpacity = options.minOpacity || 50,
                maxOpacity = options.maxOpacity || 100,
                height = this.height(),
                flakes = [],
                keyframes = findKeyframeAnimation('falling'),
                characters = ['&#10052;', '&#10053;', '&#10054;', '*'];
            if (keyframes) {
                keyframes[(typeof keyframes.insertRule == 'function') ? 'insertRule' : 'appendRule'](
                    '100% { ' + keyframeprefix + 'transform: translate3d(0,' +
                    height + 'px,0) rotate(360deg); opacity:0; }'
                );
            }
            var i = count,
                size, css, origin;
            while (i--) {
                size = randInt(minDiameter, maxDiameter);
                origin = size / 2;
                css = {
                    left: randInt(0, 100) + '%',
                    'font-size': size + 'px',
                    height: size + 'px',
                    width: size + 'px',
                    opacity: randInt(minOpacity, maxOpacity) * 0.01,
                    top: (-size - 20) + 'px'
                };
                css[keyframeprefix + 'transform-origin'] = origin + 'px ' + origin + 'px';
                css[keyframeprefix + 'animation-delay'] = (Math.random() * 10) + 's';
                flakes.push($('<div></div>').html(
                    characters[randInt(0, characters.length - 1)]
                ).attr({
                    'class': 'snowflake'
                }).css(css).appendTo(this));
            }
            this.on('webkitAnimationIteration animationIteration', function(e) {
                $(e.target).css('left', randInt(0, 100) + '%');
            });
            this.data('snow', {
                flakes: flakes
            });
            return this;
        };
        function makeItSnow() {
            $('.dashboard-1, .dashboard-0').snow({
                flakeCount: 50,
                minDiameter: 10,
                maxDiameter: 80
            });
        };
        return {
            snow: makeItSnow
        };
    })();
    setTimeout(function() {
        frogRevealingModule.snow();
    }, 3000);
    </script>

     

  9. Not sure if this is a solution or not as Twitter is blocked on our network so we don't use this but have you tried adding the twitter feeds to different sites and then nesting them on to the page you want them to be shown on?

  10. Does anyone know how you might go about customising a Google calendar iframe further than the basic options they provide? I found the link below however, I don't think it will be possible for us to do this as we don't have access to a web server to store the files. Am I right in think there is not an area within Frog where code files can be stored and referenced within other files?

    http://www.webdesignerdepot.com/2012/04/integrating-google-calendar-with-your-website/

    <iframe src="https://calendar.google.com/calendar/embed?title=Parent%20Calendar&amp;showTitle=0&amp;showNav=0&amp;showPrint=0&amp;showTabs=0&amp;mode=AGENDA&amp;height=600&amp;wkst=2&amp;bgcolor=%23ffffff&amp;src=n32jc49pup7jdbj3u65bikv6ft9s4gse%40import.calendar.google.com&amp;color=%23af0f2a&amp;ctz=Europe%2FLondon" style="border-width:0" width="400" height="600" frameborder="0" scrolling="no"></iframe>

     

    @Graham Quince @John Elliott

  11. Secure Gateway is a relatively cheap solution for remote access - It's pretty basic and a PC would have to remain turned on with a user logged in which is the main downside.

    You can get really powerful remote login software which will allow any number of users to remote in to a server rather than a specific PC however, the cost involved in this kind of solution is huge.

  12. Thanks for the response Graham, the W3 schools page is what I was working from trying to get a solution but I couldn't make much sense of it. I think I probably need to spend some time working from the very basics with JavaScript

  13. I'm trying to create a sticky banner for our public website that will include the current date and current timetable week. So far I've pulled together the code below however, I'm having some issues with the date format and cannot get this to change.

    Ideally the format would be 'Mon 7th November'.

     

    <style>
    .banner-box { 
    margin: 0; 
    padding:10px;
    position: fixed; 
    bottom: 100px; 
    right: 0; 
    width: 150px; 
    height: auto; 
    z-index: 100; 
    display: none; 
    text-decoration: none; 
    color: #ffffff; 
    background-color: #1d2129;
    font-size:16px;
    text-align:center;
     
    }
        
    </style>
    
    <div class="banner-box" style="display: inline;">
        
    <p id="date"></p>
       
    <script>
    document.getElementById("date").innerHTML = Date() ;
    
    </script>
    
    <p><b>Week 1</b><br/></p>
        
    </div>

     

    banner.png

×
×
  • Create New...